![]() |
|||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
Specifying System Requirements
Overview and ObjectivesAs you probably have noticed, we live in an information age. The World Wide Web has truly revolutionized the way in which we access information and provide information. From hotel and airline ticket reservations, to on-line banking, long-distance education, almost everything now is driven by information flows among us and the systems that are accessible either via the Internet or within the local intranets at our workplaces. Healthcare is no exception. A significant component of health services is information flow, among patients, clinicians, administrators, health devices and so on. Underlying our rich and powerful set of technologies are "databases". So clearly learning about databases is not just interesting but essential if we are going to advance in our jobs and become more efficient knowledge workers. The purpose of this course is to teach you the methodology and procedures that will allow you to design these very important constructs, i.e., databases. This course has 3 components:
This lecture belongs to the first component of the course, i.e. abstracting business processes into database requirements. Design of anything, including a database, is both an art and a science. As a database designer you have to make many important choices about what information you want to include and what you want to exclude. What you include will change the future focus of the organization and what you exclude may haunt the organization when important information they need is missing. Where you put the data and how you structure it will also matter. Because if data are not where others expect, they cannot find it. People can put the data into your database but cannot get it out -- how frustrating. So it is no surprise that there are a number of rules for how to design well. A database keeps information within the fields. The design of the database is inherently tied to specification of the fields. This section describes how one can decide which fields should be included in the design of a database. Glossary of Terms UsedDesign of a database, by definition is the process of abstracting business processes into an artificial set of concepts and ideas. It is a process fitting circular pegs into square holes - obviously not perfect. The reality we face is rich and complex and we have to abstract this reality into a new set of concepts and ideas, which by definition can not be as rich. To complicate matters more, we need names and definitions for these concepts and that introduces a lot of jargon. Its even worse when these names are abbreviated in acronyms, making it more difficult for the novice to understand what is intended. Then Database design is made more difficult than necessary. To simplify, this section introduces a minimum set of new terms that we encourage you to understand and keep a mental picture of it as you proceed in designing databases:
1. Establish the purpose of the DatabaseDesign is a purposeful activity, in other words databases are designed to accomplish specific objectives. Whenever we engage in the process of designing databases we are implicitly dealing with a specific business domain. As individuals in the health care business, our business domain is likely to be any of the various aspects of health care. For example, if we are working in a hospital then the business domain may be all the activities that take place in a hospital, from patient care, to human resources to maintenance of the facilities. Clearly, when we plan to design a database, we need to narrow the scope of work to something practical. As health care professionals, the scope of our work is narrowed to the business and clinical domains of the organization. Since these domains could be immensely large, we need to carve out a more specific purpose for the database. A good designer always asks what is the purpose of the database: "What is the point?" Unfortunately, the answer to this question is not always clear. Different people want the database to accomplish different tasks. In the end, asking "why" helps reduce the task that should be modeled into a database but does not solve the design problem entirely. Establishing the purpose of a database is not simple. Different actors express different purposes. For example, we were asked to design a database for a mental health court. A mental health court diverted mentally ill but not dangerous patients from the usual court procedure into a special procedure designed to reduce their return to the criminal justice system. The program is called Forensic Alternative Services Team (FAST) and involves a number of social workers and other clinicians deciding on the eligibility of the case for the program and monitoring the clients to see if they comply with court ordered treatment plan. The initial request for help came from the mental health court judge who wanted a better understanding of the effectiveness of her court. This was one purpose for the project. The mental health community agency funded the pilot project and the lead person in this community agency wanted a simple database tracking the performance of the FAST program. This was a different purpose. The funds for the pilot were provided by the mental health agency to the University because of impending collaboration between the court and the University on a special project. The university personnel wanted a database that would use standardized questionnaire that could be used in national program evaluations. This was still another purpose. Discussions with the FAST program director revealed that a medical record system was set up for them but had gone unused because they did not want such details. They wanted to stay as much as possible with the existing paper record and at most to have a case management system and not a medical record. This was still another purpose entirely. All of this was occurring in the context of the Federal government encouraging the development of Regional Health Information Networks designed to automatically integrate data across organizations, enabling the court, the treatment providers and the FAST team share data automatically. The more you talk to organizational leaders the more you understand that there are multiple purposes for a database, some of which the designer can meet and others for which the designer cannot meet immediately but can anticipate so that a future expansion was possible. 2. Analyze What ExistsDatabase designer can understand a great deal of organization's needs by examining current operations. They can note the tasks that are being done in the organization, the paper flow. They may even be able to review existing information systems -- if they exists. But the information that emerges from review of existing conditions are suspect because they do not involve the client and because they do not reflect future needs. Take for example the possibility of assessing information needs by examining the tasks at hand. The analyst may observe the organization tasks and the information items needed in each. But organizations are complex and learning how information flows in them is time consuming. An analyst needs to spend weeks becoming an expert in the organization's information flow and even then they are no more of an expert than the organizational leaders who breath and live in the environment. Why spend so much time studying a situation when one could easily ask the user -- who is the real expert on their own needs? Of course the ideal situation is to do both: examine the existing database and ask the organizational leaders. Examining the current conditions make sense as a starting point but soon we need to move beyond this level of analysis and involve information users. Examining the current situation has two components. First it is important to see the existing databases and their structures, no matter how inconsequential they are. Often data are kept in flat and inflexible files. For example, when we were asked to design a database for a mental health court, we found that they had a relatively flat database with six tables. These tables closely corresponded to forms they had.
The tables in the existing database kept multiple pieces of unrelated information in the same place. For example, it put name, address, demographic, arrest history and medical history in the same table. Clients of the court changed their address frequently. Every time the address changed the entire record needed to be changed. Every time the client was arrested, another entire record needed to be put in. The value of examining existing databases is that they suggest potential fields and may explain why existing databases are frustrating. In this manner, future design can avoid past errors. Second, it is important to trace the paper flow. Many organizations have paper forms that document decisions made by them. These paper flows are an important source of ideas regarding what information might be kept in the new database. For example in the mental health court example, the following paper forms were used:
The forms pointed to several decisions that the organization needed to make. The form on pre-admission screening and the admission forms pointed to the decision about diverting a defendant from usual jail and court processes to special processes set up for mentally ill patients. The demographic and the monitoring form pointed to the information needed for deciding on the effectiveness of the diversion process. The discharge form was used to decide about court staff's assigned work load. These forms point to what data might be needed for which decisions. 3. Identify Future DecisionsOne obvious way for assessing information needs is to ask organizational leaders what should be included in the database. Information users have a great deal of problems in articulating their own needs. When asked, they often produce a long wish list of data that those not correspond to their true needs. They include items that they will not use and do not mention items that they will need. Organizational leaders fall victim to their own cognitive limitations. When interviewed, they have to remember how key information was missing in the past decisions. This is very unpleasant. No one wants to remember failures or episodes in which their needs were not satisfied. Unpleasant events are often forgotten, especially when you, yourself, are in charge. Interviewing organizational leaders about failures of their organizations is akin to asking them to fess up to their own mistakes. It is an unpleasant task that many rather forget. Furthermore, many decision makers do not realize how their own needs change over time and how these needs are affected by external events. They are so engaged in everyday work that they have not had an opportunity to envision a different arrangement. Many are not aware of new technological possibilities and keep projecting future needs based on their existing expectations. In short, many fail to imagine a new future. To overcome these limitations, it is important to put organizational leaders in a new mind set. The analyst can do so by first ask what are future decisions that the database should address and then assess information needs within these decisions. Clearly, information needs change over time and by repeating what has been to date, organizations may put themselves in a disadvantage. This may be acceptable in a stable environment, but not in a dynamic one. A focus on future decisions transcends this pitfall and provides a context for the value of various pieces of information. Information collected in a databases data that have been consistently relevant to a particular decision. This is how an analyst can decide to collect or to ignore a datum. If in a given decision, there is no requirement to examine a price of data before making the decision then the database should not contain it. Only that portion of the information which we will use need to be stored and retrieved at a later time. Other information may reside elsewhere in the system, may be relevant to decisions not addressed by the database or may be handled in a different way at the time of decision making. A focus on decisions makes sure that long wish lists of information items that are never used do not clutter the system and drawn out the opportunity for collecting what really would influence actors. An analyst has no choice but to select a few fields and focus on them rather than all possible fields of information. If you look around you, you'll see many objects. Each one of those objects has potentially hundreds, or even thousands characteristics. For example the monitor in your computer has a model number, a type, a model name, a type of display, a color or colors, a height, a width, a depth. Is that all? Well, probably not. It depends on how detailed you want to be. You could also describe the lettering that the monitor may have, where that lettering is located, what color is the lettering in. Have we exhausted all the things we can say about the monitor? Hardly. We could take a magnifying glass and look for scratches and indentations on the frame of the screen, we could describe what the chemical composition of each one of the parts of the screen is, and so on and so forth. Clearly, objects are awfully rich in terms of their characteristics. An analyst must figure out what is pertinent for the database purposes and what is not. If I am a clinician I will be interested in those characteristics of a patient that are pertinent to my decisions about his health. If I am a banker, I will be interested in the financial characteristics of my client. So for every domain there are objects that are pertinent, and for each one of those pertinent objects there are characteristics that support the purpose of our database. Everything else is irrelevant and we must filter that out when considering how to build an information model. Since data become informative in the context of particular decisions, then the simplest step is to evaluate the relevance of a datum in the context of a decision that needs to be addressed by the actors. By focusing on future decisions, the databases designer anticipates various roles the information system might play. For example, in the mental health court project, we were given a tour of the court. While at the court, it became clear that many defendants come to the court without their data being available. A significant component of the time is spent in the court sorting out who knows what about the defendant. In one case, the FAST social worker reported that they had not been able to get a response from the health care provider regarding defendant's competency examination. The probation officer reported that he has not been able to locate the client in the community. The defense attorney reported that he had not met with the client yet to see how the examination went. All along the judge was left waiting for information. Eventually, the judged called the doctor involved and talked to him on the phone who collaborated the client that that she had gone to the clinic, had been examined but did not want to take the medications prescribed. It was clear from this case that an exchange of information between the FAST database and the clinic would solve the problem. Health care providers, for example those in the Veterans Administration, were reluctant to provide the care because of extensive court required paperwork. With the automated exchange between the clinic database, the court will be well informed and the clinicians would not need to file additional forms. But the FAST social workers seemed unaware that the Veterans Administration had a great electronic medical record system and that it was possible to create the electronic link to it. When the option was described to them, they were not sure that such links can be made. So asking the organization employees about what they need may not be enough. Sometimes, specially when it comes to automation of tasks previously done manually, designers of new databases need to lead the effort. A similar example occurred when we noticed that FAST social workers, treatment programs and court staff have a difficult time identifying cases. Many patients give different names at time of arrest and in clinics -- creating a havoc in matching the information to the right person. One way to overcome this is to include an image of the person in the database. When employees were asked what they want in their database, none mentioned an image of the client. When we suggest that this could be done, they were very enthusiastic. The point is that designers cannot completely rely on organizational leaders on what should be included in the design. Part of their task to push for change in business processes and information that should be collected in the database but that are not mentioned by organizational leaders. 4. Invite a Panel of Experts to Create Decision Making ScenariosTo be effective, an analyst must ask both organizational leaders and outside experts to identify the needs of the organization. By relying on a group rather than an individual, the analyst minimizes the cognitive and behavioral limitations of having a single person define information needs. The information system that emerges may not fit the idiosyncratic needs of a particular individual but it transcends people who come and go and serves the organization as a whole -- no matter who is in charge and for how long. By adding external experts to the membership of the group, the analyst emphasizes what people in the organization want and what people outside think they may need. It brings an outside point of view and breaks up the set ways of doing things. In the mental health court example, we had heard of a Federal system for probation officers. In some sense the FAST social workers were doing activities similar to the Federal probation officers: they were tasked with monitoring adherence with the court ordered actions in the community. To gain a better understanding of what the FAST database needed to look like, we examined the Federal system. Scenarios are snapshots of a story you are telling about how a database will be used. You should make different scenarios about each decision. In the scenario you should talk about how the actors will interact with the database to make a specific decision. Here is an example scenario on admission to the FAST program:
Additional scenarios can be written about how the database helps in other decisions, for example the decision about what treatment should the patient participate in. In the end when you have developed a number of scenarios, you have a way of telling a complete story about what the database will do and what decision it will have an impact on. 5. Develop Use CasesThe use case method was pioneered by Ivar Jacobson, one of the three creators of the Unified Modeling Language, an important language in designing databases. The purpose of a use case is to describe the behavior of the system from the point of view of the user interacting with that system. By stating how the system reacts, that is, what it does, when the user gets in contact with the system it is possible to gather the kind of information that will be needed to support these system actions. For example, in the mental health court system a receptionist was asked to collect information from the Federal and State databases regarding a client's "wrap" sheet. This information was then put into the computer to document the case for a client being considered for the FAST program. A form was provided to the receptionist asking her about the client's demographic and arrest information. This form was then communicated to the FAST social workers who established the client's presumed diagnosis and eligibility for the FAST program. In Unified Modeling Language one uses a series of icons to graphically depict a use case diagram. The actor is always external to the system and is normally represented as a stick figure with a label underneath it that identifies what kind of actor it is. Note that the term "actor" is not meant to be restricted to human users alone. Any object in the business domain that interacts with the system can be considered an actor. For example, another system can be an actor, if it sends or receives information from our database. The database or system is normally shown as a rectangle, and it also has a label that identifies it within the business domain. Inside the rectangle that represents the system there are ovals which correspond to the actual use cases. Each oval has a label which can be placed either inside the oval or immediately below it. The label is a short-hand for a given functionality of the system. The recommended practice is to use succinct phrases, for example verb-noun pairs, for the label of each use case to convey what the system does. Lastly, straight lines are used to connect actors to the various use cases of the system. When an actor is connected to a use case in a system it indicates that the actor interacts in some fashion with that functionality of the system. Needless to say, the bulk of the description for what that interaction consists of is not shown in the diagram itself, but is captured in a descriptive narrative. The diagram is simply a very high level depiction of the actors and their connectivity to the system. The tools for Uniform Modeling Language normally offer data entry forms where this information can be documented. In absence of case tools one can use a word processing software to document a use case. By following this discipline we can get a handle on what type of information is required by the system in order to operate correctly. The process of building use cases focuses on the message flows exchanged between the actors and the system. There are four main categories of actors which can be documented in a use case Diagram. First we have (a) the principal actors, which generally will be humans interacting with the system and its various functionalities, next are (b) the secondary actors, which normally are individuals performing administrative or maintenance functions with respect to the system. The third category of actors is (c) the external hardware. This includes those peripheral devices that enable the Input/Output functions for the system. For example, the terminals through which a human user can log in, the printer devices that generate hard copy reports, etc. Lastly, there are the (d) external systems which interact with our system. In a complex application our system may be linked to a local network which provides the connectivity to the Internet, or to the e-mail server within the organization. Each of these potential actors may send to and receive information from the system, and each of these flows may depend on the sequence of interactions between the user and the system. A given sequence of interactions is normally bundled into what is called a scenario. A patient accessing an on-line medical system may participate in multiple scenarios depending on what sequence of interactions he engages in. In one scenario, the patient may be simply searching for answers to a query posted previously. In another scenario, the patient may be reporting his health status after having followed the medical treatment recommended by his physician of record. Different use cases can then be documented for each scenario. All scenarios must be linked to decisions. In the first scenario, the patient is deciding whether to come in for a visit. In the second scenario, the provider is deciding if the patient needs to return for a follow-up visit.
The following shows an example of a use case Diagram using Uniform Modeling Language notations. The system we are dealing with is the mental health court system. A receptionist is shown with access to the registration use case. The FAST social workers are shown interacting with module for presumed diagnosis and monitoring. We have at least two actors, namely, the receptionist and the FAST social worker. The functionality of the system for this scenario is shown in the three use cases shown in the diagram, namely, the Registration Management, the Presumed Diagnosis and the Monitoring component. The diagram shows that the FAST social worker interacts with all three of the system functionalities, whereas the receptionist is focused on the registration component. More careful examination of the system revealed several flaws in the use case scenarios. First, one of the social worker was disabled and could not interact with the computer directly. This necessitated the need to send information that needed to be put into the computer back to the receptionist. Therefore, in reality and at least for one social worker, the receptionist did all of the interaction with the system. But pictures do not tell the entire story and we need to have the details captured in the use case document. It is generally recommended that a use case document should contain:
Of course other information can also be kept about each use case:
There is no canonical form that one must always adhere to for documenting a use case. Here is an alternate way of documenting the Registration Management use case.
Figure 4: Alternate Documentation of a use case Specify FieldsAt the end of specifying system requirements you should have a list of fields that correspond to various uses of the database. The more details are specified in a Use Case the easier it is to extract the type of information that the system will require, and, consequently, the easier it will be to generate the database fields. The use cases gives us the entry point into the actual process of developing the information model for the target database. It helps us specify specific fields needed. In assigning field names Hernandez (pages 209-211) suggests you follow these rules:
We also add the following additional criteria:
End the process with a thorough and careful documentation. For each of the fields, provide the name of the field, a short definition, any restriction that pertains to the values the field and the type of values expected. Types of data allowed depend on the manufacturer of the database software you are using. Some common types are:
Careful documentation and frequent sharing of the documentation with organizational members can help the design of databases. In this lecture, we have seen how information requirements can be established from review of decisions and scenarios connecting actors to specific decisions. Use cases and scenarios begin to give us a handle on the kind of information we need to concentrate on. Within the use cases we have learned that the portion of greatest importance are the information flows because they determine the fields to be kept in the database. What Do You Know?Advanced learners like you, often need different ways of understanding a topic. Reading is just one way of understanding. Another way is through writing about what you have read. The following assessment is designed to get you to think more about the concepts taught in this session. You are encouraged to discuss your ideas with others in class but please submit separate work. There are two options to complete this assignment. Option 1: Develop scenarios and use cases for a Mental Health Court which needs to make at least the following decisions:
The various actors are the following: Shelia who puts the data into the system, Connie who is a social worker making admission decisions and preparing treatment plan, Jane who is the supervisor of all social worker in the diversion program. Sue who is funding the database from mental health public funds. The judge who is deciding about the client. Various treatment providers (substance abuse treatment, employment services, mental health service, physical health services, shelters, police, other courts, etc.). In doing this assignment decide on the scenarios and use cases. Do not include any scenarios that do not fit the decisions indicated. There should be one and only one scenario for each decision. There are usually several different use cases under each scenario. Document scenarios as illustrated in Section 4. All use cases must have detailed information exchange sections - document use cases as illustrated in Section 5 (use figure 4 as a template). Submit your responses as a word attachment by email to the instructor. Option 2: Use database you are designing in your semester-long project.
Presentations
Narrated lectures require use of Flash. Frequently Asked QuestionsAsk a question and we will answer it within the next 48 hours. If you have no questions, please review the answer to the questions asked by others: Question: Question4: i am confused about the actors responsible for deciding if the program should be expanded. don't know where the request to expand the program will come from. Answer: Such decision may come from the court or policy makers. Other actors involved may be social workers who provide relevant information to the court. This question was asked on 9/15/2009 9:43:42 PM and answered on 9/17/2009 12:04:43 PM . Question: Can you only have two actors per scenario? Answer: No. There is no limit on how many actors per scenario can be defined. This question was asked on 9/2/2008 7:28:33 PM and answered on 9/3/2008 10:18:31 AM . Question: A second standardized assessment form of interest is not available at the link, below http://www.chestnut.org/li/gain/GAIN_SS/GS_1.pdf Answer: Rhanks for pointing this out. I will correct this. This question was asked on 10/7/2006 11:00:48 AM and answered on 10/9/2006 3:27:59 PM . Question: I would like to obtain a copy of the ASI doc; however, the link is not functioning as below, http://www.sounddatasource.org/downloads/asi_lite.pdf#search='addiction severity index Answer: I have corrected the link and pointed it to the addiction severity index version 5 This question was asked on 10/7/2006 10:55:00 AM and answered on 10/7/2006 6:40:14 PM . Question: If we do not have Microsoft Access on our computers are we expected to purchase the program to use for this course? Answer: Yes, either purchase the software or use university labs where computers typically have this software This question was asked on 9/15/2006 12:59:05 AM and answered on 9/15/2006 6:12:29 PM . Question: Are we to be building on the scenarios and use cases in this lesson toward our final projects? Or is this just a learning and practice exercise? Answer: These exercises should help you towards completing the final project. It is your choice, however, if you want to hit two birds with same stone. I would encourage you to do so. This question was asked on 9/15/2006 12:49:21 AM and answered on 9/15/2006 6:11:23 PM . Question: Approximately how many use cases will be devised for a given scenario? Answer: This depends on the number of actors This question was asked on 9/12/2006 6:28:12 AM and answered on 9/12/2006 10:00:16 PM . Question: I wish to edit a few fields on my scenarios and use cases. I do not see where it is possible to EDIT text submitted -- please advise. Answer: Unfortunately, we do not have this feature. You should copy the text and enter it again. This question was asked on 9/11/2006 4:58:56 PM and answered on 9/12/2006 9:59:13 PM . Question: Why did you choose Sue who is funding the database as an actor?Is she using the system in anyway? will she be reviewing any reports or so? Answer: Yes, she does read the reports from the database on a monthly basis. This question was asked on 9/5/2006 11:26:47 AM and answered on 9/5/2006 10:45:19 PM . Question: How do you decide who is the primary actor and who is the secondary actor for a complex use case with equally involved multiple actors? Answer: If the decision is difficult, then it does not really matter. You can set anyone you wish as the primary actor at that point. The real contribution of the use case is the information exchange list. So if both are equally primary, then select one arbitrarily and proceed. This question was asked on 10/2/2005 12:38:02 PM and answered on 10/2/2005 9:36:34 PM . Suggested ChangesComment: Lecture was good, but more examples of scenarios and use cases would have been helpful. This comment was left on 10/11/2009 4:56:51 PM. Comment: This lecture is a little confusing. I think more examples would be helpful for those that do not have experience with use case and scenarios. This comment was left on 9/13/2009 10:00:27 PM. Comment: liked this one better than the last. was more engaging because the presenter went well beyond the slides. felt more like a dialogue, if that is possible. This comment was left on 9/12/2009 9:43:28 PM. Comment: Great lecture. I have written several use cases in the past, but never been taught a structured way to do them. This combination of experience and education is very beneficial. This comment was left on 9/12/2009 3:14:12 PM. Comment: The scenario tool worked well, but the use case tool kept erroring out. Another example within the text might have been helpful in outlining the flow from the decision to the scenario to the use case. This comment was left on 9/14/2008 10:09:15 PM. Comment: Good lecture. I liked the examples that were used to illustrate how the different steps. This comment was left on 9/12/2008 8:53:24 AM. Comment: The lectures helped as well as the updated slides. I liked the details in the slides. This comment was left on 9/9/2008 8:35:32 PM. Comment: Overall the lecture was okay. I think if there were better examples of scenarios and use cases I would have grasped the concepts better. This comment was left on 9/2/2008 9:03:40 PM. Comment: Lays a sound foundation for the work ahead. Thank you for fixing the links as required. This comment was left on 10/26/2006 6:59:08 AM. Comment: The information is very concise and clear, but requires repeated reading to pick up and understand all of the connections and concepts that are included. This comment was left on 9/15/2006 12:55:26 AM. More
This page is part of the course on Healthcare Databases & Information Systems, the lecture on Specifying System Requirements. This page was last edited on 09/04/08 by Farrokh Alemi, Ph.D. ©Copyright protected. |
|||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||