The present invention relates generally to diagnostic systems and methods and, more particularly, to diagnostic systems and methods for troubleshooting a complex system, such as a military aircraft, to identify one or more components, such as one or more weapon replaceable assemblies (WRAs) or lower level components, that has failed.
Complex systems, such as, for example, military aircraft may be designed using existing Commercial Off-The-Shelf (COTS) components or Modified Off-The-shelf (MOTS) components. The COTS/MOTS design methodology allows the designer or system engineer to utilize readily available components that may meet the system requirements with little or no modification. Another advantage of the COTS/MOTS components may be that a design and development cycle may not be required for the individual components, thus freeing a system engineer to focus on system integration and testing issues.
While systems designed with COTS/MOTS components may enjoy the advantages described above, they may also be subject to limitations. One of the potential limitations of systems designed with COTS/MOTS components may be testability. The testability of a system may rely on the individual test features built into the COTS/MOTS component, thus the limited test capability may not fully provide interface testing, subsystem testing, and/or full system testing capabilities.
A typical requirement of complex systems, particularly in military applications, may be for the provision of enhanced diagnostic fault detection and isolation capabilities. Further, based on the complexity of the system under test (SUT), the enhanced diagnostic fault detection and isolation system may be required to automatically interact with the SUT.
Maintenance, including the reliable troubleshooting of complex systems, may be a common issue in various industries, including the aircraft and automotive industries, the electronics industry, the defense industry and the like. In the military, for example, maintenance of an aircraft may be of importance to ensure the continued safe, efficient and effective operation of the aircraft. Minimum ground time between flights may be desirable to maximize asset utilization and to meet the established mission goals. Therefore, the time allocated to unscheduled maintenance may often be limited to the relatively short time that the aircraft is required to be on the ground in order to permit reloading of munitions and ordnance, to refuel and to otherwise service the aircraft.
Properly performing unscheduled maintenance in both an accurate and timely manner may be critical in a battlefield situation. Troubleshooting a combat aircraft which may be an extremely large and complex system comprised of many interconnected subsystems may be particularly difficult. In the COTS/MOTS design methodology, each subsystem may typically be comprised of many WRAs that may be individually replaceable. A WRA may be mechanical, such as a valve or a pump; electrical, such as a switch or relay; or electronic, such as an autopilot or a flight management computer. Many WRAs are, in turn, interconnected. As such, the symptoms described by flight deck effects or other observations may indicate that a fault in more than one WRA may explain the presence of the observed symptoms. At that point, there may be ambiguity about which WRA(s) have actually failed. Additional information may be needed to disambiguate between the possibilities.
Given the complexity of modern military aircraft, computers are often used to assist in the diagnostic and maintenance processes. An example is the Integrated Electronic Technical Manual (IETM). The IETM is an electronic version of the technical manual for an aircraft that is coupled with a computer system capable of interfacing with the aircraft to interrogate the systems of the aircraft in order to better diagnose the aircraft.
The present invention provides an enhanced diagnostic fault detection and isolation approach that may be compatible with automated equipment such as the IETM, for example. Further, the systems and methods of the present invention provide the flexibility to integrate with the various COTS/MOTS subsystem components of an SUT. Accordingly, the systems and methods of the present invention may overcome the testability limitation of systems designed using COTS/MOTS components by providing a diagnostic approach that may be configurable to test each unit under test (UUT) within an SUT thereby providing a comprehensive testing capability to a system that incorporates COTS/MOTS components.
The enhanced diagnostic fault detection and isolation systems and methods of the present invention are described below in relation to an Integrated Electronic Technical Manual (IETM) for purposes of illustration. However, it should be appreciated that the enhanced diagnostic fault detection and isolation systems and methods of the present invention may be used with other types of equipment and in other operational environments, such as on a personal computer, incorporated within a system under test, on a handheld computing device, and/or the like.
According to the present invention, improved enhanced diagnostic fault detection and isolation systems and methods are provided. Since the enhanced diagnostic fault detection and isolation system and method may be particularly useful in the aircraft industry, the enhanced diagnostic fault detection and isolation system and method will be hereinafter described and illustrated in conjunction with the troubleshooting of an aircraft. However, the diagnostic system and method may be used to troubleshoot any system having a number of interconnected components, such as the complex systems created by the automotive, marine, electronics, power generation and computer industries, for example.
In general, the enhanced diagnostic fault detection and isolation methods and systems of the present invention are based on a divide and concur flow control methodology. Functional test tasks (called checkout tasks) can be built from a number of sequential subtasks. The sequential execution of these subtasks build on the successful completion of prior subtasks. This allows the system to fault diagnose/fault isolate (FD/FI) root causes of failures. It would not be valid to FD/FI a UUT if the interface to the UUT or the controlling computer to the UUT were failing. To test a subsystem or WRA, the required components between the IETM and the UUT are verified as operational, such as, for example, connectivity to the controlling computer. Once the controlling computer is verified as functional, the input/output (I/O) from the UUT is verified as valid before testing the UUT.
For example, in testing a WRA that is controlled by a mission computer over a 1553 interface, assume the 1553 interface is not connected to the mission computer or the wires have been severed for both channels. The IETM diagnostics of the present invention first verifies communications to the mission computer. Once communication has been validated, the mission computer is tested. Once the mission computer has been verified to be operational and no built in test (BIT) errors are reported, the 1553 interface is checked for communication to the various subsystems. In this case, no valid communication to any of the WRAs is possible since the interface is either not connected or broken. Fault detection has occurred within the critical path to the UUT and therefore would require fault isolation to the root cause since the 1553 is required to communicate to the UUT. Fault isolation may be accomplished by sequential execution of those subtasks built upon the successful completion of prior subtasks. In this case, the 1553 interface channels are routed via different paths of the system, thus eliminating the possibility the problem could be any place else but near or at the source of the 1553 communication. Through the various subtask tests (verify connection, inspections, and testing continuity, etc . . . ) of the 1553 prerequisite test, the fault would be isolated to the interface wiring. If this prerequisite test were not executed, FD/FI would not have correctly isolated to the root cause. Testing of the UUT never occurred in the above example because the fault was detected and isolated within the prerequisite test (root cause). The prerequisite tests in this example were the IEETM, IETM to mission computer connection, mission computer, and then mission computer interface to the UUT.
Variations of the prerequisite tests may be determined by physical hierarchy of the SUT and UUT. In the example above, if the UUT were connected to an Aeronautical Radio, Inc. (ARINC) 429 interface instead of the 1553, for example, and the ARINC 429 interface was working, the UUT would have been tested because it is not dependent upon the 1553 being functional. In fact, the 1553 prerequisite would not have been called since it is not part of the data path to the UUT.
Accordingly, prerequisite testing may be broken down into the finest parts to allow specific testing to be conducted so the path between the IETM and the UUT can be validated without interfering with the test results.
The fault group for the above example fault would have been automatically isolated to the interface wiring at the mission computer, 1553 address, and lastly the mission computer. As determined by eliminating those tests that did pass, the physical connection and routing of the interface wiring, and architecture of the system under test. In this case coordination of the I/O status of all the other WRAs on the 1553 may determine that the other WRAs could not communicate to the controlling computer.
Fault isolation ends when a fault group has been determined. The fault group at this point is a list of faults that can represent the root cause of the problem. Selecting one of the faults in the fault group will link to a Remove and Replace (R/R) procedure or a repair procedure depending on the fault.
The testing of individual UUTs may incorporate tests with overlapping scope. The enhanced diagnostic fault detection and isolation may be optimized with respect to time of test by setting a flag that indicates to the IETM that testing should not be repeated for elements. In other words, if the testing for two UUTs requires the testing of the mission computer, the second UUT test can rely on the first test of the mission computer if it passed. Optimization may enable a test to be completed in less time as compared to a test without optimization enabled.
In operation, the IETM executes an enhanced diagnostic fault detection task sequence in accordance with the present invention. The diagnostic task sequence generates commands, which are sent from the IETM 116 to the UUT server 110 via the link 114. The commands test the subsystem in a hierarchical fashion and build on one another. In other words, the enhanced diagnostic fault detection task sequence has been designed to test the subsystem in an order that permits subsequent tests to build on the results of previous tests. For example, the enhanced diagnostic fault detection task sequence may test the COTS box 1102 first, then test the MOTS box 2108, then test the MOTS box 1106 and, finally, test COTS box 2104. The order of tests may depend on a number of factors including a subsystem function and a subsystem interconnection configuration.
The UUT server 110 provides access to the COTS/MOTS subsystem built-in-test functionality, as well as the subsystem interface functionality. The UUT 110 server provides a low-level interface between the IETM and the individual subsystems. By keeping the UUT server 110 operating as a low-level interface, the subsystems may contain operational software and the ETM may contain high-level test software. This layering of the functionality may be efficient for purposes of testing and certification. In safety critical systems, such as, for example, avionics, it may often be desirable to keep the amount of software, and hence the amount of software changes, to a minimum in order to reduce the need for re-testing and/or re-qualification when the software is updated with changes.
The enhanced diagnostic fault detection and isolation system may be operated fully automatically, fully manually or in a combination of automatic and manual modes.
The enhanced diagnostic fault detection and isolation system provides fast built-in-test result interpretation. This may allow a complex system to be diagnosed rapidly. In addition to automated testing and interpreting of results, the enhanced diagnostic fault detection and isolation system also provides the capability for manual testing in cases where automated testing may be either impractical or impossible. In such cases, the enhanced diagnostic fault detection and isolation sequence guides the user through the steps necessary to perform the manual test. Further, the IETM queries the user for result input and uses the results for fault detection and isolation in conjunction with automated test results. The combination of automated and manual testing provides a balance between speed of testing and completeness of test coverage, depending upon the contemplated uses of the present invention.
In operation, the IETM 116 sends commands and receives responses via a link 114 to UUT-IETM interface 202. The UUT-IETM interface 202 routes the commands and responses to one of the three interfaces (204-208) according to the appropriate COTS subsystem (216-220) under test. Each interface (204-208) in the UUT server is connected to and configured according to the corresponding COTS interface (210-214) respectively.
The exemplary embodiment shown in
As an alternative configuration, the UUT server may be unique for each subsystem.
In operation, the IETM 116 routes commands to the appropriate UUT server in accordance with the function being tested in the enhanced diagnostic fault detection and isolation test sequence. For example, when a test sequence requires a test command be sent to COTS subsystem 1326, a test command is sent from the IETM 116 via a link 114 to the UUT-IETM interface 308 and then to the UUT server 302 subsystem interface 314. The UUT server 302 subsystem interface 314 sends the command via a link 112 to the COTS interface 320, which is coupled to the COTS subsystem 326.
In operation, the UUT interface 404 issues commands and receives responses from the interface element (PBIT 406, IBIT 408, MBIT 410, or I/O 412) of COTS subsystem 414 that corresponding to commands received from the IETM (not shown) via the IETM interface 402.
In step 504, prerequisite condition tests are performed. The prerequisite tests are selected based on physical hierarchy. Prerequisite tests are those tests that may be required to validate core functionality to the system before the UUT is diagnosed. Therefore, isolation may be performed if any prerequisite test fails. For example, in order to test a flight display, the prerequisite tests required may include the IETM to mission computer interface, the mission computer to communications bus interface, and the communications bus to flight display interface. Once all of the necessary prerequisite tests have passed, the test of the actual UUT can proceed. If a fault is found in the prerequisite condition test results, then control transfers to a fault group 505 for fault isolation and remove and replace indications. If no fault is found, control continues to step 506.
In step 506, PBIT is performed. PBIT is a non-operator initiated BIT that runs periodically in the background of a subsystem and is non-disruptive to the subsystem. If there are any faults detected in the PBIT results, then control transfers to a fault group 507 for fault isolation and remove and replace indications. If no fault is found, control continues to step 508.
In step 508, interface tests are performed. The interface test routines test the data communication between subsystems. The interface tests do not require operator intervention. Two general types of faults may be detected in the interface tests, a fault that is beyond the subsystem being tested and a fault that is within the subsystem being tested. If a fault is detected that is beyond the subsystem being tested, the WRA interface test will return with an error code and a message indicating a new work order may be needed and what test needs to be performed. If a fault is detected in a WRA that is within the subsystem or wiring being tested, then control transfers to a fault group 509 for fault isolation and remove and replace indications. If no fault is detected, control continues to step 510.
In step 510, BIT tests are performed. The IBIT test task returns when IBIT is passed or skipped. If any faults are detected during IBIT, then the task ends and control transfers to a fault group 511 for fault isolation and remove and replace indications. If the IBIT tests pass, control continues to step 512.
In step 512, manual test tasks are performed. A manual test task will not return unless it is passed or is skipped by the operator. If a fault is detected during a manual test task, control transfers to a fault group 513 for fault isolation and remove and replace indications. If no faults are detected, control continues to step 516, where control terminates.
In step 604, the PBIT task initializes variables and data structures for performing PBIT. A command may be sent from the IETM to the UUT server requesting detailed device data for the subsystem. Once initialization is complete and no errors occurred, control transfers to step 606.
In step 606, mode checks are performed on the subsystem. If the subsystem is ready for PBIT, then control transfers to step 608. If the subsystem is not ready for PBIT, then control transfers to step 614. In step 614, the CALL_PROC variable is evaluated. If the CALL_PROC variable is equal to ID, a fault is indicated and must be isolated. Control transfers to step 616 for fault group links to mini-procedures to further isolate the fault. Otherwise, control transfers to step 618. In step 618, the STATUS and CALL_STAT variables are set and a message is displayed to the user if messaging is enabled. Control then transfers to step 632, where the task returns (terminates). The CALL_PROC variable may be used to determine WRA scope. If a task (other than a FLOW task) determines a failure, the fault group will only be displayed if the WRA is the same as the CALL_PROC scope. Otherwise, CALL_STAT is set to a failure message. CALL_STAT is the return status variable for tasks/subtasks other than the controlling FLOW task. CALL_STAT may be initialized in each task to a null string and set to a failure message for exit conditions. Test tasks including PBIT, IBIT, and interface tests, may initialize CALL_STAT to null since it is a global variable. If DISPLAY_MSG is true a message is also displayed to the maintainer before testing is returned to the calling task (usually the FLOW task). DISPLAY_MSG is a variable used to trigger a display message if a fault is OUT OF SCOPE. If DISPLAY_MSG contains a non-zero value the message will be displayed. Otherwise, the no message will be displayed.
In step 608, critical Input/Output (I/O) tests are performed. If a fault is detected in the critical I/O tests, operator intervention mini-procedures may be indicated. The operator intervention mini-procedures may include circuit breaker, power switch, power cable, wire isolation, cooling fan, ETI, video, probe voltage test, bus address, configuration pin checks and/or the like. The operator intervention mini-procedures are designed to eliminate obvious sources of critical I/O faults. If the operator-intervention mini-procedures do not correct the problem and a fault still exists after performing the critical I/O test, then control transfers to step 620. If no errors are detected in the critical I/O tests, then control transfers to step 610.
In step 620, the CALL_PROC variable is evaluated. If the CALL_PROC variable is equal to ID, a fault is indicated and must be isolated. Control transfers to step 622 where the fault group further isolates the fault and remove and replace indications may be provided. If the CALL_PROC variable does not equal the ID variable control transfer to step 624. In step 624, the STATUS and CALL_STAT variables are set, and a message is generated for the user if messaging is enabled. Control then transfers to step 632, where the task returns (terminates).
In step 610, the detailed BIT status is checked in a hierarchical sequence based on IBA information to detect faults. Any BIT detected fault is isolated. The faults are mapped to a WRA or a list of candidate WRAs. If the fault that was detected is indeterminate, then the IETM generates an error. If errors were detected in the detailed BIT status check, then control transfers to step 626. In step 626, the CALL_PROC variable is evaluated. If the CALL_PROC variable is equal to ID, a fault is indicated and must be isolated. Control transfers to step 628 where the fault group further isolates the fault and remove and replace indications may be provided. If the CALL_PROC variable does not equal the ID variable control transfers to step 630. In step 630, the STATUS and CALL_STAT variables are set, and a message is generated for the user if messaging is enabled. Control then transfers to step 632, where the task returns (terminates). If no faults were detected in step 610, control transfers to step 612. In step 612, the PBIT tasks returns control to the calling function.
In step 704, variables and data structures are initialized and a command for BIT data is sent to the subsystem. Control then continues to step 706.
In step 706, a command requesting message data is sent to the subsystem. Control continues to step 708.
In step 708, status conditions on the tests for each subsystem are checked. If the status conditions indicate a fault, then control continues to step 709. If the status conditions indicate that no faults occurred then control continues to step 710.
In step 709, a message is displayed to the operator listing each faulty subsystem. The operator can then perform tests on the faulty subsystems or open a new work order for replacement of a WRA if the fault was isolated to a specific WRA. Control then transfers to step 711, in which a variable is set indicating that the interface tests did not execute and a variable is set indicating the reason for the task terminating. Control then continues to step 716, where the sequence terminates.
In step 710, the device message status is checked. If the device message status indicates no faults, a variable is set indicating successful completion of the test and control continues to step 722, where the sequence terminates. However, if the device message status indicates faults in the message interface tests then control continues to step 712.
In step 712, any detected faults are isolated to a single WRA or a list of candidate WRAs. Control continues to step 714.
In step 714, the WRA list is evaluated to determine whether the list is in scope based on the CALL_PROC variable. If the WRA list is within scope, control continues to step 718. If the WRA list is not within scope control continues to step 720.
In step 718, the WRA failure is linked to remove and replace procedures and the interface test task sequence terminates.
In step 720, a message indicating that the WRA is out of scope is displayed to the operator. The message may inform the operator that no further interface testing was performed and that a new work order may need to be created to replace the faulty WRA. A variable is set indicating that the interface tests did not execute. Control then transfers to step 711, in which a variable is set indicating that the interface tests did not execute and a variable is set indicating the reason for the task terminating. Control then continues to step 716, where the sequence terminates.
In step 804, variables and data structures that may be used in the initiated BIT test are initialized. For example, the CALL_STAT variable is set to a value of 0 indicating PASS. CALL_STAT is the return status for all tasks/subtasks other than the controlling FLOW tasks. CALL_STAT should be initialized in each task to a null string and set to a failure message for all exit conditions. All test tasks, for example PBIT, IBIT, and interface tests, should initialize CALL_STAT to null since this is a global variable. Upon detection of a failure, CALL_STAT is set such as “Pilot Flight Display Critical FAIL” before any exception processing occurs. This variable is only utilized when a fault is detected and the IETM fails to report the fault. The enhanced diagnostic fault detection and isolation system has the capability to capture non-detects and CALL_STAT is the variable used to report to the task that was executing when the problem was detected. Control then continues to step 806.
In step 806, a command is sent to the subsystem under test requesting BIT data. Detailed device data is also gathered. Control continues to step 808.
In step 808, the setup requirements for the test are checked. If the setup requirements are not properly met, control continues to step 828. If the setup conditions are properly met, control continues to step 810.
In step 828, a message is displayed to the operator listing the subsystem where the setup problem occurred. The operator can then initiate a test of the faulty subsystem. Control then continues to step 830.
In step 830, a variable is set to a value indicating that initiated BIT did not execute. Another variable is set indicating that IBIT testing is incomplete and the IBIT task is skipped. Control continues to step 832, where the IBIT control sequence terminates.
In step 810, if the test is lengthy, such as for example taking more than one minute to complete, a dialog message is displayed to an operator providing the operator with an opportunity to skip the test. The operator must provided input indicating whether to continue with the test or skip the test. Control continues to step 812, where the response from the operator is evaluated. If the operator has elected to skip the test control continues to step 830 (described above), otherwise if the operator has elected to continue with the test control continues to step 814.
In step 814, a command is sent to start the test. Control continues to step 816.
In step 816, a delay loop is set up to wait while the IBIT test is being performed. Control continues to step 818. In step 818, a command is sent to get the status of the IBIT test. Control continues to step 820.
In step 820, the status of the IBIT test is evaluated. If the test has started control continues to step 822, otherwise control continues to step 824.
In step 822, the IBIT test status is evaluated. If the status indicates that the IBIT test is complete control continues to step 834, otherwise, control continues to step 824.
In step 824, the IBIT test timeout is checked. A timeout value is used to prevent the IBIT test task from “hanging” if the IBIT does not complete for any reason. If the timeout has been reached, control continues to step 826, otherwise, control continues to step 816 (described above).
In step 826, the IBIT test task sequence terminates and control continues to a fault group which links to mini-procedures for evaluating the cause for the IBIT timeout occurring.
In step 834, the detailed BIT status is checked in a hierarchical sequence to detect failures. If failures have occurred, control continues to step 836, otherwise control continues to step 838.
In step 836, an attempt is made to isolate the faults detected during IBIT. The faults are mapped to a single WRA or a list of candidate WRAs. Interface conditions are checked if required, because external conditions can cause BIT failures in certain cases. Control continues to step 840. In step 840, the IBIT test task sequence terminates and control continues to a fault group, which links to remove and replace procedures for the WRAs identified as faulty.
In step 838, a variable is set to a value indicating successful completion of the IBIT test task sequence and the IBIT test task sequence terminates.
In operation, the IETM 902 performs a fault detection and isolation task sequence on the COTS/MOTS subsystem 906. The IETM 902 generates an intermediate listing of faults detected and stores this list in the IETM memory (not shown). The IETM 902 then requests any fault data stored by the COTS/MOTS subsystem 906 in the subsystem data storage device 908. The data received from the COTS/MOTS subsystem 906 is used to augment the intermediate listing of faults stored in the IETM memory (not shown). The intermediate listing of faults is then used by the IETM 902 to generate a fault log 910. The records in the fault log 910 can be sorted and arranged according to a variety of criteria, including, for example, time of occurrence, error code, error type, subsystems affected and/or WRAs affected.
The IETM 902 can then transform the fault log 910 into a look-up table structure. The look-up table structure provides the user with a presentation of the fault log 910 that may be easier to interpret.
In generating the fault log 910 and look-up table structure, the IETM 902 may convert BIT codes, which represent WRA and/or subsystem status into text messages that may be more easily understood by a user of the system.
The IETM 902 enhanced diagnostic fault detection and isolation task is configured to provide a time-based filter function. The filter function allows the user of the IETM 902 to specify time ranges or ordering of fault occurrences so that a user may be able to ascertain when a fault occurred in relation to other events occurring in the system and/or subsystem. This capability may be particularly useful in troubleshooting an intermittent event or correlating a fault with another seemingly unrelated system or subsystem event.
In operation, commands may be sent from the IETM 1012 to the UUT server 1000. The character conversion module 1002 processes the commands in order to map the characters of the IETM 1012 to the corresponding characters of the COTS/MOTS subsystem under test 1014. Next, the data conversion module 1004 processes the command. The data conversion module 1004 converts the data format of the command from the IETM format into the appropriate format for the COTS/MOTS subsystem under test 1014. The format conversion module 1006 then processes the command. The format conversion module 1006 converts and/or adapts the format of the IETM command to the appropriate format for transmitting to the COTS/MOTS subsystem under test 1014.
In operation, there may be a plurality of possible states that can exist for the exemplary interface arrangement shown in
In an exemplary embodiment of the present invention, a variable, DISPLAY_MSG, controls the level of messaging that is used to display messages to the maintenance technician. For example, if DISPLAY_MSG is set to 0, or none, no messages will be displayed. This level is typically not selectable by a user. However, it can be set programmatically to run tests in the silent mode.
If DISPLAY_MSG is set to 1, or critical only, only critical messages will be displayed. Critical messages are those that impact testing for those tests that are executed where CALL_PROC does not equal ID, including tests that take longer than 15 seconds (INIT, TEST, etc. . . . ). Critical messages may be displayed in blue and if a timeout occurs, the resulting message may be displayed in red. For tests that impact execution (NC, MTEST), messages will be displayed in red.
If DISPLAY_MSG is set to a value of 2, or fault, flow and fault messages will be displayed. Flow messaging will be displayed to provide maintainer insight into what tests are being executed. Fault messages are those messages that effect testing or tests that fail but do not result in a Fault Group such as (EGI1 Critical I/O Fault Detected). All Fault Messages may be displayed in red.
If the message reports a subsystem failed such as (EGI BIT Check—FAILED). The word “FAILED” may appear in uppercase and emphasized.
If the message contains mixed information such as the following: “EG12 Interface Test to Pilot Flight Display Passes. Interface test to Copilot Flight Display cannot be validated, Copilot Flight Display did not pass PBIT.” Pass information may be displayed in blue and fault information may be displayed in red and data indicating why a fault occurred may be underlined.
If DISPLAY_MSG is set to a value of 3, or all, all messages are displayed. This also pertains to Bit Display Tables. Messaging should provide what test is being executed and corresponding result. Pass messages may be displayed in green and fail/fault messages may be displayed in red.
In a first exemplary state, all WRAs pass PBIT. The interface between WRA 11202 and WRA 21204 and WRA 31206 pass. The IETM may display a message that reads, for example, “WRA 1 Interface to WRA 2 and WRA 3—Pass.”
In a second exemplary state, an interface test to WRA21204 passes and an interface test to WRA31206 fails. The IETM may display a message that reads, for example, “WRA1 interface to WRA2 passed. Interface to WRA3 failed. Probable cause is interface wiring between splice and WRA3. R/R: Interface wiring from splice to WRA3, WRA3.”
In a third exemplary state, an interface test to WRA21204 fails and interface test to WRA31206 passes. The IETM may display a message that reads, for example, “WRA1 interface to WRA3 passed. Interface to WRA2 failed. Probable cause is interface wiring between splice and WRA2. R/R: Interface wiring from splice to WRA2, WRA2.”
In a fourth exemplary state, an interface test to WRA21204 fails and an interface test to WRA31206 fails. The IETM may display a message that reads, for example, “WRA1 interface to WRA2 & WRA3 failed. Probable cause is interface wiring between WRA1 and WRA2 & WRA3. R/R: WRA1 interface to WRA2 & WRA3, WRA1, WRA2, & WRA3 (WRA2 & WRA3 low probability).”
In a fifth exemplary state, WRA11202 and WRA21204 pass PBIT, and WRA31206 fails PBIT. In this state, the interface test from WRA1 to WRA3 may be a don't care since the validity of the interface cannot be validated due to WRA31206 failing PBIT.
In a sixth exemplary state, an interface test to FDP passes. The IETM may display a message that reads, for example, “WRA1 interface Test to WRA2 Passes. Interface test to WRA3 cannot be validated, WRA3 did not pass PBIT. Run WRA3 diagnostics to isolate.”
In a seventh exemplary state, an interface test to WRA2 Fails. The IETM may display a message that reads, for example, “WRA1 interface Test to WRA2 Failed. Interface test to WRA3 cannot be validated, WRA3 did not pass PBIT. Run WRA3 diagnostics to isolate.”
In an eighth exemplary state, an interface test to WRA3 passes. The IETM may display a message that reads, for example, “WRA1 interface Test to WRA3 Passes. Interface test to WRA2 cannot be validated, WRA2 did not pass PBIT. Run WRA2 diagnostics to isolate.”
In a ninth exemplary state, an interface test to WRA3 Fails. The IETM may display a message that reads, for example, “WRA1 interface Test to WRA3 Failed. Interface test to WRA2 cannot be validated, WRA2 did not pass PBIT. Run WRA2 diagnostics to isolate.”
The last 2 variables are dependent upon the calling procedure (WRA11202 verses one of the other WRAs (WRA21204 or WRA31206). This is because the WRA11202 is the source and communicates to both WRA21204 and WRA31206 where WRA21204 and WRA31206 can only receive eliminating the interface between WRA21204 and WRA 31206.
For example, the CALL_PROC variable is set to WRA1. Both WRA21204 and WRA31206 fail PBIT. In this case, the interface test from WRA1 to WRA2 and WRA 3 may be a “don't care” since the validity of the interface cannot be validated due to WRA2 & WRA3 failing PBIT.
In a tenth exemplary state, an interface test to WRA21204 fails and an interface test to WRA31206 fails. The IETM may display a message that reads, for example, “Interface test to WRA2 cannot be validated, WRA2 did not pass PBIT. Run WRA2 diagnostics to isolate. Interface test to WRA3 cannot be validated, WRA3 did not pass PBIT. Run WRA3 diagnostics to isolate.”
In another example, the CALL_PROC is set to WRA2/WRA3. WRA11202 fails PBIT and WRA21204 and WRA31206 pass PBIT. In this case, the interface test from WRA11202 may be a don't care since the validity of the interface cannot be validated due to WRA11202 failing PBIT because WRA11202 is the source of the signal.
In an eleventh exemplary state, WRA11202 Fails PBIT. The IETM may display a message that reads, for example, “Interface test to WRA1 cannot be validated, WRA1 did not pass PBIT. Run WRA1 diagnostics to isolate.”
In step 1310, the PBIT results and interface test results for WRA 1, WRA 2 and WRA 3 are evaluated. If the interface test and PBIT tests all pass, then control continues to step 1312, where a message is displayed to the operator that the WRA 1 interface to WRA 2 and WRA 3 passed interface test and PBIT tests. Control then continues to step 1314.
In step 1314, if the PBIT tests passed, but the interface form WRA 1 to WRA 2 fails, the control continues to step 1328, otherwise, control continues to step 1316.
In step 1316, if the PBIT tests pass, but the interface from WRA 1 to WRA 3 fails, control continues to step 1336, otherwise control continues to step 1318 shown in
In step 1318, if the PBIT tests passed, but the interface from WRA1 to WRA2 and WRA3 fails, control continues to step 1344, otherwise, control continues to step 1320.
In step 1320, if WRA 1 and WRA 2 pass PBIT, but WRA 3 fails PBIT and the interface from WRA 1 to WRA 2 passes, control continues to step 1346, otherwise, control continues to step 1322.
In step 1322, if WRA 1 and WRA 2 pass PBIT, but WRA 3 fails PBIT and the interface form WRA 1 to WRA 2 fails, then control continues to step 1350, otherwise, control continues to step 1324.
In step 1324, if WRA 1 and WRA 3 pass PBIT, but WRA 2 fails PBIT and the interface from WRA 1 to WRA 3 passes, control continues to step 1354, otherwise, control continues to step 1325, where the control sequence continues to the flowchart shown in
In step 1328, the CALL_PROC variable is evaluated. If CALL_PROC is equal to WRA 1 or WRA 2, control continues to step 1330, otherwise, control continues to step 1332. In step 1330, the fault group for the interface from WRA 1 to WRA 2 and for WRA 2 is displayed. Since the interface to WRA 3 passed, the fault may be isolated to the interface between the splice (where the interface in
In step 1332, the DISPLAY_MSG variable is evaluated. If DISPLAY_MSG is greater than or equal to two, then a message is displayed to the operator, such as, for example, “WRA 1 interface to WRA 3 passed. Interface to WRA 2 failed. Probable cause is interface wiring between the splice and WRA 2. Run WRA 2 diagnostics to isolate.” Control continues to step 1316.
In step 1336, the CALL_PROC variable is evaluated. If CALL_PROC is equal to WRA 1 or WRA 3, control continues to step 1338. Otherwise, control continues to step 1340. In step 1338, a fault group is displayed comprising the interface from WRA 1 to WRA 3 and WRA 3. Since the interface to WRA 2 passed, the fault may be isolated to the interface between the splice and WRA 3 or to WRA 3 itself. Control ends for this test sequence.
In step 1340, the DISPLAY_MSG variable is evaluated. If DISPLAY_MSG is greater than or equal to two, then control continues to step 1342. Otherwise, control continues to step 1318 (shown in
In step 1342, a message is displayed to the operator, such as, for example, “WRA 1 interface to WRA 2passed. Interface to WRA 3 failed. Probable cause is interface wiring between the splice and WRA 3. Run WRA 3 diagnostics to isolate.”Control continues to step 1318 (shown in
The A sheet connector designates a connection onto the A designator of
In step 1344, a fault group is displayed containing the interface from WRA 1 to WRA 2 and WRA 3, WRA 1, WRA 2 and WRA 3. Control then ends for this test sequence.
In step 1346, the DISPLAY_MSG variable is evaluated. If DISPLAY_MSG is greater than or equal to two, then control continues to step 1348. Otherwise, control continues to step 1322.
In step 1348, a message is displayed to the operator, such as, for example, “WRA 1 interface to WRA 2 passed. Interface test to WRA 3 cannot be validated. WRA 3 did not pass critical BIT checks. Run WRA 3 to isolate.” Control continues to step 1322
In step 1350, the DISPLAY_MSG variable is evaluated. If DISPLAY_MSG is greater than or equal to two, then control continues to step 1352. Otherwise, control continues to step 1324.
In step 1352, a message is displayed to the operator, such as, for example, “WRA 1 interface to WRA 2 failed. Interface test to WRA 3 cannot be validated, WRA 3 did not pass critical BIT checks. Run WRA 3 diagnostics to isolate.” Control continues to step 1324.
In step 1354, the DISPLAY_MSG variable is evaluated. If DISPLAY_MSG is greater than or equal to two, control continues to step 1356. Otherwise, control continues to step 1325 where the control sequence continues to the flowchart shown in
In step 1356, a message is displayed to the operator, such as, for example, “WRA 1 interface to WRA 3 passed. Interface test to WRA 2 cannot be validated, WRA 2 did not pass critical BIT checks. Run WRA 2 diagnostics to isolate.” Control continues to step 1325, where the control sequence continues to the flowchart shown in
In
In step 1360, if WRA 1 passes PBIT, but WRA 2 and WRA 3 fail PBIT and the interface form WRA 1 to WRA 3 fails, then control continues to step 1370, otherwise, control continues to step 1362.
In step 1362, if WRA 2 and WRA 3 pass PBIT, but WRA 1 fails PBIT, control continues to step 1374, otherwise, control continues to step 1364, where the control sequence ends.
In step 1366, the DISPLAY_MSG variable is evaluated. If DSIPLAY_MSG is greater than or equal to two, then control continues to step 1368. Otherwise, control continues to step 1360.
In step 1368, a message is displayed to the operator, such as, for example, “WRA1 interface to WRA3 FAILED. Interface test to WRA2 cannot be validated, WRA2 did not pass critical BIT checks. Run WRA2 diagnostics to isolate.” Control continues to step 1360.
In step 1370, the DISPLAY_MSG variable is evaluated. If DISPLAY_MSG is greater than or equal to two, then control continues to step 1372. Otherwise, control continues to step 1362.
In step 1372, a message is displayed to the operator, such as, for example, “Interface test to WRA2 cannot be validated, WRA2 did not pass critical BIT checks. Run WRA2 diagnostics to isolate. Interface test to WRA3 cannot be validated, WRA3 did not pass critical BIT checks. Run WRA3 diagnostics to isolate.” Control continues to step 1362.
In step 1374, the DISPLAY_MSG variable is evaluated. If DISPLAY_MSG is greater than or equal to two, control continues to step 1376. Otherwise, control continues to step 1364 where the control sequence ends.
In step 1376, a message is displayed to the operator, such as, for example, “Interface test to WRA1 cannot be validated, WRA1 did not pass critical BIT checks. Run WRA1 diagnostics to isolate.” Control continues to step 1364, where the control sequence ends.
Although the enhanced diagnostic fault detection and isolation systems and methods of the present invention have been described and illustrated in conjunction with the troubleshooting of a military aircraft, the enhanced diagnostic fault detection and isolation systems and methods can be configured to troubleshoot any system having a number of interconnected components, such as the complex systems created by the aerospace, automotive, marine, electronics, power generation and computer industries. As such, the foregoing description of the utilization of the enhanced diagnostic fault detection and isolation systems and methods in the military aircraft industry was for purposes of illustration and example and not of limitation since the diagnostic procedure described above is equally applicable in many different industries.
According to the present invention, a system for enhanced diagnostic fault detection and isolation can be implemented on a general-purpose computer, a special-purpose computer, a programmed microprocessor or microcontroller and peripheral integrated circuit element, an ASIC or other integrated circuit, a digital signal processor, a hardwired electronic or logic circuit such as a discrete element circuit, a programmed logic device such as a PLD, PLA, FPGA, PAL, neural network, artificial intelligence device, or the like. In general, any process capable of implementing the functions described herein can be used to implement a system for fault detection and isolation according to this invention.
Furthermore, the disclosed system may be implemented in software using object or object-oriented software development environments that may provide portable source code that can be used on a variety of computer platforms. Alternatively, the disclosed system for enhanced diagnostic fault detection and isolation may be implemented partially or fully in hardware using standard logic circuits or a VLSI design. Other hardware or software can be used to implement the systems in accordance with this invention depending on the speed and/or efficiency requirements of the systems, the particular function, and/or a particular software or hardware system, microprocessor, or microcomputer system being utilized. The enhanced diagnostic fault detection and isolation system illustrated herein can readily be implemented in hardware and/or software using any known or later developed systems or structures, devices and/or software by those of ordinary skill in the applicable art from the functional description provided herein and with a general basic knowledge of the computer and electrical arts.
Moreover, the disclosed methods may be readily implemented in software executed on programmed general-purpose computer, a special purpose computer, a microprocessor, or the like. In these instances, the systems and methods of this invention can be implemented as a program embedded on a personal computer such as JAVA®, XML or CGI script, as a resource residing on a server or graphics workstation, as a routine embedded in a dedicated encoding/decoding system, as an artificial intelligence program, neural network program, or the like. The system can also be implemented by physically incorporating the system and method into a software and/or hardware system, such as the hardware and software systems of an integrated electronic technical manual.
It is, therefore, apparent that there is provided in accordance with the present invention, systems and methods for enhanced diagnostic fault detection and isolation. While this invention has been described in conjunction with a number of embodiments, it is evident that many alternatives, modifications and variations would be or are apparent to those of ordinary skill in the applicable arts. Accordingly, applicants intend to embrace all such alternatives, modifications, equivalents and variations that are within the spirit and scope of this invention.
This application claims the benefit of U.S. Provisional Application No. 60/543,618, filed Feb. 12, 2004, which is incorporated herein by reference.
Number | Name | Date | Kind |
---|---|---|---|
4371952 | Schuck | Feb 1983 | A |
4412281 | Works | Oct 1983 | A |
4570261 | Maher | Feb 1986 | A |
4634110 | Julich et al. | Jan 1987 | A |
4943919 | Aslin et al. | Jul 1990 | A |
5157667 | Carusone, Jr. et al. | Oct 1992 | A |
5223788 | Andreano et al. | Jun 1993 | A |
5293323 | Doskocil et al. | Mar 1994 | A |
5357519 | Martin et al. | Oct 1994 | A |
5408218 | Svedberg et al. | Apr 1995 | A |
5455921 | DeFilipps et al. | Oct 1995 | A |
5479610 | Roll-Mecak et al. | Dec 1995 | A |
5600791 | Carlson et al. | Feb 1997 | A |
5649094 | Hayashi et al. | Jul 1997 | A |
5712972 | Kakkar | Jan 1998 | A |
5748883 | Carlson et al. | May 1998 | A |
5805793 | Green | Sep 1998 | A |
5931877 | Smith et al. | Aug 1999 | A |
5937366 | Zbytniewski et al. | Aug 1999 | A |
5978841 | Berger | Nov 1999 | A |
6003808 | Nguyen et al. | Dec 1999 | A |
6122575 | Schmidt et al. | Sep 2000 | A |
6125312 | Nguyen et al. | Sep 2000 | A |
6219626 | Steinmetz et al. | Apr 2001 | B1 |
6226675 | Meltzer et al. | May 2001 | B1 |
6240407 | Chang et al. | May 2001 | B1 |
6240526 | Petivan et al. | May 2001 | B1 |
6317659 | Lindsley et al. | Nov 2001 | B1 |
6341358 | Bagg et al. | Jan 2002 | B1 |
6421656 | Cheng et al. | Jul 2002 | B1 |
6463440 | Hind et al. | Oct 2002 | B1 |
6476828 | Burkett et al. | Nov 2002 | B1 |
6480974 | Porterfield | Nov 2002 | B1 |
6487479 | Nelson | Nov 2002 | B1 |
6510434 | Anderson et al. | Jan 2003 | B1 |
6529620 | Thompson | Mar 2003 | B2 |
6539337 | Provan et al. | Mar 2003 | B1 |
6556986 | Hara et al. | Apr 2003 | B2 |
6567079 | Smailagic et al. | May 2003 | B1 |
6572376 | Saunders | Jun 2003 | B1 |
6574537 | Kipersztok et al. | Jun 2003 | B2 |
6625618 | Arai | Sep 2003 | B1 |
6654905 | Dickens | Nov 2003 | B1 |
6662089 | Felke et al. | Dec 2003 | B2 |
6665811 | de Azevedo et al. | Dec 2003 | B1 |
6675324 | Marisetty et al. | Jan 2004 | B2 |
6697718 | Le Draoullec et al. | Feb 2004 | B2 |
6701457 | Reynolds et al. | Mar 2004 | B2 |
6721727 | Chau et al. | Apr 2004 | B2 |
6725137 | Eagleton et al. | Apr 2004 | B2 |
6732109 | Lindberg et al. | May 2004 | B2 |
6738929 | Swoboda et al. | May 2004 | B2 |
6772369 | Smith et al. | Aug 2004 | B2 |
6782380 | Thede | Aug 2004 | B1 |
6804677 | Shadmon et al. | Oct 2004 | B2 |
6829527 | Felke | Dec 2004 | B2 |
6959235 | Abdel-Malek et al. | Oct 2005 | B1 |
6961897 | Peel et al. | Nov 2005 | B1 |
6973596 | Halphide et al. | Dec 2005 | B2 |
7174286 | Martin et al. | Feb 2007 | B2 |
20020004804 | Muenzel | Jan 2002 | A1 |
20020065822 | Itani | May 2002 | A1 |
20020085020 | Carroll, Jr. | Jul 2002 | A1 |
20020087236 | Moccio | Jul 2002 | A1 |
20020116371 | Dodds et al. | Aug 2002 | A1 |
20020143803 | Chen et al. | Oct 2002 | A1 |
20020147726 | Yehia et al. | Oct 2002 | A1 |
20020147748 | Huang et al. | Oct 2002 | A1 |
20020165872 | Meltzer et al. | Nov 2002 | A1 |
20020174387 | Lohoff et al. | Nov 2002 | A1 |
20020184111 | Swanson | Dec 2002 | A1 |
20020196281 | Audleman et al. | Dec 2002 | A1 |
20020198639 | Ellis et al. | Dec 2002 | A1 |
20030004998 | Datta | Jan 2003 | A1 |
20030009710 | Grant | Jan 2003 | A1 |
20030018661 | Darugar | Jan 2003 | A1 |
20030025732 | Prichard | Feb 2003 | A1 |
20030028858 | Hines | Feb 2003 | A1 |
20030037238 | Warner et al. | Feb 2003 | A1 |
20030055945 | Bear et al. | Mar 2003 | A1 |
20030074636 | Manepalli | Apr 2003 | A1 |
20030083794 | Halm et al. | May 2003 | A1 |
20030109973 | Hensey et al. | Jun 2003 | A1 |
20030110192 | Valente et al. | Jun 2003 | A1 |
20030120686 | Kim et al. | Jun 2003 | A1 |
20030126129 | Watson | Jul 2003 | A1 |
20030126136 | Omoigui | Jul 2003 | A1 |
20030135825 | Gertner et al. | Jul 2003 | A1 |
20030146937 | Lee | Aug 2003 | A1 |
20030149934 | Worden | Aug 2003 | A1 |
20030184585 | Lin et al. | Oct 2003 | A1 |
20030187751 | Watson et al. | Oct 2003 | A1 |
20030191564 | Haugse et al. | Oct 2003 | A1 |
20030200533 | Roberts et al. | Oct 2003 | A1 |
20030204332 | Beney et al. | Oct 2003 | A1 |
20030204481 | Lau | Oct 2003 | A1 |
20030204511 | Brundage et al. | Oct 2003 | A1 |
20030212664 | Breining et al. | Nov 2003 | A1 |
20030215128 | Thompson | Nov 2003 | A1 |
20030237046 | Parker et al. | Dec 2003 | A1 |
20040020994 | Muehl et al. | Feb 2004 | A1 |
20040024501 | Muehl et al. | Feb 2004 | A1 |
20040034456 | Felke et al. | Feb 2004 | A1 |
20040039499 | Felke et al. | Feb 2004 | A1 |
20040060007 | Gottlob et al. | Mar 2004 | A1 |
20040078123 | Igloi et al. | Apr 2004 | A1 |
20040098311 | Nair et al. | May 2004 | A1 |
20040128617 | Oh | Jul 2004 | A1 |
20040143599 | Shalabi et al. | Jul 2004 | A1 |
20040153448 | Cheng et al. | Aug 2004 | A1 |
20040172597 | Canali et al. | Sep 2004 | A1 |
20040177321 | Brown et al. | Sep 2004 | A1 |
20040183831 | Ritchy et al. | Sep 2004 | A1 |
20040193962 | Johnson et al. | Sep 2004 | A1 |
20040205082 | Fontoura et al. | Oct 2004 | A1 |
20040205571 | Adler et al. | Oct 2004 | A1 |
20040205609 | Milton et al. | Oct 2004 | A1 |
20040216003 | Floyd et al. | Oct 2004 | A1 |
20040221260 | Martin et al. | Nov 2004 | A1 |
20040267813 | Rivers-Moore et al. | Dec 2004 | A1 |
20040268306 | Cheng et al. | Dec 2004 | A1 |
20050004892 | Brundage et al. | Jan 2005 | A1 |
20050021548 | Bohannon et al. | Jan 2005 | A1 |
20050027480 | Qiao et al. | Feb 2005 | A1 |
20050055336 | Hui et al. | Mar 2005 | A1 |
20050060317 | Lott et al. | Mar 2005 | A1 |
20050114090 | Black et al. | May 2005 | A1 |
20050132282 | Panditharadhya et al. | Jun 2005 | A1 |
20050138544 | Beck et al. | Jun 2005 | A1 |
20050165724 | West | Jul 2005 | A1 |
20050182650 | Maddox et al. | Aug 2005 | A1 |
20050183007 | Gaug et al. | Aug 2005 | A1 |
20050193275 | Gohel | Sep 2005 | A1 |
20050223288 | Berbaum | Oct 2005 | A1 |
20050240289 | Hoyte et al. | Oct 2005 | A1 |
20050240555 | Wilde | Oct 2005 | A1 |
20050283694 | Shabib et al. | Dec 2005 | A1 |
20060085465 | Nori et al. | Apr 2006 | A1 |
20060085692 | Berbaum | Apr 2006 | A1 |
20060120181 | Berbaum | Jun 2006 | A1 |
20060218512 | Arslan et al. | Sep 2006 | A1 |
20060236224 | Kuznetsov et al. | Oct 2006 | A1 |
Number | Date | Country |
---|---|---|
2003002298 | Jan 2003 | JP |
Number | Date | Country | |
---|---|---|---|
20050223290 A1 | Oct 2005 | US |
Number | Date | Country | |
---|---|---|---|
60543618 | Feb 2004 | US |