Keystroke-level model
In human–computer interaction, the keystroke-level model (KLM) predicts how long it will take an expert user to accomplish a routine task without errors using an interactive computer system.[1] It was proposed by Stuart K. Card, Thomas P. Moran and Allen Newell in 1980 in the Communications of the ACM and published in their book The Psychology of Human-Computer Interaction in 1983, which is considered as a classic in the HCI field.[2][3] The foundations were laid in 1974, when Card and Moran joined the Palo Alto Research Center (PARC) and created a group named Applied Information-Processing Psychology Project (AIP) with Newell as a consultant aiming to create an applied psychology of human-computer interaction.[4] The keystroke-level model is still relevant today, which is shown by the recent research about mobile phones and touchscreens (see Adaptions).
Structure of the keystroke-level model
The keystroke-level model consists of six operators: the first four are physical motor operators followed by one mental operator and one system response operator:[5]
- K (keystroke or button press): it is the most frequent operator and means keys and not characters (so e.g. pressing SHIFT is a separate K operation). The time for this operator depends on the motor skills of the user and is determined by one-minute typing tests, where the total test time is divided by the total number of non-error keystrokes.
- P (pointing to a target on a display with a mouse): this time differs depending on the distance to the target and the size of the target,[6] but is held constant. A mouse click is not contained and counts as a separate K operation.
- H (homing the hand(s) on the keyboard or other device): This includes movement between any two devices as well as the fine positioning of the hand.
- D (drawing (manually) nD straight-line segments with a total length of D(nD, lD) cm): where nD is the number of the line segments drawn and lD is the total length of the line segments. This operator is very specialized because it is restricted to the mouse and the drawing system has to constrain the cursor to a .56 cm grid.
- M (mentally preparing for executing physical actions): denotes the time a user needs for thinking or decision making. The number of Ms in a method depends on the knowledge and skill of the user. Heuristics are given to help decide where an M should be placed in a method. For example, when pointing with the mouse a button press is usually fully anticipated and no M is needed between both operators.[7] The following table shows the heuristics for placing the M operator:[8]
Begin with a method encoding that includes all physical operators and response operations. Use Rule 0 to place candidate Ms, and then cycle through Rules 1 to 4 for each M to see whether it should be deleted. | |
Rule 0 | Insert Ms in front of all Ks that are not part of argument strings proper (e.g., text strings or numbers). Place Ms in front of all Ps that select commands (not arguments). |
Rule 1 | If an operator following an M is fully anticipated in the operator just previous to M, then delete the M (e.g., PMK -> PK). |
Rule 2 | If a string of MKs belong to a cognitive unit (e.g., the name of a command), then delete all Ms but the first. |
Rule 3 | If a K is a redundant terminator (e.g., the terminator of a command immediately following the terminator of its argument), then delete the M in front of the K. |
Rule 4 | If a K terminates a constant string (e.g., a command name), then delete the M in front of the K; but if the K terminates a variable string (e.g., an argument string) then keep the M. |
- R (response time of the system): the response time depends on the system, the command and the context of the command. It only used when the user actually has to wait for the system. For instance, when the user mentally prepares (M) for executing his next physical action only the non-overlapping part of the response time is needed for R because the user uses the response time for the M operation (e.g. R of 2 seconds – M of 1.35 seconds = R of .65 seconds). To make things clearer, Kieras [9] suggests the naming waiting time (W) instead of response time (R) to avoid confusion. Sauro suggests taking a sample of the system response time.[10]
The following table shows an overview of the times for the mentioned operators as well as the times for suggested operators:
operator | time (sec) |
---|---|
K | total typing test time/total number of non-error keystrokes Guidelines:[11][12] |
P | 1.1[11][12] |
H | 0.4[11][12] |
D | .9nD +. 16 lD[11][12] |
M | 1.35[11][12] |
R | system dependent[11][12] |
suggested operators | |
B (mouse button press or release) | 0.1[13] |
Click a Link/ Button | 3.73[14] |
Pull-Down List (No Page Load) | 3.04[14] |
Pull-Down List (Page Load) | 3.96[14] |
Date-Picker | 6.81[14] |
Cut & Paste (Keyboard) | 4.51[14] |
Typing Text in a Text Field | 2.32[14] |
Scrolling | 3.96[14] |
Comparison with GOMS
The KLM is based on the keystroke level, which belongs to the family of GOMS models.[15] The KLM and the GOMS models have in common that they only predict behaviour of experts without errors, but in contrast the KLM needs a specified method to predict the time because it does not predict the method like GOMS.[16] Therefore, the KLM has no goals and method selection rules, which in turn makes it easier to use.[17] The KLM resembles the model K1 from the family of GOMS models the most because both are at the keystroke level and possess a generic M operator. The difference is that the M operator of the KLM is more aggregated and thus larger (1.35 seconds vs. 0.62 seconds), which makes its mental operator more similar to the CHOOSE operations of the model K2.[17] All in all, the KLM represents the practical use of the GOMS keystroke level.[18]
Advantages
The KLM was designed to be a quick and easy to use system design tool, which means that no deep knowledge about psychology is required for its usage.[19] Also, task times can be predicted (given the limitations) without having to build a prototype, recruit and test users, which saves time and money.[20] See the example for a practical use of the KLM as a system design tool.
Limitations
The keystroke-level model has several restrictions:
- It measures only one aspect of performance: time,[21] which means execution time and not the time to acquire or learn a task [22]
- It considers only expert users. Generally, users differ regarding their knowledge and experience of different systems and tasks, motor skills and technical ability [23]
- It considers only routine unit tasks [24]
- The method has to be specified step by step[24]
- The execution of the method has to be error-free [24]
- The mental operator aggregates different mental operations and therefore cannot model a deeper representation of the user’s mental operations. If this is crucial, a GOMS model has to be used (e.g. model K2)[25]
Also, one should keep in mind when assessing a computer system that other aspects of performance (errors, learning, functionality, recall, concentration, fatigue, and acceptability),[26] types of users (novice, casual)[23] and non-routine tasks have to be considered as well.[23]
Furthermore, tasks which take more than a few minutes take several hours to model and a source of errors is forgetting operations.[27] This implies that the KLM is best suited for short tasks with few operators. In addition, the KLM can not make a perfect prediction and has a root-mean-square error of 21%.[28]
Example
The following example slightly modified to be more compact from Kieras shows the practical use of the KLM by comparing two different ways to delete a file for an average skilled typist. Note that M is 1.35 seconds as stated in the KLM[11][12] instead of 1.2 seconds used by Kieras. The difference between the two designs would remain the same either way for this example.
Design A: drag the file into the trash can[29] | Design B: use the short cut “control + T”[30] |
---|---|
method encoding (operator sequence)[31] | method encoding (operator sequence)[32] |
|
|
Total time | Total time |
3P + 2B + 2M = 3*1.1 sec + 2*.1 sec+ 2*1.35 sec = 6.2 sec | P + 2B + 2H + 2K + 2M = 1.1 sec + 2*.1 sec + 2*.4 sec + 2*.2 sec + 2*1.35 sec = 5.2 sec |
This shows that Design B is 1 second faster than Design A, although it contains more operations.
Adaptions
The six operators of the KLM can be reduced, but this decreases the accuracy of the model. If this low of an accuracy makes sense (e.g. “back-of-the-envelope” calculations) such a simplification can be sufficient.[33]
While the existing KLM applies to desktop applications, the model might not fulfill the range of mobile tasks,[34] or as Dunlop and Cross [35] declaimed KLM is no longer precise for mobile devices. There are various efforts to extend the KLM regarding the use for mobile phones or touch devices. One of the significant contributions to this field is done by Holleis, who retained existing operators while revisiting the timing specifications. Furthermore, he introduced new operators: Distraction (X), Gesture (G), Initial Act (I). While Li and Holleis [36] both agree that the KLM model can be applied to predict task times on mobile devices, Li suggests further modifications to the model, by introducing a new concept called operator blocks. These are defined as "the sequence of operators that can be used with high repeatability by analyst of the extended KLM.”.[37] He also discards old operators and defines 5 new mental operators and 9 new physical operators, while 4 of the physical operators focus on pen-based operations. Rice and Lartigue [38] suggest numerous operators for touch devices together with updating existing operators naming the model TLM (Touch Level Model). They retain the operators Keystroke (K/B), Homing (H), Mental (M) and Response Time (R(t)) and suggest new touch specific operators partly based on Holleis’ suggested operators:
- Distraction. A multiplicative operator that adds time to other operators.
- Pinch. A 2+ finger gesture commonly used to zoom out
- Zoom. A 2+ finger gesture commonly used to zoom in
- Initial Act. The action or actions necessary to prepare the system for use (e.g. unlocking device, tapping an icon, entering a password).
- Tap. Tapping some area of the screen to effect a change or initiate an action.
- Swipe. A 1+ finger gesture in which a finger or fingers are placed on the screen and subsequently moved in a single direction for a specified amount of time.
- Tilt. The tilting — or full rotation of — the entire device d degrees (or radians).
- Rotate. A 2+ finger gesture in which fingers are placed on the screen and then rotated d degrees (or radians) about a central axis.
- Drag. A 1+ finger gesture in which fingers are placed on the screen and then moved — usually in a straight line — to another location.
See also
- Human-Computer Interaction
- Usability
- Usability Testing
- Human information processor model
- GOMS
- CMN-GOMS
- CPM-GOMS
References
- ↑ Card, Stuart K; Moran, Thomas P; Allen, Newell (1980). "The keystroke-level model for user performance time with interactive systems". Communications of the ACM. 23 (7): 396–410. doi:10.1145/358886.358895.
- ↑ Sauro, Jeff. "5 Classic Usability Books". MeasuringU. Retrieved 22 June 2015.
- ↑ Perlman, Gary. "Suggested Readings in Human-Computer Interaction (HCI), User Interface (UI) Development, & Human Factors (HF)". HCI Bibliography : Human-Computer Interaction Resources. Retrieved 22 June 2015.
- ↑ Card, Stuart K; Moran, Thomas P; Newell, Allen (1983). The Psychology of Human-Computer Interaction. Hillsdale: L. Erlbaum Associates Inc. pp. ix–x. ISBN 0898592437.
- ↑ Card, Stuart K; Moran, Thomas P; Newell, Allen (1980). "The keystroke-level model for user performance time with interactive systems". Communications of the ACM. 23 (7): 398–400. doi:10.1145/358886.358895.
- ↑ Fitts, Paul M (1992). "The information capacity of the human motor system in controlling the amplitude of movement". Journal of Experimental Psychology: General. 47 (3): 381–91. PMID 13174710. doi:10.1037/h0055392.
- ↑ Card, Stuart K; Moran, Thomas P; Newell, Allen (1980). "The keystroke-level model for user performance time with interactive systems". Communications of the ACM. 23 (7): 400–401. doi:10.1145/358886.358895.
- ↑ Card, Stuart K; Moran, Thomas P; Newell, Allen (1980). "The keystroke-level model for user performance time with interactive systems". Communications of the ACM. 23 (7): 400. doi:10.1145/358886.358895.
- ↑ Kieras, David. "Using the Keystroke-Level Model to Estimate Execution Times" (PDF). p. 3. Retrieved 22 June 2015.
- ↑ Sauro, Jeff (2009). Jacko, Julie A, ed. "Estimating productivity: Composite operators for keystroke level modeling". Human-Computer Interaction. New Trends: Proceedings of the 13th International Conference (LNCS). Berlin Heidelberg: Springer-Verlag. 5610: 355. doi:10.1007/978-3-642-02574-7_40.
- 1 2 3 4 5 6 7 Card, Stuart K; Moran, Thomas P; Newell, Allen (1980). "The keystroke-level model for user performance time with interactive systems". Communications of the ACM. 23 (7): 399. doi:10.1145/358886.358895.
- 1 2 3 4 5 6 7 Card, Stuart K; Moran, Thomas P; Newell, Allen (1983). The Psychology of Human-Computer Interaction. Hillsdale: L. Erlbaum Associates Inc. p. 264. ISBN 0898592437.
- ↑ Kieras, David. "Using the Keystroke-Level Model to Estimate Execution Times" (PDF). p. 2. Retrieved 22 June 2015.
- 1 2 3 4 5 6 7 Sauro, Jeff (2009). Jacko, Julie A, ed. "Estimating productivity: Composite operators for keystroke level modeling". Human-Computer Interaction. New Trends: Proceedings of the 13th International Conference (LNCS). Berlin Heidelberg: Springer-Verlag. 5610: 357. doi:10.1007/978-3-642-02574-7_40.
- ↑ Card, Stuart K; Moran, Thomas P; Newell, Allen (1983). The Psychology of Human-Computer Interaction. Hillsdale: L. Erlbaum Associates Inc. pp. 161–166. ISBN 0898592437.
- ↑ Card, Stuart K; Moran, Thomas P; Newell, Allen (1983). The Psychology of Human-Computer Interaction. Hillsdale: L. Erlbaum Associates Inc. p. 260. ISBN 0898592437.
- 1 2 Card, Stuart K; Moran, Thomas P; Newell, Allen (1983). The Psychology of Human-Computer Interaction. Hillsdale: L. Erlbaum Associates Inc. p. 269. ISBN 0898592437.
- ↑ Card, Stuart K; Moran, Thomas P; Newell, Allen (1983). The Psychology of Human-Computer Interaction. Hillsdale: L. Erlbaum Associates Inc. p. 264. ISBN 0898592437.
- ↑ Card, Stuart K; Moran, Thomas P; Newell, Allen (1980). "The keystroke-level model for user performance time with interactive systems". Communications of the ACM. 23 (7): 409. doi:10.1145/358886.358895.
- ↑ Sauro, Jeff (2009). Jacko, Julie A, ed. "Estimating productivity: Composite operators for keystroke level modeling". Human-Computer Interaction. New Trends: Proceedings of the 13th International Conference (LNCS). Berlin Heidelberg: Springer-Verlag. 5610: 352–361. doi:10.1007/978-3-642-02574-7_40.
- ↑ Card, Stuart K; Moran, Thomas P; Newell, Allen (1980). "The keystroke-level model for user performance time with interactive systems". Communications of the ACM. 23 (7): 400. doi:10.1145/358886.358895.
- ↑ Card, Stuart K; Moran, Thomas P; Newell, Allen (1983). The Psychology of Human-Computer Interaction. Hillsdale: L. Erlbaum Associates Inc. pp. 260–261. ISBN 0898592437.
- 1 2 3 Card, Stuart K; Moran, Thomas P; Newell, Allen (1980). "The keystroke-level model for user performance time with interactive systems". Communications of the ACM. 23 (7): 397, 409. doi:10.1145/358886.358895.
- 1 2 3 Card, Stuart K; Moran, Thomas P; Newell, Allen (1980). "The keystroke-level model for user performance time with interactive systems". Communications of the ACM. 23 (7): 409. doi:10.1145/358886.358895.
- ↑ Card, Stuart K; Moran, Thomas P; Newell, Allen (1983). The Psychology of Human-Computer Interaction. Hillsdale: L. Erlbaum Associates Inc. pp. 285–286. ISBN 0898592437.
- ↑ Card, Stuart K; Moran, Thomas P; Newell, Allen (1980). "The keystroke-level model for user performance time with interactive systems". Communications of the ACM. 23 (7): 396–397. doi:10.1145/358886.358895.
- ↑ Sauro, Jeff (2009). Jacko, Julie A, ed. "Estimating productivity: Composite operators for keystroke level modeling". Human-Computer Interaction. New Trends: Proceedings of the 13th International Conference (LNCS). Berlin Heidelberg: Springer-Verlag. 5610: 353. doi:10.1007/978-3-642-02574-7_40.
- ↑ Card, Stuart K; Moran, Thomas P; Newell, Allen (1983). The Psychology of Human-Computer Interaction. Hillsdale: L. Erlbaum Associates Inc. p. 275. ISBN 0898592437.
- ↑ Kieras, David. "Using the Keystroke-Level Model to Estimate Execution Times" (PDF). p. 3. Retrieved 22 June 2015.
- ↑ Kieras, David. "Using the Keystroke-Level Model to Estimate Execution Times" (PDF). p. 6. Retrieved 22 June 2015.
- ↑ Kieras, David. "Using the Keystroke-Level Model to Estimate Execution Times" (PDF). p. 9. Retrieved 22 June 2015.
- ↑ Kieras, David. "Using the Keystroke-Level Model to Estimate Execution Times" (PDF). p. 10. Retrieved 22 June 2015.
- ↑ Card, Stuart K; Moran, Thomas P; Newell, Allen (1983). The Psychology of Human-Computer Interaction. Hillsdale: L. Erlbaum Associates Inc. p. 296. ISBN 0898592437.
- ↑ Li, Hui; Liu, Ying; Liu, Jun; Wang, Xia; Li, Yujiang; Rau, Pei-Luen Patrick (2010). "Extended KLM for mobile phone interaction: a user study result". CHI EA '10 CHI '10 Extended Abstracts on Human Factors in Computing Systems. New York: ACM. ISBN 978-1-60558-930-5.
- ↑ Dunlop, M.; Crossan, A. (2000). "Predictive Text Entry Methods for Mobile Phones". Personal Technologies: 134–143.
- ↑ Holleis, P.; Otto, F.; Hussmann, H.; Schmidt, A. (2007). "Keystroke-level model for advanced mobile phone interaction". CHI ’07: Proceedings of the SIGCHI Conference on Human Factors in Computing Systems. doi:10.1145/1240624.1240851.
- ↑ Li, Hui; Liu, Ying; Liu, Jun; Wang, Xia; Li, Yujiang; Rau, Pei-Luen Patrick (2010). "Extended KLM for mobile phone interaction: a user study result". CHI EA '10 CHI '10 Extended Abstracts on Human Factors in Computing Systems. New York: ACM: 3521. ISBN 978-1-60558-930-5.
- ↑ Rice, A.D.; Lartigue, J. W. (2014). "Touch-Level Model ( TLM ): Evolving KLM-GOMS for Touchscreen and Mobile Devices Categories and Subject Descriptors". ACM SE '14 Proceedings of the 2014 ACM Southeast Regional Conference Article No. 53. doi:10.1145/2638404.2638532.
External links
- Simple KLM calculator (free, web-based)
- Simple KLM calculator (free, downloadable Windows app)
- The KLM Form Analyzer (KLM-FA), a program which automatically evaluates web form filling tasks (free, downloadable Windows app).
- The CogTool project at Carnegie Mellon University has developed an open-source tool to support KLM-GOMS analysis. See also their publications about CogTool.
- GOMS by Lorin Hochstein