## KHARKOV NATIONAL UNIVERSITY OF RADIOELECTRONICS # Proceedings of IEEE East-West Design & Test Symposium (EWDTS'2011) Copyright © 2011 by the Institute of Electrical and Electronics Engineers, Inc. Technically Co-Sponsored by Sevastopol, Ukraine, September 9 – 12, 2011 # IEEE EAST-WEST DESIGN AND TEST SYMPOSIUM 2011 ORGANISING COMMITTEE ### **General Chairs** V. Hahanov – Ukraine Y. Zorian - USA #### **General Vice-Chairs** R. Ubar – Estonia E. Pashkov – Ukraine P. Prinetto - Italy ## **Program Chairs** S. Shoukourian - Armenia D. Speranskiy – Russia ## **Program Vice-Chairs** M. Renovell – France Z. Navabi – Iran ## **Steering Committee** M. Bondarenko – Ukraine V. Hahanov - Ukraine R. Ubar - Estonia Y. Zorian - USA ## **Publicity Chairs** G. Markosyan - Armenia S. Mosin - Russia ## **Public Relation Chair** V. Djigan - Russia ## **Program Committee** E. J. Aas - Norway J. Abraham - USA M. Adamski - Poland A . Barkalov – Poland R. Bazylevych - Ukraine A. Chaterjee - USA V. Djigan – Russia A. Drozd - Ukraine E. Evdokimov - Ukraine E. Gramatova - Slovakia A. Ivanov – Canada M. Karavay - Russia V. Kharchenko – Ukraine K. Kuchukjan - Armenia W. Kuzmicz - Poland A. Matrosova - Russia V. Melikyan – Armenia L. Miklea – Romania O. Novak - Czech Republic Z. Peng – Sweden A. Petrenko - Ukraine D. Puzankov - Russia J. Raik - Estonia A. Romankevich - Ukraine A. Ryjov – Russia R. Seinauskas - Lithuania S. Sharshunov - Russia A. Singh - USA J. Skobtsov - Ukraine V. Tverdokhlebov -- Russia V. Vardanian – Armenia V. Yarmolik - Byelorussia ## **Organizing Committee** Yu. Gimpilevich – Ukraine S. Chumachenko – Ukraine E. Litvinova – Ukraine ## **EWDTS 2011 CONTACT INFORMATION** Prof. Vladimir Hahanov Design Automation Department Kharkov National University of Radio Electronics, 14 Lenin ave, Kharkov, 61166, Ukraine. Tel.: +380 (57)-702-13-26 E-mail: hahanov@kture.kharkov.ua Web: www.ewdtest.com/conf/ ## 9th IEEE EAST-WEST DESIGN & TEST SYMPOSIUM (EWDTS 2011) Sevastopol, Ukraine, September 9-12, 2011 The main target of the IEEE East-West Design & Test Symposium (EWDTS) is to exchange experiences in the field of design, design automation and test of electronic circuits and systems, between the technologists and scientists from Eastern and Western Europe, as well as North America and other parts of the world. The symposium aims at attracting attendees especially from the Newly Independent States (NIS) and countries around the Black Sea and Central Asia. We cordially invite you to participate and submit your contribution(s) to EWDTS'11 which covers (but is not limited to) the following topics: - · Analog, Mixed-Signal and RF Test - Analysis and Optimization - ATPG and High-Level TPG - Built-In Self Test - Debug and Diagnosis - Defect/Fault Tolerance and Reliability - Design for Testability - Design Verification and Validation - EDA Tools for Design and Test - Embedded Software Performance - Failure Analysis, Defect and Fault - FPGA Test - HDL in test and test languages - High-level Synthesis - High-Performance Networks and Systems on a Chip - Low-power Design - Memory and Processor Test - Modeling & Fault Simulation - Network-on-Chip Design & Test - Modeling and Synthesis of Embedded Systems - Object-Oriented System Specification and Design - On-Line Test - Power Issues in Testing - Real Time Embedded Systems - Reliability of Digital Systems - Scan-Based Techniques - Self-Repair and Reconfigurable Architectures - Signal and Information Processing in Radio and Communication Engineering - System Level Modeling, Simulation & Test Generation - Using UML for Embedded System Specification #### **CAD Session**: - CAD and EDA Tools, Methods and Algorithms - Design and Process Engineering - Logic, Schematic and System Synthesis - Place and Route - Thermal, Timing and Electrostatic Analysis of SoCs and Systems on Board - Wireless Systems Synthesis - Digital Satellite Television The EWDTS'2011 will take place in Sevastopol, Ukraine. Sevastopol is a port city, located on the Black Sea coast of the Crimea peninsula. The city, formerly the home of the Soviet Black Sea Fleet, is now home to a Ukrainian naval base and facilities leased by the Russian Navy and used as the headquarters of both the Ukrainian Naval Forces and Russia's Black Sea Fleet. The symposium is organized by Kharkov National University of Radio Electronics in cooperation with Sevastopol National Technical University and Tallinn University of Technology. It is technically cosponsored by the IEEE Computer Society Test Technology Technical Council (TTTC) and financially supported by Virage Logic, Synopsys, Aldec, Kaspersky Lab, DataArt Lab, Tallinn Technical University, Cadence. ## CONTENTS | Taavi Viilukas, Maksim Jenihhin, Jaan Raik, Raimund Ubar, Samary Baranov | . 13 | |----------------------------------------------------------------------------------------------------------------------------------------------------------------------|------| | About Dependability in Cyber-Physical Systems Liviu Miclea, Teodora Sanislav | . 17 | | Self-healing Capabilities through Wireless Reconfiguration of FPGAs George Dan Moiş, Mihai Hulea, Silviu Folea and Liviu Miclea | . 22 | | Software Testing of a Simple Network Jack H. Arabian | . 28 | | A New Core to Monitor RTOS Activity in Embedded Systems Dhiego Silva, Letícia Bolzani, Fabian Vargas | . 32 | | A unifying formalism to support automated synthesis of SBSTs for embedded caches Stefano Di Carlo, Giulio Gambardella, Marco Indaco, Daniele Rolfo, Paolo Prinetto | . 39 | | Simulation-Based Hardware Verification with Time-Abstract Models Alexander Kamkin | . 43 | | Programmable Current Biasing for Low Noise Voltage Controlled Oscillators Vazgen Melikyan, Armen Durgaryan | . 47 | | Adaptive Signal Processing in Multi-Beam Arrays Victor I. Djigan | . 51 | | Optimization of Microprogram Control Unit with Code Sharing A. Barkalov, L.Titarenko, L.Smolinski | . 55 | | Synthesis of control unit with refined state encoding for CPLD devices A.Barkalov, L.Titarenko, S.Chmielewski | . 60 | | Cybercomputer for Information Space Analysis<br>Vladimir Hahanov, Wajeb Gharibi, Dong Won Park, Eugenia Litvinova | . 66 | | Verification and Diagnosis of SoC HDL-code Vladimir Hahanov, Dong Won Park, Olesya Guz, Sergey Galagan, Aleksey Priymak | | | Diagnosis Infrastructure of Software-Hardware Systems Tiecoura Yves, Vladimir Hahanov, Omar Alnahhal, Mikhail Maksimov, Dmitry Shcherbin, Dmitry Yudin | . 84 | | Overview of the Prototyping Technologies for Actel® RTAX-S FPGAs Olga Melnikova | . 90 | | Hardware Reduction for Matrix Circuit of Control Moore Automaton A. Barkalov, L.Titarenko, O. Hebda | . 94 | | RoCoCo: Row and Column Compression for High-Performance Multiplication on FPGAs Fatih Ugurdag, Okan Keskin, Cihan Tunc, Fatih Temizkan, Gurbey Fici, Soner Dedeoglu | . 98 | | Test Architecture Design for TSV based 3D Stacked ICs using Hard SOCs Surajit K. Roy, Chandan Giri, Arnab Chakraborty, Subhro Mukherjee, Debesh K. Das and Hafizur Rahaman | . 102 | |-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------| | Efficient selective compaction and un-compaction of inconsequential logical design units in the schematic representation of a design Tarun Kumar Goyal, Amarpal Singh, Rahul Aggarwal | . 106 | | Quasioptimal Algorithm of Carrier Recovery in Coherent Receiver of M-ary Alphabets APK-Signals without Traditional PLL Victor V. Panteleev | . 112 | | Quasioptimal Algorithm of Timing Recovery in Autocorrelation Receiver of Phase Shift Keying Signal Vitaliy A. Balashov, Victor V. Panteleev, Leonid M. Lyakhovetskyy | | | Design of Microprogrammed Controllers with Address Converter implemented on Programmable Systems with Embedded Memories Remigiusz Wiśniewski, Monika Wiśniewska, Marek Węgrzyn, Norian Marranghello | . 123 | | Reduction of the Memory Size in the Microprogrammed Controllers Monika Wiśniewska, Remigiusz Wiśniewski, Marek Węgrzyn, Norian Marranghello | . 127 | | Maintaining Uniformity in the Processes of Encryption and Decryption with a Variable Number of Encryption Rounds L. Smolinski | . 131 | | C++TESK-SystemVerilog United Approach to Simulation-Based Verification of Hardware Designs Mikhail Chupilko | . 136 | | Advanced Scan Chain Configuration Method for Broadcast Decompressor Architecture Jiří Jeníček and Ondřej Novák, Martin Chloupek | . 140 | | A Programmable BIST with Macro and Micro codes for Embedded SRAMs P. Manikandan, Bjørn B Larsen, Einar J Aas, Mohammad Areef | . 144 | | Modified Protocol for Data Transmission in Ad-Hoc Networks with High Speed Objects Using Directional Antennas Victor Barinov, Alexey Smirnov, Danila Migalin | . 150 | | High Performance Audio Processing SoC Platform Denis Muratov, Vladimir Boykov, Yuri Iskiv, Igor Smirnov, Sergey Berdyshev, Valeriy Vertegel, Yuri Gimpilevich, Gilad Keren | | | Methodology of the Pre-silicon Verification of the Processor Core Sergii Berdyshev, Vladimir Boykov, Yuri Gimpilevich, Yuri Iskiv, Gilad Keren, Denis Muratov, Igor Smirnov, Valeriy Vertegel | . 158 | | Spam Diagnosis Infrastructure for Individual Cyberspace Vladimir Hahanov, Aleksandr Mischenko, Svetlana Chumachenko, Anna Hahanova, Alexey Priymak | 161 | | A Security Model of Individual Cyberspace Alexander Adamov, Vladimir Hahanov | . 169 | | Organization of Pipeline Operations in Mapping Unit of the Dataflow Parallel Computing System Levchenko N.N., Okunev A.S, Yakhontov D.E | 173 | |--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----| | A Subsystem for Automated Synthesis of LFSR-Based Test Generator for Deterministic and Pseudorandom Testing Sergey G. Mosin, Natalia V. Chebykina, Maria S. Serina | 177 | | Debugging and testing features of the dataflow parallel computing system components and devices | ,, | | Levchenko N.N., Okunev A.S., Yakhontov D.E., Zmejev D.N. | 180 | | Adaptive Wavelet Codec for Noisy Image Compression Yuri S. Bekhtin | 184 | | TCAD-SPICE simulation of MOSFET switch delay time for different CMOS technologies K. O. Petrosyants, E. V. Orekhov, D. A. Popov, I. A. Kharitonov, L. M. Sambursky, A. P. Yatmanov, A. V. Voevodin, A. N. Mansurov | 188 | | Design Fault Injection-Based Technique and Tool for FPGA Projects Verification L. Reva , V. Kulanov, V. Kharchenko | 191 | | Optimal Schematic Design of Low-Q IP Blocks Sergey G. Krutchinsky, Mikhail S. Tsybin | 196 | | Parallelizing of Boolean function system for device simulation Alexander Chemeris, Svetlana Reznikova | 200 | | Optimization Some Characteristics of Continuous Phase Spread Spectrum Signal Michael Balanov, Olga Mamedova | 203 | | Development Methodology of Interoperable Add-on Tool for Static Verification of Current Density E. Babayan | 207 | | Design Consideration of CMOS Low Cut-Off Low Pass Filter for ECG Applications Andranik Hovhannisyan | 210 | | Method of Capacitor Calibration for Switched Capacitor Circuits Norayr K. Aslanyan | 214 | | Built-in Measurement Technique for On-Chip Capacitors<br>Andranik S Hovhannisyan, Norayr K Aslanyan, Vahram K Aharonyan, Hayk H Dingchyan | 217 | | A Generation of Canonical Forms for Design of IIR Digital Filters<br>Vladislav A. Lesnikov, Alexander V. Chastikov, Tatiana V. Naumovich, Sergey V. Armishev | 221 | | Variant of Wireless MIMO Channel Security Estimation Model Based on Cluster Approach O. Kuznietsov, O. Tsopa | 225 | | Compact DSM MOSFET Model and its Parameters Extraction Anatoly Belous, Vladislav Nelayev, Sergey Shvedov, Viktor Stempitsky, Tran Tuan Trung, Arkady Turtsevich | 230 | | IGBT Technology Design and Device Optimization Artem Artamonov, Vladislav Nelayev, Ibrahim Shelibak, Arkady Turtsevich | 233 | | Device-Process Simulation of Discrete Silicon Stabilitron with the Stabilizing Voltage of 6,5 V <b>Dudar N.L., Borzdov V.M.</b> | . 237 | |-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------| | Geometrical Approach to Technical Diagnosing of Automatons Tverdokhlebov V.A. | . 240 | | Loop Fusion and Power Consumption of PCs Dmytro Lazorenko | . 244 | | On Experimental Research of Efficiency of Tests Construction for Combinational Circuits by the Focused Search Method Vasily Kulikov, Vladimir Mokhor | . 247 | | Test Set Compaction Procedure for Combinational Circuits Based On Decomposition Tree Valentina Andreeva | . 251 | | Implementation by the Special Formula of an Arbitrary Subset of Code Words of $(m, n)$ -code for Designing a Self-Testing Checker N. Butorina, S. Ostanin | . 255 | | Optimal Fluctuations for Satisfactory Performance under Parameter Uncertainty HJ Kadim | . 259 | | The Evidential Independent Verification of Software of Information and Control Systems, Critical to Safety: Functional Model of Scenario Konorev Borys, Sergiyenko Volodymyr, Chertkov Georgiy | . 263 | | Si BJT and SiGe HBT Performance Modeling after Neutron Radiation Exposure Konstantin Petrosyants, Eric Vologdin, Dmitry Smirnov, Rostislav Torgovnikov, Maxim Kozhukhov | . 267 | | Compact Power BJT and MOSFET Models Parameter Extraction with Account for Thermal Effects I. A. Kharitonov | . 271 | | Thermal Analysis of the Ball Grid Array Packages K.O. Petrosyants, N.I. Rjabov | . 275 | | On Synthesis of Degradation Aware Circuits at Higher Level of Abstraction Mohammad Abdul Razzaq, Alok Baluni, Virendra Singh, Ram Rakesh Jangiry and Masahiro Fujitaz | . 279 | | Selection of the State Variables for Partial Enhanced Scan Techniques A. Matrosova, A. Melnikov, R. Mukhamedov, V. Singh | . 285 | | Efficient Regular Expression Pattern Matching using Cascaded Automata Architecture for Network Intrusion Detection Systems Pawan Kumar and Virendra Singh | . 290 | | Dispersion Analysis in Processes of Passive Monitoring and Diagnosing of Enterprise Area Networks Anna V. Babich, Murad Ali A | . 295 | | A Diagnostic Model for Detecting Functional Violation in HDL-Code of System-on-Chip Ngene Christopher Umerah, Vladimir Hahanov | . 299 | | Krivoulya G., Shkil A., Kucherenko D3 | 303 | |--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----| | A Model of Spatial Thinking for Computational Intelligence Kirill A. Sorudeykin | 311 | | New Methods and Tools for Design of Tests Memory Mudar Almadi, Diaa Moamar, Vladimir Ryabtsev3 | 319 | | Scalability of "Ideal" System Networks Based on Quasy-Complete Graph Architecture Mikhail F. Karavay and Victor S. Podlazov3 | 326 | | The Test Method for Identification of Radiofrequency Wireless Communication Channels Using Volterra<br>Model<br>Vitaliy D. Pavlenko, Viktor O. Speranskyy, Vladimir I. Lomovoy | | | A Calculation of Parasitic Signal Components Digital Filtration for the Retransmission Meter on the basi<br>of FPGA<br>Velichko D.A., Vdovychenko I.I | | | The Testware CAD Victor Zviagin3 | 337 | | The Synthesis of Periodic Sequences with Given Correlation Properties V. M. Koshevyy, D. O. Dolzhenko | 341 | | Lyapunov Function Analysis for Different Strategies of Circuit Optimization A. Zemliak, A. Michua, T. Markina | 345 | | State Identification of Bilinear Digital System Dmitriy Speranskiy | 349 | | Model order reduction of Micro-Electro-Mechanical Systems Petrenko Anatoly | 355 | | Modeling a Logical Network of Relations of Semantic Items in Superphrasal Unities Nina Khairova, Natalia Sharonova | 360 | | Resistance Dependent Delay Behavior of Resistive Open Faultsin Multi Voltage Designs Environment Mohamed Tag Elsir Mohammadat, Noohul Basheer Zain Ali, Fawnizu Azmadi Hussin | 366 | | Designing ISA Card with Easy Interface Taghi Mohamadi | 372 | | Real Time Operating System for AVR Microcontrollers Taghi Mohamadi | 376 | | Recognition of Automatons by their Geometrical Images Epifanov A.S | 381 | | Problems of Cause-Effect Link's Definition in Man-Machine Systems' Accidents | 385 | | OFDM-based Audio Watermarking for Covered Data Transmission in VHF Radiotelephony Oleksandr V. Shishkin, Oleksandr O. Lyashko | 389 | |--------------------------------------------------------------------------------------------------------------------------------------------------------|-----| | Validation&Verification of an EDA Automated Synthesis Tool Giulio Gambardella, Marco Indaco, Paolo Prinetto, Daniele Rolfo | 393 | | Infrastructure for Testing and Diagnosing Multimedia Device Vladimir Hahanov, Karyna Mostova, Oleksandr Paschenko | 394 | | Architecture for an Intelligent Test Error Detection Agent Matthias Kirmse, Uwe Petersohn, Elief Paffrath | 400 | | Cadence EDA Flow for IC's and Electronics Anatoli Ivanov | 405 | | Designing an Embedded System for Interfacing with Networks Based on ARM Taghi Mohamadi | 407 | | Checkability of the Digital Components in Safety-Critical Systems: Problems and Solutions A. Drozd, V. Kharchenko, S. Antoshchuk, J. Sulima, M. Drozd | 411 | | AUTHORS INDEX | 416 | ## Verification and Diagnosis of SoC HDL-code Vladimir Hahanov<sup>1</sup>, Dong Won Park<sup>2</sup>, Olesya Guz<sup>3</sup>, Sergey Galagan, Aleksey Priymak<sup>1</sup> Computer Engineering Faculty, Kharkov National University of Radioelectronics, Kharkov, Ukraine, hahanov@kture.kharkov.ua <sup>2</sup> Pai Chai University, the Republic of Korea dwpark@pcu.ac.kr <sup>3</sup>Road Transport Faculty, Donetsk Institute of Road Transport, Donetsk, Ukraine kiu@kture.kharkov.ua ## **Abstract** Xor-metrix for object relations in a vector logic space and a structural testing model are proposed. Assertionbased models and methods for the verification and diagnosis of HDL-code functional failures, which make possible to reduce considerably time-to-market of software and hardware, are developed. An architectural model of multimatrix reduced logical instruction set processor for embedded diagnosing is offered. ## 1. Introduction Recent trends in creating new communications, computing and information services, useful to the human, are development of dedicated gadgets, which have important advantages over PCs and laptops: power consumption, compactness, weight, cost, functionality, and friendliness of interface. Practically the top ten dedicated products 2010 (Apple iPad, Samsung Galaxy S, Apple MacBook Air, Logitech Revue, Google Nexus One (HTC Desire), Apple iPhone 4, Apple TV, Toshiba Libretto W100, Microsoft Kinect, Nook Color) is realized as digital systems-on-chips. By 2012 the mobile and wireless communication market will move to 20 nm (results of the January 2011 Technology Forum of Common Platform Alliance). Further development of the technologies by year: 2014 - 14 nm, 2016 - 11nm. In 2015 more than 55% of mobile phones will be smartphones, tablet PCs will replace laptops and netbooks. Superfones (Nexus-1, Google) will unite all devices and services. The transition from the computing platform to mobile devices with small size results in considerable reduction in power consumption worldwide. The next computerization wave, entitled "Internet of things", is being accelerated. It will lead to widespread sensor networks, including their integration into the human body. The world market of the above devices and gadgets today involves about 3 billion products. For their effective designing, manufacturing and exploitation the new technologies and Infrastructures IP are created. One of the possible steps in this direction is represented below in the form of verification technology TV: Mt is metrics and model for testing, H<sup>c</sup> is HDL-code of a design, G<sup>t</sup> is synthesis of software transaction graph, {M<sup>f</sup>, M<sup>s</sup>} determine creating two verification models for HDL-code (functional failure table and software activation matrix), {D<sup>c</sup>, D<sup>r</sup>, D<sup>m</sup>} determine developing three methods for diagnosing the functional failures (for analyzing rows, columns and whole matrix), which use the assertion engine (assertion is a logical statement for detecting the semantic errors in software), Pm is architecture of multimatrix processor for parallel analyzing tabular data, R is implementation of models, methods and tools in the system Riviera, Aldec Inc.: $$T^{v} = M^{t} \to H^{c} \to G^{t} \to \begin{bmatrix} M^{f} \to \begin{bmatrix} D^{c} \\ D^{r} \end{bmatrix} \to P^{m} \to R.$$ $$\begin{bmatrix} M^{s} \to D^{m} \end{bmatrix} \to D^{m} \to R.$$ The objective of the research is to reduce time-to-market and improve the quality of digital systems-on-chips by developing the assertion-based infrastructure, models and methods for verification and diagnosis HDL-code. The information, needed for detecting failures at the functional blocks, is formed during simulation (execution) of software code. Design effectiveness for digital product is determined as the average and normalized in the range [0,1] integral criterion: $$E = F(L, T, H) = \min[\frac{1}{3}(L + T + H)], Y = (1 - P)^{n};$$ $$L = 1 - Y^{(1-k)} = 1 - (1 - P)^{n(1-k)};$$ $$T = [(1 - k) \times H^{s}]/(H^{s} + H^{a}); H = H^{a}/(H^{s} + H^{a}).$$ (1) The criterion takes into account the following: the error level L, the verification time T, software-hardware redundancy, determined by the assertion engine and Infrastructure IP tools H. The parameter L, as a complement of the parameter Y (yield), depends on the testability k of a design, the probability P of existence of faulty components, and the quantity of undetected errors n. The time of verification is determined by the testability of a design k [3,4], multiplied by the structural complexity of hardware-software functionality, divided by the total complexity of a design in code lines. The software-hardware redundancy depends on the complexity of assertion code and other costs, divided by the total design complexity. At that software or hardware redundancy has to provide the specified diagnosis depth for functional errors and time-tomarket, defined by customer. The problems are: 1) Creation of a metrics and structural-analytical model for testing digital systems-on-chips. 2) Improvement of the models and methods for detecting functional failures, based on assertion engine, to increase the speed of HDL-code verification and diagnosis. 3) Development of the architectural model of multimatrix processor for diagnosing. References are: 1. Models of the problems for technical diagnosis are presented in [1-6]. 2. Diagnosis and verification of digital systems-on-chips are described in [9-17, 22-15]. 3. Hardware and matrix processors for increasing the speed of testing are proposed in [18-21]. ## 2. A model for testing and verification The effective process models and methods for diagnosing the functional failures in software and/or hardware are offered. The register or matrix (tabular) data structures, focused to parallel execution of logic operations, are used for detecting the faulty components. The problem of synthesis or analysis of system components can be formulated in the form of interaction (symmetrical difference is an analog of xor-operation on the Boolean) of its model F, input stimuli T and responses L in a cybernetic space: $$f(F, T, L) = \emptyset \rightarrow F\Delta T\Delta L = \emptyset$$ . (2) A cyberspace is a set of information processes and occurrences, which use computer systems and networks as a carrier. Particularly, a space component is represented by k-dimensional (tuple) vector $\mathbf{a}=(a_1,a_2,...,a_j,...,a_k),\ a_j=\{0,1\}$ in a binary alphabet. Zero-vector is k-dimensional tuple, all coordinates of which are equal to zero: $\mathbf{a}_j=0,\ j=\overline{1,k}$ . The procedures of test synthesis, fault simulation and detection can be reduced to xor-relations on a full interaction graph (Fig. 1) for four nodes (functionality, unit, test, faults) $G = \{F, U, T, L\}$ . Fig. 1. Graph of interaction between technical diagnosis components The graph creates four basic triangles, which form 12 triads of relations for the problems of technical diagnosis: | $T \oplus F \oplus L = 0$ | $T \oplus L \oplus U = 0$ | $T \oplus F \oplus U = 0$ | $F \oplus L \oplus U = 0$ | |---------------------------|---------------------------|---------------------------|---------------------------| | 1) T = F ⊕ L | 4) T = L ⊕ U | 7) T = F ⊕ U | 10) F = L ⊕ U | | 2) F = T ⊕ L | 5) L = T ⊕ U | 8) F = T ⊕ U | 11) L = F ⊕ U | | 3) L = T ⊕ F | 6) $U = T \oplus L$ | 9) $U = T \oplus F$ | 12) U = F⊕ L | Insertion of the node U in the graph of interaction between technical diagnosis components extends the functionality of the model; new properties of the resulting system appear. Introduction the new node in the structure has to have strong arguments of its advisability. Concerning the graph, represented in Fig. 1, all problems can be classified into groups as follows. Group 1 involves the theoretical experiments (on the functionality model), without the device: 1) test synthesis by using the functionality model for a specified fault list; 2) development of the functionality model, based on a given test and fault list; 3) fault simulation for functionality by using given test. Group 2 – real experiments (by device) without functionality model: 4) test synthesis by physical fault simulation in the device; 5) fault list generation for the device by means of diagnostic experiment; 6) test and faults verification by means of the experiment on a real device. Group 3 – test experiments (verification) without faults: 7) test synthesis by means of comparing the model simulation results and real device; 8) functional- ity synthesis by using a real device and a given test; 9) verification of test and functionality model by using the real device with existing faults. Group 4 – experiments during operation with real inputs: 10) check of correct behavior of a real device on the existing or specified faults; 11) test the device on the existing model in the operation; 12) verification of the functionality and fault list relative to the behavior of a real device. The most popular problems of the above list are: 1, 3, 5, 8, 9. Another classification of the problem types can be introduced. It allows defining by the graph G = (F, U, T, L) all the conceptual solutions of target problems: test synthesis, functionality model definition, fault model generation and designing of a device: ``` 1) T=F⊕L; 4) F=T⊕L; 7) L=T⊕F; 10) U=T⊕L; 2) T=U⊕L; 5) F=U⊕L; 8) L=T⊕U; 11) U=T⊕F; 3) T=F⊕U; 6) F=T⊕U; 9) L=F⊕U; 12) U=F⊕L. ``` All constructions, used in a relationship, have the remarkable property of reversibility. Component, calculated using the other two, can be used as an argument to determine any of the two original ones. Thereby, transitive reversibility of each relation triad on complete graph is occur, when by using any two components it is always possible to restore or to determine the third one. At that the format for each component must be identical in structure and dimension (vectors, matrices). Fault diagnosis methods, based on the proposed metrics and testing models, are considered in more detail below. # 3. Model for detecting functional failures in software The space equation $$f(F, T, L, U) = 0 \rightarrow F \oplus T \oplus L \oplus U = 0$$ is used. It is transformed to the form $L = (T \oplus F) \oplus (T \oplus U)$ . Fault (functional failures) diagnosis is reduced to comparison of simulation $(T \oplus F)$ and full-scale $(T \oplus U)$ results, which generates a functional failure list L, detected in the diagnosed unit. Model-formula for searching the functionally faulty block $F_i$ is reduced to solving by determining xorinteraction between three components: $$L = F_i \leftarrow [(T \oplus F_i) \mathop{\oplus}_{i=1}^p (T \oplus U_i)] = 0.$$ An analytic model for verification of HDL-code by using temporal assertion engine (additional observation lines) is focused to achievement the specified diagnosis depth and presented as follows: $$\begin{array}{ll} M\!=\!f(F\!,A\!,B\!,S\!,T\!,L), & F\!=\!(A\!^*B)\!\times\!S\!; \, S\!=\!f(T\!,B); \\ A\!=\!\{A_1\!,A_2\!,...,\!A_i\!,...,\!A_n\}; & B\!=\!\{B_1\!,B_2\!,...,\!B_i\!,...,\!B_n\}; \\ S\!=\!\{S_1\!,S_2\!,...,\!S_i\!,...,\!S_m\}; & S_i\!=\!\{S_1\!,S_{i2}\!,...,\!S_{ij}\!,...,\!S_{ip}\}; \end{array} \tag{3}$$ Here $F = (A * B) \times S$ is functionality, represented by Code-Flow Transaction Graph – CFTG (Fig. 2); $S = \{S_1, S_2, ..., S_i, ..., S_m\}$ are nodes or states of software when simulating test segments. Otherwise the graph can be considered as ABC-graph – Assertion Based Coverage Graph. Each state $S_i = \{S_{i1}, S_{i2}, ..., S_{ij}, ..., S_{ip}\}$ is determined by the values of design essential variables (Boolean, register variables, memory). The oriented graph arcs are represented by a set of software blocks $$B = (B_1, B_2, ..., B_i, ..., B_n), \bigcup_{\substack{i=1\\i=1}}^n B_i = B; \bigcap_{\substack{i=1\\i=1}}^n B_i = \emptyset,$$ where the assertion $A_i \in A = \{A_1, A_2, ..., A_i, ..., A_n\}$ can be put in correspondence to each of them. Each arc $B_i$ – a sequence of code statements – determines the state of the node $S_i = f(T, B_i)$ depending on the test $T = \{T_1, T_2, ..., T_i, ..., T_k\}$ . The assertion monitor, uniting the assertions of node incoming arcs $A(S_i) = A_{i1} \vee A_{i2} \vee ... \vee A_{ij} \vee ... \vee A_{in}$ can be put in correspondence to each node. A node can have more than one incoming (outcoming) arc. A set of functionally faulty blocks is represented by the list $L = \{L_1, L_2, ..., L_i, ..., L_n\}$ . $\begin{array}{l} B = (B_1B_3B_9 \vee (B_2B_7 \vee B_1B_5)B_{11})B_{13} \vee \\ \vee ((B_1B_4 \vee B_2B_6)B_{10} \vee B_2B_8B_{12})B_{14} = \\ = B_1B_3B_9B_{13} \vee B_2B_7B_{11}B_{13} \vee B_1B_5B_{11}B_{13} \vee \\ \vee B_1B_4B_{10}B_{14} \vee B_2B_6B_{10}B_{14} \vee B_2B_8B_{12}B_{14}. \end{array}$ Fig. 2. Example of ABC-graph for HDL-code The model for HDL-code, represented in the form of ABC-graph, describes not only software structure, but test slices of the functional coverage, generated by using software blocks, incoming to the given node. The last one defines the relation between achieved on the test variable space and potential one, which forms the functional coverage as the power of state i-th graph node $Q = cardC_i^T/cardC_i^p$ . In the aggregate all nodes have to be full coverage of the state space of software variables, which determines the test quality, equal to 1 (100%): $$Q = card \bigcup_{i=1}^m C_i^r / card \bigcup_{i=1}^m C_i^p = 1$$ . Furthermore, the assertion engine $< A, C>$ that exists in the graph allows monitoring arcs (code-coverage) $A = \{A_1, A_2, ..., A_i, ...., A_n\}$ and nodes (functional coverage) $C = \{C_1, C_2, ...., C_i, ...., C_m\}$ . The assertions on arcs are designed for diagnosis of the functional failures in software blocks. The assertions on graph nodes carry information about the quality of test (assertion) for their improvement or complement. The Code-Flow Transaction Graph makes possible the following: 1) use the testability design to estimate the software quality; 2) estimate the costs for creating tests, diagnosing and correcting the functional failures; 3) optimize test synthesis by means of solving the coverage problem by the minimum set of activated paths of all arcs (nodes). For instance, the minimum test for the above mentioned ABC-graph has six segments, which activate all existent paths: $$\begin{split} T &= S_0 S_1 S_3 S_7 S_9 \vee S_0 S_1 S_4 S_8 S_9 \vee S_0 S_1 S_5 S_7 S_9 \vee \\ &\vee S_0 S_2 S_4 S_8 S_9 \vee S_0 S_2 S_5 S_7 S_9 \vee S_0 S_2 S_6 S_8 S_9. \end{split}$$ Tests can be associated with the following program block activization matrix: | B <sub>ij</sub> | $B_1$ | В2 | Вз | B <sub>4</sub> | B <sub>5</sub> | В6 | В7 | В8 | В9 | $B_{10}$ | B <sub>11</sub> | B <sub>12</sub> | B <sub>13</sub> | B <sub>14</sub> | |-----------------|-------|----|----|----------------|----------------|----|----|----|----|----------|-----------------|-----------------|-----------------|-----------------| | T <sub>1</sub> | 1 | | 1 | | | | | | 1 | - | | | 1 | | | T <sub>2</sub> | 1 | | | 1 | | | | | | 1 | | | | 1 | | T3 | 1 | | | | 1 | | | | | | 1 | | 1 | | | T <sub>4</sub> | | 1 | | | | 1 | | | | 1 | | | | 1 | | T <sub>5</sub> | | 1 | | | | | 1 | | | - | 1 | | 1 | | | T <sub>6</sub> | | 1 | | | | | | 1 | | | | 1 | | 1 | The activization matrix shows the fact of indistinguishability of the functional failures on a test in the blocks 3 and 9, 8 and 12, which constitute two equivalence classes if there is one assertion (monitor) in the node 9. To resolve this indistinguishability it is necessary to create two additional monitors in the nodes 3 and 6. As a result, three assertions in the nodes $A = (A_3, A_6, A_9)$ allow distinguishing all the blocks of software code. Thus, the graph enables not only to synthesize the optimal test, but also to determine the minimum number of assertion monitors in the nodes to search faulty blocks with a given diagnosis depth. Increasing the number of assertion monitors leads to modification of an activization table. Otherwise, on a given test and the assertion engine it is necessary to solve uniquely the diagnosis problem for functional failures of the software code with the depth up to a software module. At that the number of assertions and test segments to be minimum acceptable for the code identification of all the blocks: $|T| + |A| \ge \log_2 |B| = \operatorname{card} T + \operatorname{card} A \ge \log_2 \operatorname{card} B$ . Initially, the number of monitors-assertions is equal to the number of test segments. The activization table for software modules makes it possible to identify code blocks with functional failures by the generalized outresponse vector (assertion monitoring) $V = (V_1, V_2, ..., V_i, ..., V_n), V_i = \{0,1\}, V_i = T_i \oplus B_j, \forall j (B_{ij} = 1) \ .$ The vector coordinate $V_i = T_i \oplus B_j = 1$ identifies the nonpassage of the test segment on a subset of activated modules. In accordance with the vector V, defined on the activization table subject to the above rule for calculating its coordinates: | B <sub>ij</sub> | B <sub>l</sub> | В2 | В3 | В4 | B <sub>5</sub> | В6 | B <sub>7</sub> | В8 | В9 | $B_{10}$ | B <sub>11</sub> | $B_{12}$ | B <sub>13</sub> | B <sub>14</sub> | V | |-----------------|----------------|----|----|----|----------------|----|----------------|----|----|----------|-----------------|----------|-----------------|-----------------|---| | Tı | 1 | | 1 | | | | | | 1 | | | | 1 | | 0 | | T <sub>2</sub> | 1 | | | 1 | | | | | | 1 | | | | 1 | 1 | | T <sub>3</sub> | 1 | | | | 1 | | | | | | 1 | | 1 | | 0 | | T <sub>4</sub> | | 1 | | | | 1 | | | | 1 | | | | 1 | 1 | | T <sub>5</sub> | | 1 | | | | | 1 | | | | 1 | | 1 | | 0 | | T <sub>6</sub> | | 1 | | | | | | 1 | | | | 1 | | 1 | 1 | a logical function of software functional failures can be constructed, which is simplified using the coordinates of the output response vector V: $$\begin{split} B = & (\overline{T}_1 \vee B_1 \vee B_3 \vee B_9 \vee B_{13}) \wedge (\overline{T}_2 \vee B_1 \vee B_4 \vee B_{10} \vee B_{14}) \wedge \\ & \wedge (\overline{T}_3 \vee B_1 \vee B_5 \vee B_{11} \vee B_{13}) \wedge (\overline{T}_4 \vee B_2 \vee B_6 \vee B_{10} \vee B_{14}) \wedge \\ & \wedge (\overline{T}_5 \vee B_2 \vee B_7 \vee B_{11} \vee B_{13}) \wedge (\overline{T}_6 \vee B_2 \vee B_8 \vee B_{12} \vee B_{14}); \\ \{V, T\} = & (010101) \rightarrow \\ B = & (0 \vee B_1 \vee B_4 \vee B_{10} \vee B_{14}) \wedge (0 \vee B_2 \vee B_6 \vee B_{10} \vee B_{14}) \wedge \\ & \wedge (0 \vee B_2 \vee B_8 \vee B_{12} \vee B_{14}) = (B_1 \vee B_4 \vee B_{10} \vee B_{14}) \wedge \\ & \wedge (B_2 \vee B_6 \vee B_{10} \vee B_{14}) \wedge (B_2 \vee B_8 \vee B_{12} \vee B_{14}) = \\ & = & B_1 B_2 \vee B_4 B_2 \vee ... \vee B_3 B_6 B_{12} \vee ... \vee B_1 A. \end{split}$$ After transformation the conjunctive normal form (CNF) to disjunctive normal form the obtained terms include all possible solutions in the form of unit coordinate coverage for the output response vector by single or multiple software functional failures. Choosing the best solution is made by determining DNF term of the minimum length. In this example, the optimal solution is a term containing a single block $B=B_{14}$ , which covers three units in the output response vector $V=\left(010101\right)$ . This fact is also evident from comparison of the last two columns of the activation matrix B. ## 4. A method for vector logic analyzing columns Methods for detecting the functional failures (FF) in the statement blocks use previously generated functional failure table $B = [B_{ii}]$ , where a row is relation between a test segment and subset of activated (on this segment) software blocks $T_i \approx (B_{i1}, B_{i2}, ..., B_{ij}, ..., B_{in})$ . A column forms the relation between software block and test segments $B_{j}\approx (T_{1j},T_{2j},...,T_{ij},...,T_{pj})\,,$ which activate it. Otherwise, a column is an assertion vector, detecting the functional failure in corresponding block. On simulation stage the response $m = (m_1, m_2, ..., m_i, ..., m_p)$ of the assertion engine on a test is identified by means of generating $m_i = (A_1 \vee A_2 \vee ... \vee A_i \vee ... \vee A_k), A_i = \{0,1\}$ response of assertions on the test segment T<sub>i</sub> . Searching FF's is based on the definition of xor-operation between the vector of assertion states and columns of functional failure $\textbf{m} \oplus (\textbf{B}_1 \vee \textbf{B}_2 \vee ... \vee \textbf{B}_j \vee ... \vee \textbf{B}_n)$ . The solution is determined by the vector B<sub>i</sub> with minimum quantity of 1 coordinates, which determine the functionally faulty software blocks, checked by the test segments. Diagnosis by the functional failure table on the basis of the response $m = (m_1, m_2, ..., m_i, ..., m_n), m_i = \{0,1\}$ is reduced to the methods for vector logic analyzing columns or rows. The first one is based on use vector xor-operation between m-response of the functionality on the test, formally considered as an input vector-column, and columns of the fault detection table $m \oplus (B_1 \vee B_2 \vee ... \vee B_j \vee ... \vee B_m)$ . To determine the interaction quality of vectors $Q_j(m \oplus B_j)$ and to choose the best solution the columns with minimal quantity of 1's for resultant vector are identified. They forms the functionally faulty blocks, checked by test patterns. The analytic model for solving the diagnosis problem and obtaining the list of functionally faulty software blocks is represented in the following form: $$L = L \bigvee_{j=1}^{n} B_{j} \leftarrow \sum_{i=1}^{k} (B_{ij} \bigoplus_{i=1}^{k} m_{i}) = (0 \vee \min).$$ (4) Here an output response vector is input one for subsequent analyzing of the functional failure table $$m = f(A, B) \oplus f^*(A, B, L)$$ (5) And it is a result of test experiment – comparison of the functional (output states) for model under test f(A,B) and unit under test $f^*(A,B,L)$ with the faults L on the test patterns A. In second case if a set of faults L > 1, it means existence of equivalent functional failures on given test and assertion engine. A process model for searching the best solution with minimum quantity of 1 coordinates from 2 or more alternatives is shown in Fig. 3. It involves the following operations: 1) Initially, in all coordinates (the worst solution) of the vector Q, where the best solution is stored, 1 values are entered; and simultaneously left slc operation with compaction of 1's is performed for given vector $Q_i$ . 2) Comparing of two vectors is performed: Q and the next estimation $Q_i$ from the solution list. 3) Vector operation And $(Q \wedge Q_i)$ is performed. The result is compared with vector Q, which allows changing it, if the vector $Q_i$ has less quantity of 1 values. 4) The procedure for searching the best solution is repeated by n times. Fig. 3. Process-decision model An advantage of the method for vector logic analyzing columns is the choice of the best solution from all possible single and multiple faults. Actually, such single functional failures are included in the fault list, which when logical multiplying them by output response vector give a result in the form of vector-column. Disjunction of all columns, generating a solu- tion, is equal to the output response vector $\begin{tabular}{l} r\\ \lor (B_j \in B) = m \ .\\ j = 1 \end{tabular}$ An example for analyzing the functional failure table FFT of the module Row\_buffer (Fig. 4) is represented below. Fig. 4. Row\_buffer transaction graph and table On the basis of the diagnosis procedure (4) and tables FFT (see Fig. 3) the faulty components can be determined by analysis of FFT columns. Here the vectors $m_1$ , $m_2$ define the diagnosis results, performed by the procedure (5). The diagnosis result for single and multiple functional failures is following: $$\begin{split} L^{S}(m_{1}) &= m_{1} \wedge (\bigvee_{j=1}^{10} B_{j}) = B_{9} \rightarrow D_{2}; \\ L^{m}(m_{2}) &= m_{2} \wedge (\bigvee_{j=1}^{10} B_{j}) = B_{1} \vee B_{2} \rightarrow L_{1} \vee L_{2}; \\ Q(m_{1}, D_{2}) &= 1; \ Q[m_{2}, (L_{1} \vee L_{2})] = 0,52. \end{split}$$ In the first case, the diagnosis is defined as a single faulty module $D_2$ that present in the transactional graph; the solution quality is equal to 1. In the second case, the diagnosis procedure detects two faulty modules $L_1 \vee L_2$ , the quality estimation of which is not the optimal. Nevertheless, the solution is the best among all the possible, which is maximally approximate to the output response vector by the membership criterion $Q[m_2,(L_1\vee L_2)]$ . The computational complexity of the method for analyzing columns is determined by the following dependence: $Z^c = 3n^2 + n^2 = 4n^2$ ; $Z^r = 3n + n = 4n$ . Here, the first estimate takes into account the implementation of coordinate operations on the matrix of the dimension $n\times n$ . The second estimate determines the computational complexity of the register parallel operations to compute quality criteria and process the matrix, respectively. ## 5. Method for vector logic analysis of rows The method is designed for determination of fault or functional failure (FF) location in software code and consists of two procedures: 1) determining the logical product of the conjunction of lines, marked by unit values of the vector $T_i(m_i=1)$ , by the negation of disjunction of zero rows $T_i(m_i=0)$ for single faulty modules; 2) determining the logical product of disjunction of unit lines by the negation of the disjunction of zero rows for multiple faulty modules: $$L^{S} = (\bigwedge_{\forall m_{i}=1} T_{i}) \land (\overline{\bigvee_{\forall m_{i}=0} T_{i}});$$ $$L^{m} = (\bigvee_{\forall m_{i}=1} T_{i}) \land (\overline{\bigvee_{\forall m_{i}=0} T_{i}});$$ (6) The formulas are interesting, because they are not related to the diagnosis quality criteria and operate only two components: FFT table and output response vector. Performing the diagnosis procedure by the formufor the output response vector $m_1 = (0101010010010)$ , specified in the last table FFT, forms the result: $L^{s}(m_1,T) = D_2$ , which is not worse than previously obtained by the method for analyzing columns. For the output response vector $m_2 = (1110011100000)$ the diagnosis result is: $L^{m}(m_{2},T) = L_{1} \vee L_{2}$ . Computational complexity of the method for analyzing rows is determined by the following dependence: $Z^c = n^2$ ; $Z^r = n$ . The first estimate is designed to count the number of coordinate operations, the second one determines the computational complexity of processing, based on the register parallel operations. The proposed methods for diagnosing functional failures in software and hardware are the most important components of the Infrastructure IP. Formulae (6) can be modified if the following designations are introduced: $$\begin{split} a &= (\bigwedge_{\forall m_1 = 1} T_i); \ b = (\bigvee_{\forall m_1 = 0} T_i); \ c = (\bigvee_{\forall m_1 = 1} T_i); \\ L^S &= a\overline{b} = a \oplus ab = a(a \oplus b) = a(b \oplus l); \\ L^m &= c\overline{b} = c \oplus cb = c(c \oplus b) = c(b \oplus l); \\ L &= \begin{cases} a\overline{b} = a\overline{b} = a \oplus ab = a(a \oplus b) = a(b \oplus l); \\ c\overline{b} = c\overline{b} = c \oplus cb = c(c \oplus b) = c(b \oplus l) \leftarrow a\overline{b} = 0; \end{cases} \end{split}$$ Any right side expression of the equations can be used to detect functional failure in the software or hardware. The difference lies in the presence or absence of inversion, which is replaced by xor-operation, more preferable for diagnosis and pattern recognition. In this case, the process model for diagnosing single (using acomponent) or multiple (b-component) faults (functional failures) based on analyzing the table FFT has an effective vector-oriented computing technology: $$L = (b \oplus 1)(a \vee c)$$ , embedded Infrastructure IP of software/hardware. According to set theory, this means determining the result of set-theory subtraction $L = (a \lor c) \lor b = (a \lor b) \lor (c \lor b) \quad \text{in the algebra-logic}$ vector space. For such operations the multimatrix processor is needed, which is strictly focused on the parallel execution of several logic operations on data matrices. # 6. Matrix method for detecting the functional failures in software Further to the software transaction graph (3) a method for diagnosing functional failures in software uses the triad of matrices of the same format: $$\begin{split} \mathbf{M} &= \mathbf{B} \oplus \mathbf{A} \oplus \mathbf{L} = \mathbf{0}, \ \mathbf{L} = \mathbf{B} \oplus \mathbf{A} \leftarrow \mathbf{L}_{ij} = \\ &= \mathbf{B}_{ij} \oplus \mathbf{A}_{ij} \leftarrow \{\mathbf{B}_{ij}, \mathbf{A}_{ij}, \mathbf{L}_{ij}\} = \{0, 1\}; \\ \mathbf{B} &= [\mathbf{B}_{ij}], \ \mathbf{A} = [\mathbf{A}_{ij}], \ \mathbf{L} = [\mathbf{L}_{ij}], \ i = \overline{1, n}; \\ \mathbf{j} &= \overline{1, m}; \ \oplus = \mathbf{a} \overline{\mathbf{b}} \vee \overline{\mathbf{a}} \mathbf{b}. \end{split}$$ Here matrices form: B - block activization on test segments during simulation; A - activity of assertions, corresponding to blocks, on test segments and during simulation; L - faulty blocks, obtained as result of xor- operation on two above matrices. Coordinate-wise analyzing the matrices uses binary xor-operation, such as: | 1 | | | | | | | | | | 1 | | |---|-----------------|----------------|----------------|-------|----------------|----------------|----------------|----------------|-----|--------|---| | | B <sub>ij</sub> | B <sub>1</sub> | B <sub>2</sub> | $B_3$ | $B_4$ | B <sub>5</sub> | В6 | В7 | В8 | | | | | T <sub>1</sub> | 1 | | | 1 | | | 1 | | 1 | | | | $T_2$ | | 1 | 1 | | 1 | | | | | | | | T <sub>3</sub> | | | | | | 1 | 1 | 1 | | | | | $T_4$ | 1 | | 1 | | | 1 | | | 0 | | | | T <sub>5</sub> | | 1 | | 1 | | | | 1 | | | | | T <sub>6</sub> | 1 | | | | | | 1 | 1 | | | | | T <sub>7</sub> | | 1 | | | 1 | 1 | | | | | | | T <sub>8</sub> | | | 1 | 1 | 1 | | | | | | | | Aij | A <sub>1</sub> | A 2 | A 3 | A <sub>4</sub> | A 5 | A <sub>6</sub> | A 7 | 7 A | 8 | | | | $T_1$ | 1 | | | 1 | | ٠. | 1 | ١. | $\neg$ | | | | T <sub>2</sub> | | 1 | 1 | ١. | 1 | ١. | | | | | | | Τ3 | | | | | ١. | 1 | 1 | 1 | | | | ∌ | T <sub>4</sub> | 1 | | 1 | ١. | ١. | 1 | | | | = | | | T <sub>5</sub> | | 1 | | 1 | ١. | ١. | | 1 | | | | | T <sub>6</sub> | 1 | | | ١. | | ١. | 1 | 1 | . | | | | T <sub>7</sub> | | 1 | | ١. | 1 | 1 | | . | | | | | T <sub>8</sub> | | | 1 | 1 | 1 | | | | | | | | Lij | $B_1$ | B <sub>2</sub> | В3 | $B_4$ | B <sub>5</sub> | В6 | B <sub>7</sub> | В8 | ] | | | | T <sub>1</sub> | | | | | | | | | 1 | | | | T <sub>2</sub> | | | | | | | | | | | | | T <sub>3</sub> | | | | | | | | | | | | = | T <sub>4</sub> | | | | | | | | | | | | | T5 | | | | | | | | | | | | | T <sub>6</sub> | - | | | | | | | | | | | | T <sub>7</sub> | - | | | | | | | | | | | | T <sub>8</sub> | | | | | | | | | | | | | | | | | | | | | | | | Obtained result $L = B \oplus A$ in the form of L-matrix $[L_{ij}] = (T \times B \times \{0,1\})$ , all coordinated of which are equal to zero, indicates absence functional failures in software relatively the proposed verification plan in the format (test – functional blocks – activization $[B_{ij}] = (T \times B \times \{0,1\})$ , test – assertions – response $[A_{ij}] = (T \times A \times \{0,1\})$ . Another model experiment indicates presence the functional failures $L = \{B_1, B_2, B_3, B_5, B_6\}$ in software code: | | B <sub>ij</sub> | В1 | B <sub>2</sub> | Вз | В | 34 | В | 5 | В | 6 | В | 7 | В | 8 | | | |----------|---------------------------------|----------------|----------------|----------------|----------|---------|----|-----|---|----|---|-------|---|----|----------|---| | | T <sub>1</sub> | 1 | | | Т | 1 | | . | - | | 1 | | | | | | | | T <sub>2</sub> | | 1 | 1 | | | 1 | l | | | | . . | | . | | | | | Τ <sub>3</sub> | | | | | | | . | 1 | | 1 | . | | 1 | | | | | T <sub>4</sub> | 1 | | 1 | | | | - | 1 | | | . | | . | $\oplus$ | | | | T <sub>5</sub> | | 1 | | | 1 | | | | | | . | | 1 | _ | | | | T <sub>6</sub> | 1 | | - | | | | . | | | 1 | . | | 1 | | | | | T <sub>7</sub> | - | 1 | | | - | 1 | | 1 | | | . | | . | | | | | T <sub>8</sub> | | | 1 | L | 1 | _1 | l | _ | | _ | | | | | | | | | | <u> </u> | | <u> </u> | $\perp$ | | | | | | | | | | | | | A ij | A | A <sub>2</sub> | 2 A | 3 | Α4 | ŀ | A | 5 | A | 6 | Α | | A | 8 | | | | T <sub>1</sub> | 1 | - | . | | 1 | | | | | | - 1 | l | | | | | | T <sub>2</sub> | - | 0 | | ) | | 0 | | | 1: | | 1 | | | | | | | T <sub>3</sub> | | | | | | | | | 1 | | ] | l | | 1 | | | $\oplus$ | T <sub>4</sub> | 0 | 1: | | ) | : | | | | ( | ) | | | | | = | | | T <sub>5</sub> | | 1 | - | | 1 | | | | | | | | | 1 | | | | T <sub>6</sub> | 1 | 1 | | | | | 1 | | 1 | | 1 | l | | 1 | | | | T <sub>7</sub> | - | 1 | | | 1 | | 1 | | | | | | | | | | | T <sub>8</sub> ∨ A <sub>1</sub> | 1 | 1 | + | | 1 | | | _ | 1 | | 1 | | 1 | | | | ļ | V Ai | | | | | | ᆛ | 1 P | | | | | | | | ı | | | L <sub>ij</sub> | B <sub>1</sub> | B <sub>2</sub> | B <sub>2</sub> | 1 | $B_4$ | 1 | В5 | 1 | В6 | | В7 | 4 | В8 | 4 | | | | T <sub>1</sub> | - | ; | 1 | | | | 1 | | - | | - | | - | | | | | T <sub>2</sub> | - | 1 | 1 | | | | 1 | | - | | - | | - | | | | | T <sub>3</sub> | | | ; | | | | | | 1 | | - | | - | | | | = | T <sub>4</sub> | 1 | | 1 | | | | ٠ | | I | | - | | - | | | | | T <sub>5</sub> | - | | • | | | | | | - | | - | | - | | | | | T <sub>6</sub> | - | | • | | | | | | - | | - | | - | | | | | T <sub>7</sub> | | | 1 | | • | | ٠ | | | - | | . | | | | | | T <sub>8</sub> | 1 | 1 | 1 | + | 0 | + | 1 | + | 1 | + | 0 | + | 0 | + | | | | I V Li | 1 | 1 | 1 | - | U | 1 | 1 | I | 1 | ı | U | ı | U | 1 | | Here are the results of vector operations on all rows of two tables $\vee L_i$ =11101100 and $\vee A_i$ =11011111. Logical conjunction of them with the preliminary inversion of the first vector gives the coordinates of blocks with functional failures, marked by units. In this example, the vector forms only one block (00100000)&(11101100)=(00100000). What is the reason for the reduction of faulty blocks? If to assume that in compliance with the verification plan the verification of the first block has to detect faults on first and sixth test, which is not satisfied, so block 1 can be excluded from the fault list. Similarly, modules 2, 5, 6 can be excluded. Then the corrected result will have only one block with the functional failures: $L = \{B_3\}$ . The procedure for refining the diagnosis result can also formalized in the following $L = B_j \leftarrow B_j \wedge L_j = B_j, j = 1, m$ . If the comparison result is negative $B_i \oplus L_i = 0$ , it means the code is incorrect, assertion or test failed, including functional coverage. For the diagnosis code in accordance with the process model of the form $$L(B,T) = (B \oplus A) \to L(B) = (\overline{\underset{i=1,n}{\vee} A_i}) \land (\underset{i=1,n}{\vee} L_i) \ ,$$ it is necessary to consider the following items: - 1. Coverage is any metric for choosing test and determining its confidence. Code coverage is test metric, focused on the confirmation of execution of all code lines. Decomposition of software code into blocks is performed $B = \{B^s, B^t\} \leftarrow B^s \cap B^t = \emptyset, B^s \cup B^t = B$ . Each block belongs to one of two types: the sequence of statements without a branch or time delay circuit $B_i \in \{B^S, B^t\}$ . Location of assertion monitors is carried out for block activity on test at the beginning of the branch or in the first timer cycle of a time delay circuit. In the modeling process assertions form an activization matrix for software blocks on each test segment $B_{ij} = T_i \oplus B_j \in \{0,1\}$ . If the block is active (assertion passed) on the test (testbench), matrix coordinate is equal to 1, otherwise $-B_{ii} = 0$ . Testbench is input conditions for testing the HDL-code and corresponding output responses, which define transformations of the device under test in the functional sub- - 2. Functional coverage is test metric that ensures the accessability of all essential states in the software variable and function definition space. Decomposition of software functionality in control and transaction graphs is performed: $F = \{F^c, F^t\} \leftarrow F^c \cap F^t = \emptyset, F^c \cup F^t = F$ . This makes it possible to considerably reduce the dimension of coverage problem that defines the domain for the control variable and data flow. Test generation and the subsequent coverage driven verification use the above mentioned graphs with constraints, taken from the specification. Synthesized test for the control graph allows activation of all logic and arithmetic variables involved in initiation of software transaction. Way of variable activation or test synthesis consists of pseudorandom or deterministic (algorithmic) generating test inputs, as well as hand-writing input stimuli. Forms of coverage definition are an abbreviated truth table, Boolean equation, binary decision diagrams, the flowgraph. Test for the second graph handles data flows, which at the system level not always have to be checked because of the absence of faults, such as short circuits between the variables or constant faults in them. Transaction graph can be used to create a verification plan for essential interface parameters of software. To do this it is necessary to use interface assertions operating by global variables. 2. Assertion matrix for software blocks has a form similar to the structure of block activation $A = [A_{ij}]$ . Here format of assertion as logic statement, using the essential variables of software block $f(X) = A_{ij} = \{0,1\}$ , responses for running the corresponding activated on the test module $B_{ii} = 1$ . Several statements can be in the block, separated to increase the diagnosis depth or united by function or. In last case assertion responses for correct functioning of the block. Assertion has two values: 1 - block operates fault-free, 0 - there are functional failures. Assertions are represented by two hierarchy levels: interface and block ones $A = \{A^i, A^b\}$ . The first ones are focused on testing the essential parameters of the specifications, which are common for the software and external for it. Second ones are built into software block, which don't have branches. Power of commands or code lines - up to 20 - is determined by the number of statements to be placed on the screen. Such block can contain time or event delay statements. # 7. Implementation of models and methods in the verification system Practical implementation of models and verification methods is integrated into the simulation environment Riviera of Aldec Inc., Fig. 5. New assertion and diagnosis modules, added in the system, improved the existing verification process, which allowed 15% reduction the design time of digital product. Fig. 5. Implementation of results in the system Riviera Actually, application of assertions makes possible to decrease the length of test-bench code and considerably reduce (x3) the design time (Fig. 6), which is the most expensive. Assertion engine allows increasing the diagnosis depth of functional failures in software blocks up to level 10-20 HDL-code statements. Fig. 6. Comparative analysis of verification methods Due to the interaction of simulation tools and assertion engine, automatically placed inside the HDL-code, an access of diagnosis tools to the values of all internal signals is appeared. This allows quickly identifying the location and type of the functional failure, as well as reducing the time of error detection in the evolution of product with top-down design. Application of assertion for 50 real-life designs (from 5 thousand up to 5 million gates) allowed obtaining hundreds of dedicated solutions, included in the verification template library VTL, which generalizes the most popular on the market EDA (Electronic Design Automation) temporal verification limitations for the broad class of digital products. Software implementation of the proposed system for analyzing assertions and diagnosing HDL-code is part of a multifunctional integrated environment Aldec Riviera for simulation and verification of HDL-models. High performance and technological combination of assertion analysis system and HDL-simulator of Aldec company is largely achieved through integration with the internal simulator components, including HDLlanguage compilers. Processing the results of the assertion analysis system is provided by a set of visual tools of Riviera environment to facilitate the diagnosis and removal of functional failures. The assertion analysis model can also be implemented in hardware with certain constraints on a subset of the supported language structures. Products Riviera including the components of assertion temporal verification, which allow improving the design quality for 3-5%, currently, occupies a leading position in the world IT market with the number of installations of 5,000 a year in 200 companies and universities in more than 20 countries on the world. ## 8. Verification infrastructure On the basis of multimatrix (register) processor an infrastructure for verification HDL-code (Fig. 7) is developed. It is modification of I-IP standard IEEE 1500 SECT [3, 4, 11, 14]. There are 4 process models: testing on the simulation stage, diagnosis of functional failures, diagnosis optimization, repairing. Process model for testing involves HDL-model, assertion engine, testbench and coverage. Last one estimates test quality for all design states. In simulating the activization matrix B for software blocks and assertion response matrix A on test segments are generated. Matrix A can be transformed to assertion state vector m by application of the function Or to vector-columns of A-matrix. $$\begin{cases} B = (T \oplus F); \\ m \\ m = \bigvee_{j=1}^{\infty} A_j \leftarrow A = (T \oplus A^c). \end{cases}$$ The last two components are used in the second process model for diagnosing blocks of HDL-code. Diagnosis is fault vector, which forms a subset of blocks $m_d$ with functional failures. At that the errors can be in testbench and in assertion statements, which are designed for testing and monitoring software blocks. If exact identification of the block is absent when comparing the columns of activization matrix and assertion responses, triple diagnosis uncertainty $D = \{B_i, T_i, A_{ii}\}$ arises. Fig. 7. Verification infrastructure for HDL-code The third block solves the problem of minimizing the number of blocks, in which functional failures can be, up to one of them. At that a block activization matrix and the diagnosis $m_{\mbox{\scriptsize d}}$ , obtained in the previous process model, are used. Correction of functional failures is focused on manual searching errors in a software block, presented by the vector $\mathbf{m}_b$ . Automated correcting errors in the block is possible, if there is a library of diversion software modules of the similar functionality in the verification infrastructure. The proposed infrastructure is one of steps towards the creation of verification automaton for software blocks. An example of diagnosing the functional failure, based on using the activization matrix, is represented below. The vector of assertion responses is obtained from the matrix $A_{ij} = \{1 \rightarrow \text{failed}, 0 \rightarrow \text{passed}\}$ by disjunctive union of rows content: Subsequent implementation of xor-operation between the assertion vector and activization matrix columns allows obtaining the best solution, which is determined by the minimum code distance $$L = L \vee B_j \leftarrow \sum_{i=1}^n (B_{ij} \overset{n}{\underset{i=1}{\oplus}} m_i) = (0 \vee min) :$$ | | B <sub>ij</sub> | B <sub>1</sub> | B <sub>2</sub> | В3 | В4 | B <sub>5</sub> | В6 | В7 | В8 | | T | m | | |---|-----------------|----------------|----------------|----------------|----|----------------|----------------|----|----|----------|-------|---|---| | | T <sub>1</sub> | 1 | | | 1 | | | 1 | | | $T_1$ | | | | | T <sub>2</sub> | | 1 | 1 | | 1 | | | | | $T_2$ | 1 | | | | T <sub>3</sub> | | | | | | 1 | 1 | 1 | | $T_3$ | | | | | T <sub>4</sub> | 1 | | 1 | | | 1 | | | $\oplus$ | $T_4$ | 1 | = | | | T <sub>5</sub> | | 1 | | 1 | | | | 1 | | $T_5$ | | _ | | | T <sub>6</sub> | 1 | | | | | | 1 | 1 | | $T_6$ | | | | | T <sub>7</sub> | | 1 | | | 1 | 1 | | | | $T_7$ | | | | | T <sub>8</sub> | | | 1 | 1 | 1 | | | | | $T_8$ | 1 | | | | | | | | | | | | | | | | | | | L | ij | B <sub>1</sub> | B <sub>2</sub> | В3 | В4 | B <sub>5</sub> | В6 | В7 | В | 3 | | | | | T | ì | 1 | | | 1 | | | 1 | | | | | | | T | 2 | 1 | | | 1 | | 1 | 1 | 1 | | | | | | T | | | | | | | 1 | 1 | 1 | | | | | = | T | | | 1 | | 1 | 1 | | 1 | 1 | | | | | _ | T | | | 1 | | 1 | | | | 1 | | | | | | T | 6 | 1 | | | | | | 1 | 1 | | | | | | T | | | 1 | | | 1 | 1 | | ١. | | | | | | T | 8 | 1 | 1 | | | | 1 | 1 | 1 | | | | | | d(A | $B_j$ | 4 | 4 | 0 | 4 | 2 | 4 | 6 | 6 | | | | Diagnosis is block 3 has functional failures, because three assertions are failed on the test segments 2,4 and 8, which in this combination activate only block number 3. If assertion matrix (not vector) is used for diagnosing, searching for faulty blocks is the following: | | B <sub>ij</sub> | B <sub>1</sub> | B <sub>2</sub> | В3 | В4 | B <sub>5</sub> | В6 | В7 | В8 | | |----------|-----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----|----------| | | T <sub>1</sub> | 1 | | | 1 | | | 1 | | | | | T <sub>2</sub> | . | 1 | 1 | | 1 | | | | | | | T <sub>3</sub> | . | | | | | 1 | 1 | 1 | | | | T <sub>4</sub> | 1 | | 1 | | | 1 | | | $\oplus$ | | | T <sub>5</sub> | . | 1 | | 1 | | | | 1 | ~ | | | T <sub>6</sub> | 1 | | | | | | 1 | 1 | | | | T <sub>7</sub> | . | 1 | | | 1 | 1 | | | | | | T <sub>8</sub> | | | 1 | 1 | 1 | | | | | | | | | | | | | | | | <u> </u> | | | Aij | A <sub>1</sub> | A <sub>2</sub> | A <sub>3</sub> | A <sub>4</sub> | A <sub>5</sub> | A <sub>6</sub> | A <sub>7</sub> | Ag | 3 | | <b>⊕</b> | $T_1$ | | | | | 1 | | | | | | | T <sub>2</sub> | | 1 | 1 | | 1 | | . | | | | | T <sub>3</sub> | | | | | | 1: | . | | | | | T <sub>4</sub> | 1 | | 1 | | | 1 | . | | = | | | T <sub>5</sub> | | | | | | | . | | | | | T <sub>6</sub> | - | | | | | | • | | | | | T <sub>7</sub> | | | | | | | • | | | | | T <sub>8</sub> | | | 1 | · | | | <u> </u> | | _ | | | | | | _ | | | | | | | | = | L | ij | B <sub>1</sub> | B <sub>2</sub> | В3 | B <sub>4</sub> | B <sub>5</sub> | В6 | В7 | В8 | | | T <sub>1</sub> | | 1 | | | 1 | | | 1 | . | | | T <sub>2</sub> | | | | | | | | : | : | | | T <sub>3</sub> | | | | | | | 1 | 1 | 1 | | | T <sub>4</sub> | | | | | | | | | . | | | T <sub>5</sub> | | | 1 | ٠ | 1 | | ٠ | | 1 | | | T <sub>6</sub> | | 1 | 1 | • | | 1 | 1 | 1 | 1 | | | T <sub>7</sub> | | | 1 | | | | I | | | | | T <sub>8</sub> | | 2 | 2 | 0 | 3 | 1 | 2 | 3 | 3 | | | $d(A,B_j)$ | | 2 | 2 | U | 3 | 2 | 2 | 3 | ) | Diagnosis is similar to the previous one: block 3 has functional failures, because the code distance is equal to zero only for the column number 3. ## 9. Conclusion The following results are proposed in the paper: - 1. A structural model for relations on the set of four main components of technical diagnosis (functionality, unit, test and faults), which is characterized by complete xor-interaction of all the graph nodes and transitive reversibility of each relation triad that allows defining and classifying the ways of solving practical problems, including test synthesis, fault simulation and fault detection. - 2. A new model of software in the form of Code-Flow Transaction Graph, as well as a new matrix method for diagnosing functional failures, which are characterized by adaptability of data preparation when detecting faulty blocks, are proposed. They allow considerably reducing the design time of digital systems on chips. - 3. Methods for searching functional failures, which differ in parallel execution of vector operations on the rows of a functional failure table, are improved. They allow substantially (x10) increasing the performance of computational procedures associated with diagnosis and repair of software and hardware. - 4. The architecture of multimatrix processor, focused to increasing the speed of embedded diagnosis of functional failures in the software or hardware product, which differs using parallel logic vector operations and, or, xor, slc that enables to increase considerably (x10) the speed of diagnosing single and/or multiple faults (functional failures). - 5. The infrastructure for verification and diagnosis of HDL-code for design digital systems-on-chips, which involves four process models for testing, diagnosing, optimization and correcting errors, closed in a cycle, that makes it possible to reduce the time of code debugging, when creating a design. - 6. Practical implementation of models and verification methods is integrated into the simulating environment Riviera of Aldec Inc. New assertion and diagnosis modules improved the existing verification process, which allowed 15% reduction in overall design time of digital products. ## 6. References Technical diagnosis basics / Editor P.P. Parchomenko.-M.: Energy. 1976. – 460 p. - [2] Parchomenko P.P., Sogomonyan E.S. Technical diagnosis basics (Optimization of diagnosis algorithms, hardware tools) / Editor P.P. Parchomenko.— M.: Energy.—1981.—320 p. - [3] Infrastructure for brain-like computing / M.F. Bondaryenko, O.A. Guz, V.I. Hahanov, Yu.P. Shabanov-Kushnaryenko. Kharkov: Novoye Slovo. 2010. 160 p. - [4] Design and Verification of digital systems on chips / V.I. Hahanov, I.V. Hahanova, E.I. Litvinova, O.A. Guz.– Kharkov: Novoye Slovo. – 2010. – 528 p. - [5] Semenets V.V., Hahanova I.V., Hahanov V.I. Design of digital systems by using VHDL language.— Kharkov: KHNURE.—2003.—492 p. - [6] Hahanov V.I., Hahanova I.V. VHDL+Verilog = synthesis for minutes. Kharkov: KHNURE. 2006. 264 p. - [7] Hahanov V.I. Technical diagnosis of digital and microprocessor structures: Manual.- K.: ISIO, 1995.- 242 p. - [8] Skobtsov Yu.A. Logic simulating and testing digital devices / Yu.A. Skobtsov, V.Yu. Skobtsov. –Donetsk: IPMM NSA of Ukraine, DonNTU. – 2005. – 436 p. - [9] IEEE Standard for Reduced-Pin and Enhanced-Functionality Test Access Port and Boundary-Scan Architecture IEEE Std 1149.7-2009. – 985 p. - [10] Da Silva F., McLaurin T., Waayers T. The Core Test Wrapper Handbook. Rationale and Application of IEEE Std. 1500™. –Springer. – 2006. – XXIX. – 276 p. - [11] Marinissen E.J., Yervant Zorian. Guest Editors' Introduction: The Status of IEEE Std 1500.–IEEE Design & Test of Computers.– 2009.– No26(1).– P.6-7. - [12] IEEE Std 1800-2009 IEEE Standard for System Verilog-Unified Hardware Design, Specification, and Verification Language. - http://ieeexplore.ieee.org/servlet/opac?punumber= 5354133 - [13] Marinissen E.J. Testing TSV-based three-dimensional stacked ICs // DATE 2010.– 2010.– P.1689-1694. - [14] Benso A., Di Carlo S., Prinetto P., Zorian Y. IEEE Standard 1500 Compliance Verification for Embedded Cores // IEEE Trans. VLSI Syst.—2008.— No 16(4).— P. 397-407. - [15] Ubar R., Kostin S., Raik J. Embedded diagnosis in digital systems // 26th International Conference "Microelectronics", MIEL 2008. – 2008. – P. 421-424. - [16] Elm M., Wunderlich H.-J. Scan Chain Organization for Embedded Diagnosis // Design, Automation and Test in Europe, DATE '08.– 2008.– P. 468–473. - [17] Bulent I. Dervisoglu. A Unified DFT Architecture for Use with IEEE 1149.1 and VSIA/IEEE P1500 Compliant Test Access Controllers. Proceedings of the Design Automation Conference. – 2001. – P. 53-58. - [18] Chenlong Hu, Ping Yang, Ying Xiao, Shaoxiong Zhou. Hardware design and realization of matrix converter based on DSP & CPLD // 3rd International Conference Power Electronics Systems and Applications.—2009.—P. 1-5. - [19] Dave N., Fleming K., Myron King, Pellauer M., Vijayaraghavan M. Hardware Acceleration of Matrix Multiplication on a Xilinx FPGA // 5th IEEE/ACM International Conference Formal Methods and Models for Codesign.— 2007.— P.97-100. - [20] Loucks W.M., Snelgrove M., Zaky S.G. A Vector Processor Based on One-BitMicroprocessors // IEEE Micro.-Volume 2, Issue 1.– 1982.– P. 53-62. - [21] Hilewitz Y., Lauradoux C., Lee R.B. Bit matrix multiplication in commodity processors // International Conference Application-Specific Systems, Architectures and Processors. 2008. P. 7-12. - [22] Soon, J.L.K.; Low Ching Ling; DEV. Design explorer for verification. Integrated Circuits, ISIC '09. Proceedings of the 2009 12th International Symposium: 2009, Page(s): 413 416. - [23] Rafe, V.; Rafeh, R.; Azizi, S.; Miralvand, M.R.Z.; Verification and Validation of Activity Diagrams Using - Graph Transformation. Computer Technology and Development, 2009. ICCTD '09. 2009, Page(s): 201 205. - [24] Xiaoxi Xu; Cheng-Chew Lim; Using Transfer-Resource Graph for Software-Based Verification of System-on-Chip. Computer-Aided Design of Integrated Circuits and Systems, IEEE Transactions on Volume: 27, Issue: 7. 2008, Page(s): 1315 – 1328. - [25] Zhongjun Du; Zhengjun Dang; A New Algorithm Based Graph-Search for Workflow Verification. Information Engineering and Computer Science (ICIECS), 2010 2nd International Conference: 2010, Page(s): 1–3. - [26] Gorbatov V.A., Gorbatov A.V., Gorbatova M.V. Discrete mathematics.—M: High School, 2006.—448 p. Camera-ready was prepared in Kharkov National University of Radio Electronics Lenin Ave, 14, KNURE, Kharkov, 61166, Ukraine Approved for publication: 26.08.2011. Format 60×841/8. Relative printer's sheets: 42. Circulation: 150 copies. Published by SPD FL Stepanov V.V. Ukraine, 61168, Kharkov, Ak. Pavlova st., 311 Матеріали симпозіуму «Схід-Захід Проектування та Діагностування — 2011» Макет підготовлено у Харківському національному університеті радіоелектроніки Редактори: Володимир Хаханов, Світлана Чумаченко, Євгенія Литвинова Пр. Леніна, 14, ХНУРЕ, Харків, 61166, Україна > Підписано до публікації: 26.08.2011. Формат 60×84<sup>1</sup>/<sub>8</sub>. Умов. друк. Арк. 42. Тираж: 150 прим. Видано: СПД ФЛ Степанов В.В. Вул. Ак. Павлова, 311, Харків, 61168, Україна