FDA Expectation On Software Validation
FDA Expectation On Software Validation
FDA Expectation On Software Validation
No. 4317
Software Validation
Page 1 of 40
DFS/ORA
No. 4317
Software Validation
Page 2 of 40
Nearly all of the spreadsheets in the laboratory showed rounding-off errors and none
used the Excel rounding function, when needed to avoid rounding-off discrepancies
between the original and check calculations by the second analyst.
Formulas in the analytical procedures did not follow the Excel equations.
Conversion factors were not expressed in the analytical procedures.
The formulas used by the check analyst for manual calculations were not the same as
those used in the Excel spreadsheets.
The pre-determined specifications or limits were not shown in the spreadsheets.
Spreadsheets were not clearly documented. For example, the product declaration was
not indicated, replaced by only a number in a cell.
Units were expressed as numbers without descriptive labels such as mg/mL or mg/g.
Sample weights were described as sample volume and areas as ratios.
Spreadsheets did not contain provisions for security and integrity of data.
Spreadsheet applications were not protected from changes, meaning analysts could
freely change labels and formulas.
Regression analysis was calculated with the y and x axis inverted in the Excel
formula, which generated erroneous slope and intercept results.
These analytical spreadsheet mistakes can be eliminated if the analyst (developer) ensures that
each element in the spreadsheet application is uniquely and unambiguously defined.
As a minimum, a simple spreadsheet validation documentation should include the following
items (3):
DFS/ORA
No. 4317
Software Validation
Page 3 of 40
DFS/ORA
No. 4317
Software Validation
Page 4 of 40
Raw Data. Raw data is defined at 21 CFR 58.3 (k) (2), as any laboratory
worksheets, records, memoranda, notes, or exact copies thereof, that are the result of
original observation and activities of a non-clinical laboratory study and are necessary
for the reconstruction and evaluation of the report of that study. In addition to hand
written observations in ink on paper, raw data may include photographs, microfilm,
or microfiche copies, computer printouts, magnetic media, including dictated
observations, and recorded data from automated instruments. In the chemistry
laboratory, the raw data from notebooks or paper worksheets can be entered manually
into the computer spreadsheet program or can be directly collected (from balances,
GC, LC, etc.) into the spreadsheet program, by means of an interface or a Laboratory
Information Management System (LIMS). Under those circumstances, the
spreadsheet becomes raw data. A worksheet generated by a spreadsheet program can
be designed to be used as a fill-in-the-blanks worksheet for raw data. After the raw
data is entered manually into the paper worksheet (fill-in-the-blanks worksheet), the
worksheet becomes original data, which is the result of original observations. The raw
data worksheet can not be remade if errors are found. Errors cannot be erased or
overwritten; a line must be drawn through an incorrect entry and the correct figure or
word written nearby and initiated. Also, significant data must not be discarded
without explanation. Discarded analytical data must be crossed out, initiated, and the
reason for discarding the data explained. An example of the raw data worksheet will
be presented in Part II of this LIB.
Secondary Data. The secondary data worksheet is used for the calculations and
results, which utilize the data from the raw data worksheet (standard and sample
weights and dilutions, sample dilution factor, etc.) previously developed and printed,
which included the original observations. It can be remade if errors are found. To
verify the secondary data spreadsheet (calculation and results sheet), data in the
spreadsheet are checked against the printed and used raw data sheet (fill-in-the-blanks
Excel Worksheet in which the blanks had been manually written). The results of the
verification must be documented, and the check analyst must sign for approval. A
laboratory notebook in which raw data is entered manually also becomes original data
and copies can be attached to the spreadsheet printout. Figures 2 and 3 are examples
of the secondary data worksheets.
The workbook files containing the raw data (fill-in-the-blank form) and secondary
data worksheets should be preserved, controlled, and maintained for future audits of
DFS/ORA
No. 4317
Software Validation
Page 5 of 40
the electronic file. In addition a copy of the completed sample printout should include
the name and saved date for the workbook file, and the software name, version, and
upgrade designations.
Security. 21 CFR Part 11; Electronic Records; Electronic Signatures (6) Sec. 11.10
Controls for closed systems. Users who use closed systems to create, modify,
maintain, or transmit electronic records shall employ procedures and controls
designed to ensure the authenticity, integrity, and, when appropriate, the
confidentiality of electronic records. Such measures ensure that the signer cannot
readily repudiate the signed record as not genuine. Such procedures and controls shall
include the following: (a) Validation of systems to ensure accuracy, reliability,
consistent intended performance, and the ability to discern invalid or altered records.
(b) The ability to generate accurate and complete copies of records in both human
readable and electronic form suitable for inspection, review, and copying by the
agency. Individuals should contact the agency if there are any questions regarding the
ability of the agency to perform such review and copying of the electronic records.
Other part 11 requirements may be implemented as well (6).
For example, the access control to the computer and the Excel workbook files and
audit trails (Section 21 CFR 11.10(e)) should be implemented as follows:
(a) For computer access control, the Agency established security in accordance with
Federal mandates (Computer Security Act of 1987, Computer Fraud Abuse Act of
1986, and others, see http: //intranet.fda.gov/oirm/itsecurity/useful.htm).
The Agency is required to provide adequate security to manage potential risk to its
automated information. The Southeast Region Information Technology Services
(SRITS) manages the computer security program. The Information System Security
Officer (ISSO) serves as the Agency focal point to direct and oversee the security
program. The ISSO will develop policies, procedures, and guidance establishing,
implementing, maintaining and overseeing requirements for the Agencys
information technology (IT) security program. For example, the agency and the
SRITS have established access controls at various levels. The ORA's wide area
network (WAN) is a closed system protected by two internal firewalls. This closed
system is contained within another closed system that consists of the HHS WAN (the
departmental level). The ORA's WAN has a secured gateway to the Internet through
the various firewalls. At the ORA's WAN level, all computers (laptops as well as
desktops) have been migrated to Microsoft's Windows 2000 Professional operating
system (OS). This new OS has improved security features. The most important ones
are:
9 Authenticated Logon - Users now must enter a username / password combination
in order to access the files and resources in any computer. If a user does not have
DFS/ORA
No. 4317
Software Validation
Page 6 of 40
an account in the ORA network domain, then the user would not be able to access
any files or computer resources.
9 File Level Security - All hard disks will be using NTFS (New Technology File
System from Microsoft) as the file system (not the common FAT file system).
This provides additional security features for file access over previous file
systems such as FAT (File Allocation Table) or FAT32. Files stored in local hard
drives can be secured by using access lists. Administrators can designate who can
access a specific file and what level of access the user can have (read, write,
change, delete).
9 Audit Trails - NTFS and Windows 2000 provides features that allow the system
to log the use of a file or folder.
9 File Encryption - Users can encrypt the data files to protect them from unauthorized access. The highest encryption algorithm is being implemented (128bit).
In addition, data files stored in network drives are also protected from unauthorized
access. File servers use NTFS as the file system and data is backup every night.
(b) For access control to Excel workbook files applications, the developer should
implement adequate security. For example, Excel has several levels of protection that
can be applied to a workbook file. The highest level of protection is set on the file
level. A password can be set in order to open, access and save a workbook. After the
workbook file is open, security options can be set inside the application file. There are
three levels of security: workbook, worksheet, and object. Protecting the workbook
prevents the user from inserting new worksheets. Protecting the worksheet prevents
the user from changing the contents of a worksheet, such as formulas. Protecting the
object prevents the user from deleting, moving or resizing objects.
In addition, spreadsheet applications should be protected with the safeguards
identified in 21 CFR Part 11. These include validation with its documentation;
security, and audit trails (Section 21 CFR 11.10(e)). The security, audit trails, and true
electronic signatures can be implemented by software and services such as what is
available from the company Wimmer Systems (www.wimmersystems.com). For
example, Wimmer Systems can take our verified Excel application spreadsheet,add
the compliance package, and when finished,install the application and provide
training.
Also, during an in-house audit, the laboratory must provide the validation
documentation and copies of the applications in both hard copy and electronic form
as per 21 CFR 11.10 (a) and (b), if the copies are requested by the auditor. Therefore,
Part 11 requires that laboratories be able to give the auditor electronic copies and hard
DFS/ORA
No. 4317
Software Validation
Page 7 of 40
copies of their electronic records. Providing copies of the software program (for
example Microsoft Excel program) that produce the records is not required.
In addition all workbook files (single-user and multi-user) should be preserved,
controlled and maintained for future audits against the reviewed printed sample
reports (single-user) or the validation documentation (multi-user). Otherwise, if
workbook files were not controlled, problems might result (e.g., paper printouts or
printed reports might be challenged as being incomplete or inaccurate representations
of the corresponding electronic records).
Computer software is documented and suitably validated as being adequate for use.
Procedures are established for protecting the integrity of data; such procedures shall
include, but not be limited to, integrity of data entry or capture, data storage, data
transmission and data processing.
Computer and automated equipment are maintained to ensure proper functioning.
Environmental and operating conditions necessary to maintain the integrity of test
and calibration data must be provided.
Appropriate procedures for the maintenance of security of data including the
prevention of unauthorized access and/or amendment of computer records are
established and implemented.
Procedures are established to describe how changes in documents maintained in
computerized systems are made and controlled.
DFS/ORA
No. 4317
Software Validation
Page 8 of 40
Guaranteed correctness. If you cannot guarantee that your model always yields the
right answers, it is not effective and may actually be dangerous. Design your model to
make errors immediately apparent.
Adaptability. Most likely, the task you want your model to perform will change in
time. Design the model so that you or others can easily improve it.
Use a vertical, modular design. In a given spreadsheet use only one or two screen
widths of columns, containing as many rows as needed. A strict vertical scheme
promotes a clearer flow of calculation and provides rapid recalculation. Worksheets
should be organized into manageable sections, each occupying a horizontal slice of
the generally vertical worksheet. Each section should serve a single purpose. Try to
make all sections the same width and no more that two screens high. Clearly
distinguish each section from the adjoining ones by using cell formatting, colors, cell
borders or separate sheets for each section.
Every formula should refer only to the cells above it. As a result, calculations should
go strictly downwards from raw data near the top of the worksheet to the results at the
bottom.
Use a standard layout. A standard worksheet layout will facilitate maintenance. It
should contain the following separate sheets:
9 Documentation: This sheet includes critical documentation about the rest of the
worksheet; title, purpose, and author, a list of other worksheets or macros that
must be opened for the model to work, and a table of contents that outlines the
order of the sections in the worksheet. There should be no calculations in this
section.
9 Menu: This sheet can include the instruction for the user and all the worksheets
associated with the application. By pressing a button in the worksheet, a dialog
box can open showing the user instructions. The instructions can include the
location of data-entry cells or drop-down lists or other pertinent information to
help the user move around the application.
DFS/ORA
No. 4317
Software Validation
Page 9 of 40
9 Assumptions: This sheet contains any initial assumptions used in the worksheet
formulas.
9 Document assumptions. Critical assumptions about formulas should not be
hidden in the middle of the worksheet. Instead, clearly document all the
assumptions in a special assumption section that helps everyone who looks at the
worksheet to understand how the results were derived, and the inherent limits.
9 Data: This sheet includes the raw data, such as records of data from which the
model will perform calculations.
9 Calculations: Include as many calculation sheets as needed to process the data.
As mentioned, each section should be based only on the results of the previous
sections so that calculations progress through the worksheet from top to bottom.
Break the task into manageable segments. Divide the worksheets task into a
series of calculation steps, and then plan one section on the worksheet for each
step. As each section is developed, record its purpose. For example, you might
enter text such as This section refers to the database on the supporting worksheet
and summarizes results from drug or food samples for a single month; see Figure
2; see statement in cell comment. This helps other users to understand the
formulas in the model.
9 Results: The last section should contain the final results. Along with the
assumptions section, this section should provide a comprehensive summary of the
models calculations.
Write clear formulas: This reduces calculation errors and makes the model easy to
maintain. You should:
9 Spread complex calculations over several cells instead of trying to pack them into
a single one.
9 Use a text label in an adjacent cell or insert a cell comment whenever someone
might misinterpret what a number means.
9 Always document how the formulas work. For more complex explanations of the
thinking behind a formula, use cell comments, which are available when required.
DFS/ORA
No. 4317
Software Validation
Page 10 of 40
If K35 is less than 80 the formula will return to Fail or if is above 80 it will
return to Pass.
9 Use error condition functions such as IF(ISERROR to prevent an error
display (such as #DIV/0!) in the cell if the formula returns an error. This is useful
if formulas are used to perform calculations on cells that might have no data. As
an example the following formula calculates a percentage
=ROUND((E31/D4)*100,1), If cell D4 contains 0 or is empty, the formula will
display a #DIV/0 error. To display a blank cell when D4 contains 0 or is empty
use the expression:
=IF(ISERROR(ROUND((E31/D4)*100,1)),"",ROUND((E31/D4)*100,1)).
Also, this function can eliminate many other error values such as #N/A,
#VALUE!, #REF!, #NUM!, #NAME?, or NULL!.
Use drop down lists whenever possible. This feature restricts the user to valid
entries, when they are known beforehand. It is created by the sequence: Data
Validation Choose Setting Tab in Allow choose List in Source
give the cell range where the allowed choices will be written. A message will be
activated when the cell is addressed. For setting up the message, select Data
Validation choose Input Message enter short instructions in the window Title.
Optionally, choose: Error Alert and write the correction instructions in the window:
Error Message.
DFS/ORA
No. 4317
Software Validation
Page 11 of 40
Introduce the units in all appropriate cells. This feature allows creation of new
number formats. For example, units (e.g. mg/mL) used in analytical methods can be
added by selecting from the Excel main menu bar: Format Format Cells
Choose Number Choose Category Custom: Type: General. In the window
where General is typed, type the entry: mg/mL just after General and press OK.
Format numbers. Use the Round function and specify the number of decimal places
to which the value should be rounded-off. For example, a formula to calculate an
average with three decimals would be:
=ROUND(AVERAGE(Range), 3)
Never round to fewer than five places (including decimal places). For example, it is
permissible to round the average to 87.333 but not 87.33. This criterion is used for
rounding-off the values of intermediate calculations. When rounding by local
laboratory policy, this policy may be used. The weighing and the chromatographic
peak areas should be reported with all their digits. The final results should be rounded
to the least significant digit (LSD), using the appropriate official guidance. For
example the USP 24 / NF 19 page 4 provides the following rules:
9 Establish the position of the LSD.
9 If the digit to the right of the LSD is less than 5, eliminate all remaining digits
after the LSD.
9 If the next digit is larger than or equal to 5, increase the LSD by one and eliminate
all the digits beyond the LSD.
The main reason for rounding the data is to provide safety in checking the displayed
results against hand calculators. In the absence of the rounding function, Excel will
guard additional decimals which might produce discrepancies with the hand
calculator data. The Round function should be included in the formula where
rounding is performed.
Calculations. In the calculation and results worksheet (secondary data, attachment
B3), each calculation should be based on the results of the previous calculation so that
the calculations progress through the worksheet from top to bottom.
Add supplemental cell comments. Use the cell comments whenever necessary for
notes or instructions. To insert a comment in a cell, use Insert Comment. When the
mouse pointer moves over a cell that contains a comment, the comment becomes
visible. See a comment example on attachment C2. (Cells that have a small red
triangle in the upper-right corner have a comment attached).
Color-coded cells. Use liberally. For example, all data entry cells could be yellowcoded, while the drop-down lists may use blue cells. This is done by using the Format
Cells Patterns.
DFS/ORA
No. 4317
Software Validation
Page 12 of 40
Add path to footer. The workbook file name is inserted into the left footer of each
worksheet. Implement with: File Page Setup. The footer can advantageously be
used to insert operating instructions for the worksheet. Also, the creation date, last
modification date, and version number can be inserted in the footer.
Protection. By default, Excel has all cells locked. First, unlock all data-entry cells in
each worksheet by using the Format Cells Protection tab, and remove both
checkmarks. Next, apply protection to each of the other worksheets in the workbook
file by selecting from the Excel main menu bar: Tools Protection Protect Sheet
and optionally entering a password. This protects the secondary calculated data from
unintentional changes.
Relative and Absolute Reference Cells. Press F4 repeatedly while the mouse pointer
is in front of a cell address (You obtain the sequence: A1, $A$1, A$1, $A1).
Equation Editor. Use to describe the formula in the analytical method. Insert
Object Microsoft Equation 3.0.
Statistics. Use the following Excel formulas when necessary (use Excel 2002 Office
Assistant for Excel 2002 formula definitions and descriptions):
9 Equations for calculating trendlines
The equation for the straight line: y = mx + b
where:
m is the slope
b is the intercept
Once the slope and intercept are known, if one of the dependent variables is
known, a value for the other dependent variable x or y can be calculated through
the formulas:
x' =
(y b)
m
y' = mx + b
Example
Use: =(Sample Response-INTERCEPT)/SLOPE.
This formula gives the sample concentration as found by regression.
9 Equation for calculating the intercept
Use: =INTERCEPT(Response range of cells, Concentration range of cells). For
example, INTERCEPT(A1:A6, B1:B6).
9 Equation for calculating the slope
DFS/ORA
No. 4317
Software Validation
Page 13 of 40
Validation plan (10). The validation plan is a strategic document that should state
what is to be done, the scope of approach, the schedule of validation activities, and
DFS/ORA
No. 4317
Software Validation
Page 14 of 40
the tasks to be performed. The plan should also state who is responsible for
performing each activity. The plan should be reviewed and approved by designated
management. Some suggested components of the validation plan are the following:
Purpose and scope of plan; background information; references; system overview and
process description; vendor selection and management (when applicable);
development/implementation methodology; configuration management for the code,
system, and documentation; validation scope; assumptions, exclusions, and
limitations; validation approach; high-level test plans and system acceptance criteria;
roles and responsibilities; validation schedule; overview of computing environments;
training and implementation strategy; system maintenance and support strategy; requalification criteria; and documentation maintenance.
In addition, the validation plan needs to be written as early in the project as possible
to avoid additional validation costs involved by writing documentation
retrospectively that should have been written at the time the activity occurred.
Validation procedure (10). The validation procedure should include detailed steps
on how to conduct the validation. It should describe the computer system
configuration, as well as test methods and objective acceptance criteria, including
expected outcomes. The procedures should be reviewed and approved by designated
management. The validation procedure should be divided into an Installation
Qualification (IQ) and Performance Qualification (PQ).
9 Installation Qualification. The test cases in the IQ will establish confidence that
the computer hardware and spreadsheet software is in compliance with the
manufacturer and the specifications. The following test cases in the IQ for the
spreadsheet applications software, workbook files and formulas include (4):
System documentation.
Computer system configuration verification.
List of communication cables.
Verification of electrical utility.
Hardware maintenance contracts/procedures.
Hardware change control.
List of critical equipment and spare parts.
Software review.
Software change control.
Standard operating procedure review.
Personnel training requirements and records
System security-physical access.
System security-on line program access.
Software formulas.
DFS/ORA
No. 4317
Software Validation
Page 15 of 40
Validation report (10). The validation report should document detailed results of the
validation effort, including test results. Whenever possible, test results should be
expressed in quantified terms rather than stated as pass/fail. The report should be
reviewed and approved by designated management.
Develop the requirements (in writing). This includes the definition of use,
definition of parameters (range of values, formulas, errors, messages, etc., from the
analytical method) needed to design the spreadsheet.
Use dynamic testing (10). Some testing considerations:
9 Test conditions should include not only normal or expected values, but also
stress conditions (such as a high number of users accessing a network at the same
time). Test conditions should extend to boundary values, unexpected data entries,
error conditions, reasonableness challenges (e.g., empty fields, and date outliers),
branches, data flow, and combinations of inputs. If the worksheet is set up to
perform calculations using input cells, spend some time and enter very large or
very small numbers and observe the effect on the formulas. If the user should
enter a percentage, see what happens if a value over 100 is entered. If a positive
number is expected, try entering a negative number. This also is a good way to
ensure that columns are wide enough.
DFS/ORA
No. 4317
Software Validation
Page 16 of 40
DFS/ORA
No. 4317
Software Validation
Page 17 of 40
text box. Alternatively, use the Insert Comment to add additional instructions for
the users.
Add validation to data-entry cells. Use validation criteria for a particular cell to
ensure that data-entry is of the proper type. Restrict data to whole numbers, decimal
numbers, or text or set limits on entries. Also, a list of acceptable entries can be
specified (this is described in the safety procedure above). For example, to restrict
data to decimal numbers use the sequence: Data Validation Choose Setting
Tab in Allow choose: Decimal in Data Choose between in
Minimum enter 0 and in Maximum enter 100. If the value does not fall between
0 and 100, an error message will be activated. For setting up the message, select Data
Validation choose: Input Message enter short instructions in the window
Title. Optionally, choose: Error Alert and write the correction instructions in the
window: Error Message.
Performance monitoring. Testing must include a periodic review using input data
and conditions that represent the range of actual operating situations. Inputs should be
used for which the correct output is known.
Backup. Procedures should be in place to ensure that the backups are performed on
regular basis and stored in a secure location.
DFS/ORA
No. 4317
Software Validation
Page 18 of 40
DFS/ORA
No. 4317
Software Validation
Page 19 of 40
Provide a source code copy. For Excel the source codes are written in VBA.
Document data-entry validation ranges. Show which cells had data-entry restriction
and what error message(s) will be activated if the value is out of range. Test the
workbook sheet showing different input values.
Use the Workbook Audit report (Power Utility Pak v5.0) to audit each worksheet in
the workbook file and add the report to the validation documentation (12). The PUP
2000 auditing tools provides the following utility tools which are created in a new
workbook automatically:
9 Workbook Summary Report (Figures 5A and 5B): This utility includes the
Workbook summary (Summary information about the workbook), the Name
report (A listing of all names defined in the workbook), the Worksheet report
(Information about each worksheet in the workbook), and the VBA module report
(A listing of the procedures contained in each VB Component).
9 Workbook Link Finder (Figure 6) is a detailed listing of all links contained in the
workbook file (ideal for tracking down phantom links). The utility also has an
option to create a report of all links. This report includes: the Linked files (The
items that appear when Links are selected from the Edit menu); the Formula links
(Formulas that refer to cells in a different workbook); the Name links (Names that
are defined using a different workbook); the XL5/95 dialog box links (Link in the
controls contained on dialog sheets); the Chart links (Links contained in a chart's
SERIES formula or in shapes contained in the chart); Object links (Links
contained in drawing objects or shapes); and, the OLE links (Links from
embedded objects).
9 Worksheet Map (Figure 7) creates a color-coded map that summarizes the
contents of a worksheet. This map can help you spot errors in your sheet -- for
example, a non-formula among a group of formulas. This map displays cell
entries graphically and shows the position in the worksheet of formulas, values,
texts, logic and error.
9 Compare Ranges performs a cell-by-cell comparison of two ranges or two
worksheets. It generates a report of the differences found. You can select among
three options that determine if two cells are different.
9 Date Report (Figure 8) creates a useful report that describes all date cells in a
worksheet or workbook. This report may help identify potential year-2000
problems.
9 Name Lister (Figure 9) allows viewing of all names in a workbook, sorted by the
following categories: the All names (Every name defined in the active workbook),
the Workbook-level names (Names defined at the workbook level) and the Sheetlevel names (Names defined at the worksheet level). These names are preceded by
the worksheet's name and an exclamation point (e.g., Sheet1!MyName), the
Hidden names (Names that are hidden and do not appear in Excel's Define Name
DFS/ORA
No. 4317
Software Validation
Page 20 of 40
dialog box), the Linked names (Names that are defined in terms of a range on a
different workbook) and the Bad names (Names that contain an erroneous
reference). These names often cause a "phantom link" problem -- Excel prompts
the user to update links when the workbook is opened.
9 Formula Report (Figure 10) creates a listing of all formulas in a worksheet or
workbook, including values, and locked /unlocked status for each worksheet.
9 VBA Project Summary Report (Figure 11 and 12) generates a listing of all VBA
procedures contained in a workbook. Optionally, the report includes a list of all
controls contained in all UserForms.
9 VBA macro code (Figure 13) prints the VBA macro codes and can be performed
by PUP 2000 or by Excel it self using the VBA project explorer.
Identify the server drive location of the spreadsheet file. A server location is preferred
over a local hard drive, because it provides wider access by users and ensures that the
backup of the program is automated.
Demonstrate to the supervisor, reviewers and users that the spreadsheet performs
correctly and obtain supervisor and director signatures to release the validated
spreadsheet for general use.
Include copies of the formulas used from the analytical procedure and check them
against the formulas used in Excel. Software formulas must be identified, reviewed
and accepted by QA. The list of all algorithms or formulas used in the spreadsheet
should be on file and documented.
Provide copies of test results and procedures, and of error messages that may result
upon testing. Final specification / requirements document.
Correctly paginate (for example, page X of Y). Validation documentation is a
controlled document, be sure it is signed by author, authorized by two other people
(technical and supervisory), and distributed to specified individuals.
Provide on a 3.5-inch floppy a copy of the final spreadsheet application, the
validation results of the raw data set, a copy of the worksheet validation form (Figure
4), and a copy of the users instruction to the supervisor or person designated by
management to maintain validation documentation.
Create the worksheet validation form on an Excel workbook file (Excel Validation
Forms.xls) as a fill-in-the-blank form; the file can be send via e-mail upon request.
DFS/ORA
No. 4317
Software Validation
Page 21 of 40
proposed change should be requested by completing the request for change section of the change
request form (Figure 14). Each change request should be assigned a unique reference number
and logged in the change request index (Figure 15). If more than one controlled item is to be
changed as a result of the change request then each change should be tracked to completion. The
use of a change note form (Figure 16) for each item should be considered, defining the particular
changes to be made to that item. A change plan may be required for multiple activities and
resources and, if produced, should be attached to the change request and cross-referenced from
it. When all changes have been implemented and re-testing is completed, the change request
should be passed to the supervisor for final review and approval. When the change request form
is completed it should be filed and the change request index (Figure 15) updated.
Managing Workbook File Applications
Each laboratory section should maintain a listing of all validated spreadsheets, their revision
numbers, and corresponding analytical procedures. When the spreadsheet application is
approved, an electronic version of the spreadsheet file must be placed in a dedicated directory on
a network drive. This directory will be protected, with read-only access designated for end-users
of the application file. Access to the network directory where the spreadsheet application is
installed should be granted only to those laboratory sections that will use the application.
A separate, dedicated network directory shall be established for saving filled-in or used
spreadsheets. After completing a given set of data analyses, the analyst must save the filled-in
spreadsheet in this directory. The analyst may not re-use any filled-in spreadsheets for
subsequent analyses. All new data sets must be calculated using the write-protected, blank
spreadsheet template from the network directory. All filled-in spreadsheet applications using the
old spreadsheet version must also immediately be removed and archived in a protected location.
Conclusions
Currently, spreadsheets for analytical applications are widely used in the FDA analytical
laboratories and are starting to emerge in other areas such as the microbiology laboratories. For
these reasons, applications need to be standardized within all FDA laboratories through the use
of standard operation procedures (SOPs) to minimize design and validation discrepancies
among the applications. Basic principles of software engineering techniques must be applied in
the construction of spreadsheet applications. If spreadsheet applications are used without proper
control (SOPs, training), the operation may go out of control creating serious errors among the
applications. Also it is important to use the operational change control (15) forms, which
maintain the analytical applications in a validated stage.
This document is based on a system that consists of both, electronic and paper records. For
example, when a workbook file is completed and printed by the original analyst and verified by
the second analyst, the verified printed sample worksheets are used for the regulatory
documentation and not the electronic workbook file, which is saved and maintained in the
DFS/ORA
No. 4317
Software Validation
Page 22 of 40
laboratory where the sample analysis was performed. This saved workbook file can be used for
future audits against the completed printed worksheets.
Each laboratory must train several analysts to design and validate spreadsheet analytical
applications. These trained analysts can, in turn, train other analysts. The advantage of training
analysts in creating spreadsheet applications is definitely positive for the FDA as was
demonstrated in the Atlanta Center for Nutrient Analysis (ACNA) in which all analysts are using
the single-user spreadsheets (discussed in Part II) as well as the multi-user applications. All
analysts cooperate on improving the multi-user applications as well as the single-user
spreadsheets. Therefore, the standardization of ACNA analytical spreadsheets improved reports
and saved considerable analyst time. The authors currently maintain and up-grade the multi-user
applications by improving the spreadsheet applications (method changes, errors, method
reference changes and improvement of the instructions for the users as requested by the analysts)
and re-validations.
Use of the Power Utility Pak, Version 5.0 or equivalent is recommended, which is a unique
collection of add-ins for Microsoft Excel for Windows. Add-ins are designed to save time, ease
the use of functions and generate validation documentation. It is important to mention that the
degree of validation depends on the complexity of the spreadsheet analytical application. When a
LIMS approach is used to manage the raw data (data from balances and analytical
instrumentation), the raw data can be sent to the existing spreadsheet applications. The
spreadsheet applications should be tested and validated with its documentation before and after
the raw data from the LIMS is sent to the applications. Where application files are locally
installed or on a network by means of a LIMS, it is important that the LIMS and the spreadsheet
applications are secured by implementation of the safeguards in 21 CFR 11 (electronic records
and electronic signature regulations).
Management commitment is needed in order to implement policies and SOPs necessary for
future laboratory accreditation. Implementing controls over the design and development of
analytical spreadsheet applications serves to protect the integrity of the data and offers some
assurance regarding the usefulness of the information of the applications generated. Currently,
spreadsheet development in FDA laboratories is not standardized by means of SOPs, and training
is not normally given to reduce errors.
Finally, it was found that spreadsheet error rates (13) are completely consistent with error rates
found in other human activities (speech, typing, programming, driving, industrial accidents, even
commercial aircraft disasters). Overconfidence tends to blind people to the need for taking steps
to reduce risk. In spreadsheeting formal testing and adherence to tedious disciplines (such as
training and SOPs) can save time and avoid errors. The ability to catch errors installs confidence.
DFS/ORA
No. 4317
Software Validation
Page 23 of 40
References:
1. Title 21 Code of Federal Regulations, Part 211, Current Good Manufacturing Practice for
Finished Pharmaceuticals, Revised as of April 1, 2000; pages 115-135. http://www.fda.gov
2. Title 21 Code of Federal Regulations, Part 58, Good Laboratory Practice for Non-clinical
Laboratory Studies, Revised as of April 1, 2000; pages 297-311. http://www.fda.gov.
3. Ludwig Huber: Validation of Computerized Analytical Systems, Interpharm Press, Inc.,
Buffalo Grove, IL, ISBN: 0-935184-75-9, 1995.
4. Lopez, Orlando, Journal of Validation Technology, Computer Validation Doctor:
Spreadsheet Qualification Applications, Vol. 3, No. 3. 1997, pages 260-266.
5. AOAC International (2000), ISO 17025 and the Laboratory An Introduction to Laboratory
Accreditation, Gaithersburg, MD. http://www.aoac.org
6. 21 CFR Part 11, "Electronic Records; Electronic Signatures, Final Rule," Federal Register 62
(1997) 13430-13466, World Wide Web http://www.fda.gov/ora/compliance_ref/Part11/.
7. Rajalingham, Chadwick, Knight, and Eduards, Proceedings of the 33rd Hawaii International
Conference on System Sciences-2000, Quality Control in Spreadsheets: A software
Engineering-Based Approach to Spreadsheet Development. Available at the internet address:
http://panko.cba.hawaii.edu/ssr/HICSS33/HICSS33-Rajal-SoftEngr.pdf
8. Institute of Chartered Accountants in England and Wales (1994), Briefing No. 6
9. Walkenbach, John (1996), Excel 97 Bible, IDG Books Worldwide, Inc.
10. FDA Draft Guidance for Industry 21 CFR Part 11; Electronic Records; Electronic Signatures
Validation, August 2001. Internet address:
http://www.fda.gov/ora/compliance_ref/part11.htm.
11. Parenteral Drug Association Technical Report 18, 1995, Validation of Computer-Related
System.
12. JWalk & Associates: Auditing report (Power Utility Pak 97 or 2000), http://www.jwalk.com, P.O. Box 12861, La Jolla, CA 92039-2861, (1997).
13. Panko R. R., Journal of End User Computings, Vol. 10, No. 2. 1998, pp. 15-21.
(www.cba.hawaii.edu/panko).
14. FDA: Glossary of Computerized System and Software Development Terminology, The
Division of Field Investigations, Office of Regional Operations, Office of Regulatory Affairs,
(1995).
15. GAMP 4 Good Automated Manufacturing Practice (Guide for Validation of Automated
Systems), 2001
16. Spreadsheet Detective: (for auditing spreadsheets). Southern Cross Software , Queensland.
http://www.uq.net.au/detective
17. Cantellops, Dennis (1997), LIB No. 4119
18. Cantellops, Dennis (1994), LIB No. 3946
19. Diamond, D.; Hanratty, and Venita C. A. (1997), Spreadsheet Applications in Chemistry
Using Microsoft Excel, John Wiley & Sons, NY.
20. Compliance Policy Guide 7153.17 for enforcement of 21 CFR 11: Electronic Records and
Electronic Signatures," Federal Register 64 (1999) 41442-41443.
DFS/ORA
No. 4317
Software Validation
Page 24 of 40
21. DEramo, Paul N.; Budihandojo Rory (1999), Pharmaceutical Technology, 23, No. 3, 78-88.
22. John R. Joyce: Computer / Software Trends. [email protected], Inside Laboratory
Management, AOAC International, August, 1999.
23. Information about ISO17025: http://ts.nist.gov/ts/htdocs/230/235/qualtemp.htm
24. Information about ISO in general: http://www.isogroup.iserv.net/basic10.htm
25. Computerized Systems Used In Clinical Trials
(http://www.fda.gov/ora/compliance_ref/bimo/ffinalcct.htm)
26. R.D. Mcdowall, February 2001. Validation of Spectrometry Software, Part I, Spectroscopy
Magazine.
Additional Information:
Panko, R. R. (1997b). Spreadsheet Research (SSR) is a repository for research on spreadsheet
development, testing, use, and technology. Website: (http://www.cba.hawaii.edu/panko/ssr/).
Honolulu, Hawaii: University of Hawaii.
Panko, R. R. (1997a). Human Error Website:
(http://www.cba.hawaii.edu/panko/papers/ss/humanerr.htm) . Honolulu, HI: University of
Hawaii.
Acknowledgments
The authors wishes to thank Ronald R. Eiternmiller, Ph.D., Basil Vassos Ph.D., Luis Burgos,
Chemist, Cecilia Romero, Chemist and ACNA chemists for useful comments.
Special appreciation is given to Paul J. Motise, CSO for the review of this document and
clarifying some 21 CFR Part 11 issues, which have been included in the body of this paper.
Special appreciation is given to David Irizarry, Computer Specialist, for clarifying some of the
computer related security issues.
DFS/ORA
No. 4317
Software Validation
Page 25 of 40
Show Toolbar
>>
Sample and results page (total fat, saturated fat, polyunsaturated fat, and
monounsaturated fat)
>>
Standard page
>>
>>
DFS/ORA
Show Toolbar
No. 4317
Software Validation
Page 26 of 40
Show Menu
Fatty Acid
4:0
6:0
8:0
10:0
12:0
13:0
14:0
14:1
15:0
15:1
16:0
16:1 cis
17:0
17:1
18:0
18:1 trans
18:1 cis
18:2
18:3
18:4
20:0
20:1
20:5
20:6
22:0
22:1
22:5
22:6
Peak
Area
(Asi)
Res.
Factor
Ri
FAME
wt. (g)
Fi
26160.90
27098.10
251269.00
0.8776
0.9397
0.9867
0.00545
0.00527
0.04656
117172.00
1.0132
0.02114
774.60
1.0302
0.00014
230872.00
1361.89
1831.65
1.0607
1.0489
1.0499
0.03979
0.00024
0.00032
235333.00
13063.03
738911.00
371516.22
7199.01
1.0876
1.0638
1.0854
1.0677
1.1358
0.03956
0.00225
0.12447
0.06362
0.00116
4860.69
1.1058
0.00080
4680.04
1.1217
0.00076
Conv.
Conv.
Factor
Factor
FAME TG
FAME FA
0.9868
0.8627
0.9897
0.8923
0.9915
0.9114
0.9928
0.9247
0.9937
0.9346
0.9941
0.9386
0.9945
0.9421
0.9944
0.9417
0.9948
0.9453
0.9947
0.9449
0.9950
0.9481
0.9950
0.9478
0.9953
0.9507
0.9952
0.9503
0.9955
0.9530
0.9955
0.9527
0.9955
0.9527
0.9954
0.9524
0.9954
0.9520
0.9954
0.9517
0.9959
0.9570
0.9959
0.9568
0.9958
0.9557
0.9957
0.9554
0.9962
0.9604
0.9962
0.9602
0.9961
0.9593
0.9961
0.9591
Total Fat (as triglycerides):
Saturated Fat (as fatty acids):
Polyunsat. Fat (as fatty acids):
Monounsat. Fat (as fatty acids):
Triglyceride
wt (g)
F (i, TG)
Fatty Acid
wt (g)
F (i,FA)
0.00540
0.00523
0.04627
0.00497
0.00488
0.04351
0.02103
0.01992
0.00014
0.00013
0.03960
0.00024
0.00032
0.03773
0.00022
0.00030
0.03938
0.00223
0.12391
0.06332
0.00115
0.03770
0.00214
0.11858
0.06059
0.00110
0.00080
0.00077
0.00076
0.00073
27 %
N/A
N/A
N/A
N/A
11.6 %
4.76 %
9.22 %
27 g
11.6 g
4.76 g
9.22 g
Figure 2. Calculation and results worksheet (secondary data). The raw data sheet is not shown.
DFS/ORA
Show Toolbar
Show Menu
This is the concentration of the internal
standard (C13:0) in mg/mL of the
standard mix (CS13).
Fatty Acids
4:0
6:0
8:0
10:0
12:0
13:0
14:0
14:1
15:0
15:1
16:0
16:1 cis
17:0
17:1
18:0
18:1 trans
18:1 cis
18:2
18:3
18:4
20:0
20:1
20:5
20:6
22:0
22:1
22:5
22:6
No. 4317
Software Validation
Page 27 of 40
Peak
Area
(Ai)
FAME Conc.
(mg/mL)
Fsi
Response
Factor
Ri
16721.90
29841.80
62666.30
0.8776
0.9397
0.9867
32175.50
19334.00
19628.20
0.3000
0.5000
1.0000
0.5000
0.5000
0.3000
0.3000
134731.00
66615.20
33340.60
2.0000
1.0000
0.5000
1.0607
1.0489
1.0499
69074.50
27024.70
206805.00
135629.00
72138.10
1.0000
0.4000
3.0000
2.0000
1.0000
1.0876
1.0638
1.0854
1.0677
1.1358
9852.70
21069.60
0.3000
0.3000
0.5171
1.1058
21372.70
21246.70
0.3000
0.3000
1.1217
1.1151
1.0132
1.0147
1.0302
0.5000 mg/mL
31756.00
Notes:
1. Standard mix used: Kel-Fim-Fame-5, Total FAME's 15.5 mg/mL, catalog No. 4210, Matreya, Inc., Pleasant Gap, PA.
2. Excel 97 v8.0 computerized spreadsheet program, was used to developed this multi-user application.
DFS/ORA
No. 4317
Software Validation
Page 28 of 40
Type of Interaction
N/A
N/A
7. Spreadsheet / Worksheet security (cells and visual basic project properties protection) for inadverted changes.
(Protect worksheet for Contents, Objects, Scenarios)
(VBA Project Properties - Lock project for viewing)
Provide password (s): "xxxxxxxx" for both each worksheet and VBA project properties (see Director bellow).
Each worksheet protected for contents, objects, scenarios and VBA Project Properties - Locked for viewing
8. Workbook file (worksheets) has been tested for normal and problem cases and all formulas were verified by manual
calculations by (signature and date).
Thomas Hamill
9. Spreadsheet / worksheet released for validated use by (Supervisor's / Director's signatures and dates).
Anne P. Reid
10. Server location / Individual PC's of the spreadsheet / worksheet application.
Installed on drive Q, Folder: ACNA Spreadsheet Applications, Folder: FAME's and select > FAME's Calc.xls
11. Document data-entry validation ranges. Shows which cells had data-entry restriction and what error message will
be activated if the value is out of range.
See Attachment F for testing out-put (Screen print out showing the results for the testing).
12. Validation documentation (3.5 inch floppy copy of the final workbook file, the validation results of the
raw data set, a copy of spreadsheet validation form and a copy of the user's instructions) are provided to the supervisor.
Author's signature and date: Dennis Cantellops, 00/00/00
Supervisor signature and date: Anne P. Reid, 00/00/00
DFS/ORA
No. 4317
Software Validation
Page 29 of 40
FAME's Calc.xls
C:\~ACNA Spreadsheet Applications
Dennis Cantellops
Excel 97/2000 W orkbook
W ednesday, January 24, 1996 2:01:02 PM
470,528 bytes
No
Workbook Protection
Structure protected:
Windows protected:
No
No
Sheet Information
Total sheets:
Hidden sheets:
Worksheets:
Chart sheets:
Excel 5/95 Dialog sheets:
Excel 4 XLM Macro sheets:
6
0
6
0
0
0
Workbook Settings
Date system:
Precision as displayed:
Accept labels in formulas:
Linked Files
(no linked files)
ClearStd1
Fat1!PrintArea
Fat2!PrintArea
Menu!PrintArea
Fat1!Print_Area
Fat2!Print_Area
Formulas_1!Print_Area
Inst_1!Print_Area
Menu!Print_Area
Refers To
=Fat1!$D$3,Fat1!$D$4,Fat1!$D$9,Fat1!$I$3,Fat1!$I$4
,Fat1!$I$5,Fat1!$J$8:$J$10,Fat1!$D$15:$D$19,Fat1!$
D$21:$D$42,Fat1!$C$6:$H$7
=Fat2!$I$12,Fat2!$D$10:$D$14,Fat2!$D$16:$D$37
=Fat1!$B$2:$L$52
=Fat2!$B$2:$K$57
=$C$4:$G$17
=Fat1!$B$2:$L$53
=Fat2!$B$2:$K$58
=Formulas_1!$E$63:$G$77
=Inst_1!$B$2:$K$51
=Menu!$E$63:$G$77
Type
Workbook Level
Hidden
No
Workbook Level
Sheet Level
Sheet Level
Sheet Level
Sheet Level
Sheet Level
Sheet Level
Sheet Level
Sheet Level
No
No
No
No
No
No
No
No
No
Figure 5A. Summary Audit Report for worksheets on Figure 1, 2 and 3. This report is generated
with the Power Utility Pak v5.0. If PUP v5.0 is installed in Excel 2002, Select PUP v5 from the
main menu: Auditing Tools. From Figures 5A to 12 are the auditing reports for the worksheet
in Figures 1, 2 and 3, showing the calculations and results for FAMEs.
DFS/ORA
No. 4317
Software Validation
Page 30 of 40
Sheet Name
Menu
Fat1
Fat2
Inst_1
Formulas_1
HelpSheet
Index
1
2
3
4
5
6
Visible
Yes
Yes
Yes
Yes
Yes
Yes
Contents
Protected
No
No
No
No
No
No
Objects
Protected
No
No
No
No
No
No
Scenarios
Protected
No
No
No
No
No
No
Used
Range
A1:H77
A1:IU2205
A1:BF226
A1:BT195
A1:AD197
A1:M98
Used
Rows
77
2205
226
195
197
98
Used
Columns
8
255
58
72
30
13
Cells in
Used Range
616
562275
13108
14040
5910
1274
Hidden
Rows
0
0
0
0
0
0
Hidden
Columns
0
0
0
0
0
0
Sheet Name
Menu
Fat1
Fat2
Inst_1
Formulas_1
HelpSheet
Formula
Cells
0
124
33
5
5
0
Constant
Cells
35
194
102
52
69
10
Empty
Cells
614
561986
13001
14203
5840
1264
Chart
Objects
0
0
0
0
0
0
Shapes
15
16
7
2
14
0
Comments
0
10
3
0
0
0
Scenari
os
0
0
0
0
0
0
Pivot
Tables
0
0
0
0
0
0
Query
Tables
0
0
0
0
0
0
1-2-3
Eval
No
No
No
No
No
No
1-2-3
Entry
No
No
No
No
No
No
Figure 5B. VBA module report for the file FAMEs Cal.xls. The macros and code lines that run
the worksheets on Figures 1, 2, 3 are included.
DFS/ORA
No. 4317
Software Validation
Page 31 of 40
Figure 6. Link Summary Report for worksheet of Figure 2 generated with PUP v5.0.
DFS/ORA
- - T
T V
T -
T
T
T
T
T
T
T
T
T
T
T
T
T
T
T
T
T
T
T
T
T
T
T
T
T
T
T
T
T
T
T
T
T
-
T
V
T
T
T
V
V
V
V
V
V
V
V
V
V
V
V
V
V
V
T
T
T
T
T
- - - - - - - - T T T
T T T
T T T
F F V
F F V
F F V
F F V
F F V
F F V
F F V
F F V
F F V
F F V
F F V
F F V
F F V
F F V
F F V
F F V
F F V
F F V
F F V
F F V
F F V
F F V
F F V
F F V
F F V
F F V
F F V
F F V
- - - - - - - - F - F - F - F - - - - - - -
- - - - T
T
T T T V - - - T V
- T V
- T V
- - T T T
T T T
T T T
V F F
V F F
V F F
V F F
V F F
V F F
V F F
V F F
V F F
V F F
V F F
V F F
V F F
V F F
V F F
V F F
V F F
V F F
V F F
V F F
V F F
V F F
V F F
V F F
V F F
V F F
V F F
V F F
T F T
T T F
T T F
T T F
- - - - - - - - - - - - - - -
F
F
F
F
-
T
T
T
T
T
T
T
T
T
T
T
T
T
T
T
T
T
T
T
T
T
-
No. 4317
Software Validation
Page 32 of 40
Figure 7. Map report for worksheet in Figure 2 generated with PUP v5.0. The graphic display
shows where formulas, values, texts, error and logic are in the audited worksheet.
DFS/ORA
No. 4317
Software Validation
Page 33 of 40
DFS/ORA
No. 4317
Software Validation
Page 34 of 40
Refers to
Sheet level
=Menu!$E$63:$G$77
TRUE
=Fat1!$B$2:$L$53
TRUE
=Fat2!$B$2:$K$58
TRUE
=Inst_1!$B$2:$K$51
TRUE
=Formulas_1!$E$63:$G$77
TRUE
=Fat1!$D$3,Fat1!$D$4,Fat1!$D$9,Fat1!
FALSE
$I$3,Fat1!$I$4,Fat1!$I$5,Fat1!$J$8:$J$1
0,Fat1!$D$15:$D$19,Fat1!$D$21:$D$42
,Fat1!$C$6:$H$7
ClearStd1
=Fat2!$I$12,Fat2!$D$10:$D$14,Fat2!$D
$16:$D$37
FALSE
Fat1!PrintArea
Fat2!PrintArea
Menu!PrintArea
=Fat1!$B$2:$L$52
=Fat2!$B$2:$K$57
=$C$4:$G$17
FALSE
FALSE
FALSE
Defined in
Menu
Fat1
Fat2
Inst_1
Formulas_1
FAME's Calc.xls
Hidden
FALSE
FALSE
FALSE
FALSE
FALSE
FALSE
Linked Bad
FALSE FALSE
FALSE FALSE
FALSE FALSE
FALSE FALSE
FALSE FALSE
FALSE FALSE
FALSE FALSE
FALSE FALSE
FALSE FALSE
FALSE
FALSE
FALSE
FALSE
Figure 9. Display of the named cells and its cell references including the page name.
DFS/ORA
No. 4317
Software Validation
Page 35 of 40
Display
Number
Format
0.0000
0.00000
All
Precedents
1
Direct
Precedents
1
=IF(D15="","",(D15*$J$8/1000)/($J$10*E15)
*($J$9))
Formula
=IF(D15="","",ROUND(+Fat2!F10,4))
F15
15
E16
16
0.0000
=IF(D16="","",ROUND(+Fat2!F11,4))
F16
16
0.00000
E17
17
0.8776
0.0000
=IF(D16="","",(D16*$J$8/1000)/($J$10*E16)
*($J$9))
=IF(D17="","",ROUND(+Fat2!F12,4))
F17
17
0.00545
0.00000
E18
F18
18
18
5
6
0.9397
0.00527
0.0000
0.00000
1
5
1
5
E19
F19
19
19
5
6
0.9867
0.04656
0.0000
0.00000
1
5
1
5
E20
F20
20
20
5
6
1
5
1
5
E21
F21
21
21
5
6
1
5
1
5
E22
F22
22
22
5
6
1
5
1
5
E23
F23
23
23
5
6
1
5
1
5
E24
F24
24
24
5
6
1
5
1
5
E25
F25
25
25
5
6
1.0607
0.03979
0.0000
0.00000
1
5
1
5
E26
F26
26
26
5
6
1.0489
0.00024
0.0000
0.00000
1
5
1
5
E27
F27
27
27
5
6
1.0499
0.00032
0.0000
0.00000
1
5
1
5
E28
F28
28
28
5
6
1
5
1
5
E29
F29
29
29
5
6
=IF(D17="","",(D17*$J$8/1000)/($J$10*E17)
*($J$9))
=IF(D18="","",ROUND(+Fat2!F13,4))
=IF(D18="","",(D18*$J$8/1000)/($J$10*E18)
*($J$9))
=IF(D19="","",ROUND(+Fat2!F14,4))
=IF(D19="","",(D19*$J$8/1000)/($J$10*E19)
*($J$9))
=IF(D20="","",ROUND(+Fat2!F15,4))
=IF(D20="","",(D20*$J$8/1000)/($J$10*E20)
*($J$9))
=IF(D21="","",ROUND(+Fat2!F16,4))
=IF(D21="","",(D21*$J$8/1000)/($J$10*E21)
*($J$9))
=IF(D22="","",ROUND(+Fat2!F17,4))
=IF(D22="","",(D22*$J$8/1000)/($J$10*E22)
*($J$9))
=IF(D23="","",ROUND(+Fat2!F18,4))
=IF(D23="","",(D23*$J$8/1000)/($J$10*E23)
*($J$9))
=IF(D24="","",ROUND(+Fat2!F19,4))
=IF(D24="","",(D24*$J$8/1000)/($J$10*E24)
*($J$9))
=IF(D25="","",ROUND(+Fat2!F20,4))
=IF(D25="","",(D25*$J$8/1000)/($J$10*E25)
*($J$9))
=IF(D26="","",ROUND(+Fat2!F21,4))
=IF(D26="","",(D26*$J$8/1000)/($J$10*E26)
*($J$9))
=IF(D27="","",ROUND(+Fat2!F22,4))
=IF(D27="","",(D27*$J$8/1000)/($J$10*E27)
*($J$9))
=IF(D28="","",ROUND(+Fat2!F23,4))
=IF(D28="","",(D28*$J$8/1000)/($J$10*E28)
*($J$9))
=IF(D29="","",ROUND(+Fat2!F24,4))
=IF(D29="","",(D29*$J$8/1000)/($J$10*E29)
*($J$9))
1
5
1
5
0.0000
0.00000
1.0132
0.02114
0.0000
0.00000
0.0000
0.00000
1.0302
0.00014
0.0000
0.00000
0.0000
0.00000
0.0000
0.00000
1.0876
0.03956
0.0000
0.00000
Figure 10. Formula addresses (Generated with PUP v5.0) for worksheet shown in Figure 2. This
is only an example and not all the formulas are shown.
DFS/ORA
No. 4317
Software Validation
Page 36 of 40
Component Type
Standard Module
Standard Module
Standard Module
Document Module
Procedure Name
PrintForms
EditData
ReturnToForm
workbook_open
Procedure Type
Sub
Sub
Sub
Sub
Start Line
2
19
24
1
Total Lines
17
5
5
7
Procedure Declaration
Sub PrintForms()
Sub EditData()
Sub ReturnToForm()
Private Sub workbook_open()
ThisWorkbook
Document Module
Workbook_BeforeClose
Sub
15
24
Private Sub
Workbook_BeforeClose(Cancel As
Boolean)
Sheet3
Document Module
Worksheet_SelectionChange
Sub
Private Sub
Worksheet_SelectionChange(ByVal
Target As Excel.Range)
Sheet11
Sheet21
Document Module
Document Module
(no procedures)
Worksheet_SelectionChange
(no procedures)
Sub
(no procedures)
1
0
3
(no procedures)
Private Sub
Worksheet_SelectionChange(ByVal
Target As Excel.Range)
Sheet31
Module1
Module1
Module1
Document Module
Standard Module
Standard Module
Standard Module
(no procedures)
Auto_Open
DeleteToolbar
SiblingWorkbooks
(no procedures)
Sub
Sub
Function
(no procedures)
2
25
38
0
23
14
24
(no procedures)
Sub Auto_Open()
Sub DeleteToolbar()
Function
SiblingWorkbooks(WorkbookName,
NumberHurdle)
Module1
Module1
Module1
Module1
Module1
Module1
Module1
Module1
Module1
Module1
Module1
Module1
Module1
Module1
Module1
Module2
Module2
Sheet1
Sheet2
AboutBox
AboutBox
Standard Module
Standard Module
Standard Module
Standard Module
Standard Module
Standard Module
Standard Module
Standard Module
Standard Module
Standard Module
Standard Module
Standard Module
Standard Module
Standard Module
Standard Module
Standard Module
Standard Module
Document Module
Document Module
Form
Form
ShowToolbar
HideToolbar
SampleMacro
GoTo_Fat1
GoTo_Fat2
GoTo_Menu
GoTo_Spl1
GoTo_Std
GoTo_Inst_1
GoTo_Formulas_1
GoTo_Top2
GoTo_Top1
ClearCells1
ClearCells2
ClearCells3
Print_Page_Fat1
Print_Page_Fat2
(no procedures)
(no procedures)
Label2_Click
OKButton_Click
Sub
Sub
Sub
Sub
Sub
Sub
Sub
Sub
Sub
Sub
Sub
Sub
Sub
Sub
Sub
Sub
Sub
(no procedures)
(no procedures)
Sub
Sub
62
69
75
86
94
102
110
118
125
132
143
151
159
173
184
1
9
(no procedures)
(no procedures)
2
6
5
7
11
8
8
8
8
7
7
7
12
8
14
11
20
7
8
0
0
4
4
Sub ShowToolbar()
Sub HideToolbar()
Sub SampleMacro()
Sub GoTo_Fat1()
Sub GoTo_Fat2()
Sub GoTo_Menu()
Sub GoTo_Spl1()
Sub GoTo_Std()
Sub GoTo_Inst_1()
Sub GoTo_Formulas_1()
Sub GoTo_Top2()
Sub GoTo_Top1()
Sub ClearCells1()
Sub ClearCells2()
Sub ClearCells3()
Sub Print_Page_Fat1()
Sub Print_Page_Fat2()
(no procedures)
(no procedures)
Private Sub Label2_Click()
Private Sub OKButton_Click()
Module11
Module11
FormHelp
Standard Module
Standard Module
Form
ShowAboutBox
ShowInstructionsBox
CommandButton1_Click
Sub
Sub
Sub
1
5
12
3
4
9
Sub ShowAboutBox()
Sub ShowInstructionsBox()
Private Sub CommandButton1_Click()
FormHelp
Form
LabelText_Click
Sub
21
FormHelp
Form
UserForm_Initialize
Sub
25
13
FormHelp
FormHelp
Form
Form
UpdateForm
ComboBoxTopics_Click
Sub
Sub
38
63
25
6
FormHelp
Form
PreviousButton_Click
Sub
69
FormHelp
Form
NextButton_Click
Sub
77
FormHelp
Form
ExitButton_Click
Sub
85
HelpMod
Standard Module
ShowHelp
Sub
Sub ShowHelp()
Figure 11. Display of the Visual Basic project for the workbook file.
DFS/ORA
No. 4317
Software Validation
Page 37 of 40
Control Type
Label
CommandButton
Label
CommandButton
CommandButton
CommandButton
Label
Frame
ComboBox
CommandButton
Control Name
Label1
OKButton
Label2
ExitButton
NextButton
PreviousButton
LabelText
Frame1
ComboBoxTopics
CommandButton1
Left
12.0000
168.0000
12.0000
12.0000
216.0000
156.0000
4.0000
12.0000
12.0000
72.0000
Top
30.0000
90.0000
6.0000
162.0000
162.0000
162.0000
3.8500
30.0000
6.0000
162.0000
Width
Height
198.0000 54.0000
42.0000 20.0000
66.0000 18.0000
49.5000 19.5000
49.5000 19.5000
49.5000 19.5000
212.0000 122.1500
252.0000 120.8000
252.0000 18.0000
72.0000 20.0000
Container
AboutBox
AboutBox
AboutBox
FormHelp
FormHelp
FormHelp
Frame1
FormHelp
FormHelp
FormHelp
Figure 12. Display of the Visual Basic project for the workbook file user form names, which
control the dialog boxes of the application.
Sub DeleteToolbar()
' Delete the toolbar from the collection
' This keeps the EXCEL5.XLB file smaller
' Cancel the toolbar display
If IsNull(SiblingWorkbooks(BookName, 1)) Then
Application.OnWindow = ""
With ThisWorkbook
.OnSheetActivate = ""
.OnSheetDeactivate = ""
Toolbars("Fatty Acids Toolbar").Delete
End With
End If
End Sub
Figure 13. Example of a VBA macro in the Module 1 composed of nine code lines (Module 1 is
composed of a total of 202 code lines) that must be included in the validation documentation.
DFS/ORA
No. 4317
Software Validation
Page 38 of 40
Date: 05/07/02
Signature:
Date: 05/07/02
Change Details
Comments: Formula in cell K19, page "FAME Calc", the rounding formula is incorrect.
Date: 05/07/02
Date: 05/07/02
Job title:
Director
Date: 05/07/02
Figure 14. Example for the request for change form. This example is for correcting a formula.
DFS/ORA
No. 4317
Software Validation
Page 39 of 40
Description
FAMEs rounding formula incorrect.
Disposition Acc.
/ Rej. Date
Number of
Change Notes
Date Close
Accepted
05/07/02
DFS/ORA
No. 4317
Software Validation
Page 40 of 40
Change Note
Analytical Application:
FAMEs Calc.
Type of Change:
Correct formula
Note Number:
1
Application Version:
FAMEs Calc. V3.0
Details of Change to perform:
Formula in cell K19, page "FAME Calc", the rounding formula is incorrect.
Implemented by:
Print name:
James Martin
Signature:
Date:
5/7/02
Figure 16. Example for change note form. This form is use when more than one change is
requested. Use one separate change note form for each item to be change.