














Professor William H. Robinson (Co‐Chair)      Date         
Professor Robert A. Reed (Co‐Chair)        Date         
Professor Gautam Biswas          Date         
Professor Marcus H. Mendenhall        Date         
























TABLE OF CONTENTS     Page  DEDICATION...............................................................................................................................................iii ACKNOWLEDGEMENTS......................................................................................................................... iv LIST OF TABLES ........................................................................................................................................ ix LIST OF ACRONYMS............................................................................................................................. xvii CHAPTER   I  INTRODUCTION..........................................................................................................................................1   Summary of Document ....................................................................................................4  II.  BACKGROUND .............................................................................................................................................8   Basic Mechanisms ..............................................................................................................8 Previous Approaches to IC Single Event Analysis.............................................13 Soft‐Error Tolerance Analysis and Optimization of Nanometer Circuits [33] .......................................................................................................................16 Soft‐Error‐Rate‐Analysis (SERA) Methodology [34] .......................................16 SEAT‐LA: A Soft Error Analysis tool for Combinational Logic [35]...........17 Circuit Reliability Analysis Using Symbolic Techniques [36] ......................17 Modeling and Optimization for Soft‐Error Reliability of Sequential Circuits [37] ...............................................................................................................18 Summary .............................................................................................................................18  III.  OVERVIEW OF MULTI‐SCALE SIMULATION OF SINGLE EVENT TRANSIENTS...........20   Overview of the Multi‐Scale Simulation Approach...........................................20  
 IV.  CALIBRATION OF MRED TO COMPUTE SET RESPONSE .......................................................32   Charge Collection Simulation using MRED ..........................................................32 Example Geometry of the Nested Sensitive Volumes In MRED ..................40 
  vii 
 V.  MODELING OF SINGLE EVENT TRANSIENTS WITH DUAL   DOUBLE‐EXPONENTIAL CURRENT SOURCES ...........................................................................46   Background........................................................................................................................46 Limitations of Double‐Exponential Current Source.........................................50 Dual Double‐Exponential Current Source Model ..............................................52 Results and Discussion .................................................................................................60  VI.  MRED2SPICE ANALYSIS.......................................................................................................................68   Connecting MRED to SPICE for SET analysis.......................................................68 MRED2SPICE – Comparison of Experimental Data for CMOS Combinational Cells................................................................................................73  VII.  TRANSIENT FAULT ANALYSIS FOR SEQUENTIAL CAPTURE IN  DUAL‐COMPLEMENTARY FLIP‐FLOPS .......................................................................................................82   BACKGROUND ..................................................................................................................82 DUAL COMPLEMENTARY DFF (DC‐DFF)..............................................................83 SINGLE EVENT TRANSIENT CIRCUIT SIMULATION .......................................88 HEAVY ION TESTING OF DUAL‐COMPLEMENTARY DFFS............................97 CLOCK DEPENDENT MECHANISMS..................................................................... 101  VIII.  SPICE CIRCUIT ANALYSIS FOR LOGICAL AND TIMING SIMULATIONS........................ 104 SET Pulse‐Width Characterization for Radiation‐Induced Faults........... 104  IX.  IC LOGIC SIMULATION FOR SOFT ERROR PREDICTION .................................................... 117   Basic Testing Approach ............................................................................................. 117 Multi‐scale simulation for Soft Error Rate Prediction.................................. 120   X.  CONCLUSIONS ....................................................................................................................................... 133   Future Work ................................................................................................................... 136  REFERENCES ..........................................................................................................................................139 
  viii 
 Appendix  A.  MRED INPUT PYTHON SCRIPT ...................................................................................................... 146 B.  4‐INVERTER CHAIN BASIC CIRCUIT SPICE NETLIST........................................................... 150 C.  PYTHON SCRIPT FOR Ithresh, Iprompt, Ihold....................................................................................... 151 D.  PYTHON SCRIPT FOR MRED2SPICE ............................................................................................ 157 E.  MRED2LOGIC PYTHON SCRIPT ..................................................................................................... 163 F.  ALU TESTBENCH CODE..................................................................................................................... 170  
  ix 
  LIST OF TABLES 
  Table                          Page  1.   Sensitive volume definitions for MRED Python script including the   (x, y, z) coordinates in mm for the volume center and the length, width,   and depth for the volume, also in mm ................................................................................ 42  2.   Charge collection efficiencies listed for each sensitive volume in the INV cell. 44  3.   Sample outputs from the MRED Python script with charge collection calculations (charge given in fC) ........................................................................................... 45  4.   Simulation Results for INV1, NAND2, NOR2 cells for the VDD input configuration ................................................................................................................................. 61  5.   Simulation Results for INV1, NAND2, NOR2 cells for the VSS input   configuration ................................................................................................................................. 61  6.   Simulation Results for inverter cells of increasing drive strength for the   VDD input configuration............................................................................................................. 62  7.  Simulation Results for inverter cells of increasing drive strength for the   VSS input configuration.............................................................................................................. 62  8.   Simulated threshold charges (Qthresh) and hold currents (IHold) for the combinational cells for comparison to experimental data given different   test configurations ...................................................................................................................... 76  9.   Input Configurations for 2‐Input NOR gate...................................................................... 80  10.   Input controls, output signals, and transistor conditions required to change DC‐DFF memory circuit from logic state 1 to logic state 0. ....................................... 87  11.   Input control, output signal, and transistor conditions required to change 
  x 
  DC‐DFF memory circuit from logic state 1 to logic state 0. A single event to   the input circuit keeps n1 at logic state 1. ........................................................................ 93  12.   Input control, output signal and transistor conditions required to change   DC‐DFF memory circuit from logic state 1 to logic state 0. A single event to   the memory circuit keeps transistor MN13 on, thereby keeping qa closed. ..... 95  13.   Heavy ions, LETs and ion energies used to test DC‐DFFS. .......................................100  14.   Simulation results for percent susceptible to SETs for logical‐masking. ..........126  15.   SER Error cross‐section => (Errors Observed / Faults Generated) x Integral Cross‐Section for LET = 2.1 MeV‐cm2/mg ......................................................................128  16.   Methodology for SER Error cross‐section of the entire ALU design. The   table would need to be completed for all the cell types. The three cells from this dissertation are included within the table.............................................................129 
  xi 
LIST OF FIGURES   Figure                             Page  1.   Typical shape of nodal current at a junction ................................................................... 13  2.   SEU_Tool operations flow chart[9] ...................................................................................... 14  3.   Multi‐scale simulation approach black box block diagram....................................... 22  4.   MRED process basic block diagram..................................................................................... 24  5.   SPICE pre‐process basic block diagram............................................................................. 25  6.   Conversion of Vtran to Vr­r after a random number of stages of combinational library cells ..................................................................................................................................... 26  7.   SPICE process complete block diagram............................................................................. 27  8.   (a) Fault within the inner scope masked and not visible to an IC output   (b) Fault propagated outside the inner scope to the outer scope and   visible as a soft error to the output of the IC. [24]......................................................... 28  9.   Generic structure of a testbench and an IC design under verification ................. 29  10.   Multi‐scale simulation for generation, propagation and capture of an SET ...... 31  11.   TCAD‐generated spatial distribution of the collected charge as a function of strike location with 8 of 30 sensitive volumes (SV) drawn for the single   node NMOS device at 0.1 pC/mm (top down view). [11]........................................... 34  12.   Spatial distribution of the collected charge as a function of strike location   for the single node PMOS device at 0.1 pC/mm (top down view). [11]............... 34  13.   Top view of CMOS transistor that is representative of layout ................................. 36  14.   Side view of CMOS transistor from cut along the line X in Figure 13 ................... 36 
  xii 
 15.   Top view of CMOS transistor with top view of charge‐collection volumes........ 38  16.   Side view of CMOS transistor with side view of charge‐collection volumes ..... 38  17.   Top view of two CMOS transistors connected in parallel with a shared drain   in the middle .................................................................................................................................. 39  18.   Top View of two CMOS transistors connected in parallel with a shared drain   on the outside. Metal lines connecting the shared drain are not shown. ............ 40  19.   Top view of two CMOS transistors connected is series with an intermediate drain .................................................................................................................................................. 40  20.   Top view of drain area and active area for basic INV cell (PMOSFET on top   and NMOSFET on bottom)....................................................................................................... 42  21.   Ion strike on combinational library cell modeled as double exponential   current source............................................................................................................................... 47  22.   Propagation of double‐exponential current source to square wave..................... 48  23.   Example of a Double‐Exponential Current Pulse (IPeak = 100 µA, td1 = 10 ps,   td2 = 5 ps, τ1 = 2 ps, τ2 = 10 ps) ............................................................................................... 50  24.   Example of a voltage transient that overdrives the circuit (i.e., the voltage drops below VSS = 0 volts)........................................................................................................ 51  25.   Example of a voltage transient with a slow leading edge .......................................... 51  26.   Device‐level simulation results showing short burst of high current   followed by a sustained shelf of lower current (after [41])...................................... 53  27.   Example of: (a) short peak, IPrompt(t), (b) sustained, IHold(t), and (c) dual   double‐exponential current sources ................................................................................... 54  28.   Baseline 4‐inverter chain schematic ................................................................................... 57  29.   Flowchart to Identify Ithresh variable for implementation with the dual 
  xiii 
  double‐exponential current source model ....................................................................... 58  30.   Flowchart to identify IPrompt and IHold variables for implementation into the   dual double‐exponential current source model ............................................................. 59  31.   Injected current waveforms for circuit configurations with loads listed in   Table 5 to produce ~200 ps SET........................................................................................... 63  32.   Resulting SET voltage waveforms for the circuit configurations with loads listed in Table 5 and for the injected current waveforms shown in   Figure 31.......................................................................................................................................... 63  33.   Device‐level simulation results showing voltage transients (solid lines) for various deposited charges (after [41])............................................................................... 65  34.   90‐nm inverter ring oscillator................................................................................................ 66  35.   MRED to SPICE (MRED2SPICE) framework block diagram...................................... 69  36.   Sample test design using INV1s for MRED2SPICE development............................ 70  37.   MRED2SPICE process flowchart. .......................................................................................... 72  38.   Output samples of data files for: (a) MRED Qcoll source (b) SPICE‐generated   SET results, and (c) SPICE latch SET results. The yellow highlighted events from (a) result in a generated output highlighted in blue in (b), and the   final SET latched errors are in shown in (c). ................................................................... 73  39.   Example core circuit for SET characterization test structure. ................................. 77  40.   SET cross‐section of 1X drive strength for inverter as a function of LET. MRED2SPICE predictions are drawn with solid lines and SEE data is drawn with dashed lines. ........................................................................................................................ 78  41.   SET cross‐section of 1X drive strength of 2‐input NAND gate (1st input   chained, 2nd input tied to Vdd) as a function of LET. MRED2SPICE predictions are drawn with solid lines and SEE data are drawn with dashed lines. .............. 78  42.   SET cross‐section of 1X drive strength for 2‐input NOR gate (1st input   chained, 2nd input tied to Vss) as function of LET. MRED2SPICE predictions 
  xiv 
  are drawn with solid lines and SEE data are drawn with dashed lines. .............. 79  43.   SET cross‐section of 1X drive strength NOR2 MRED2SPICE results with different input chain configurations from Table 9........................................................ 81  44.   Block diagram of circuits for single event simulation of DC‐D‐Latch. .................. 85  45.   Dual‐Complementary DFF input circuit showing internal connections. ............. 85  46.   Dual‐Complementary DFF memory circuit showing internal connections........ 85  47.   Memory Circuit ‐ start state qa/qb holds logic state 1. ............................................... 86  48.   Results from memory circuit normal operation ‐ circuit will settle to logic   state qa/qb = 0, (i.e., no error). .............................................................................................. 88  49:   Block diagram of circuits for single event simulation of Dual‐Complementary D‐Latch. The current sources for single event modeling are placed in the   input and memory circuits. ..................................................................................................... 89  50.   Complementary data ‐ no error (b) matches (h), change of logic state 0 to 1,   or logic state 1 to 0; (a) input clock pulse, (b) input state, (c) ion strike,   (d) through (g) internal storage nodes, (h) output data............................................. 91  51.   Results from input circuit single event ‐ circuit will settle to logic state   qa/qb =1, which is an error..................................................................................................... 93  52.   Complementary input data with error located between 3 ns and 5 ns ‐   single event on input circuit.................................................................................................... 94  53.   Results from memory circuit single event – circuit will settle to logic state qa/qb = 1, which is an error.................................................................................................... 96  54.   Complementary input data with error between 2.5 ns and 4.5 ns – single   event on memory circuit. ......................................................................................................... 96  55.   V‐CREST block diagram. ........................................................................................................... 98  56.   Upset cross‐section versus LET for DC‐DFF layouts at two different clock frequencies. ..................................................................................................................................101 
  xv 
 57.   Maximum SET pulse widths versus collected charge for various NAND2 transistor conditions................................................................................................................103  58.   Variation of SET pulse‐width relative to strike location distance to well contact[40] ...................................................................................................................................105  59.   PMOSFET drain ion strike voltage pulses for 0.2 µm2 and 4 µm2 n‐well contacts.[60] ................................................................................................................................106  60.   Effect of input state on single event response of NAND gate[60].........................107  61.   SET propagation in 10‐inverter delay chains [51]......................................................107  62.   MRED to LOGIC depth (MRED2LOGIC) block diagram .............................................109  63.   Target design for logic depth SET pulse‐width analysis. Logic depths of   3, 7, and 10 were used. ............................................................................................................110  64.   MRED2LOGIC process flowchart ........................................................................................112  65.   MRED2LOGIC SET pulse‐width output file samples for inverter cell with   logic depth 3, (a) Original MRED input file for Qcoll, (b) MRED2LOGIC SET   pulse‐width output file results with corresponding MRED simulation event number after being processed through the multi‐scale simulation with no   loss of information. ...................................................................................................................113  66.   Bin counts of SET pulse‐widths for IBM 90‐nm INVx1 for three different   logic depths and particles of 2.1 MeV‐cm2/mg.............................................................114  67.   Bin counts of SET pulse‐widths for IBM 90‐nm NAND2x1 for three different logic depths and particles of 2.1 MeV‐cm2/mg.............................................................114  68.   Bin counts of SET pulse‐widths for IBM 90‐nm NOR2x1 for three different   logic depths and particles of 2.1 MeV‐cm2/mg.............................................................115  69.   SET multi‐scale simulation MRED to SPICE to ModelSim® for complex   digital ICs.......................................................................................................................................118  70.   Basic block diagram for a testbench with a design under test (DUT).................118 
  xvi 




Acronym  Definition ALU  Arithmetic Logic Unit ASIC  Application Specific Integrated Circuit AVF  Architectural Vulnerability Factor CRÈME96  Cosmic Ray Effects on Micro‐Electronics Code DUE  Detected Unrecoverable Error DUT  Device Under Test ECC  Error Correction Code EHP  Electron‐Hole Pair FF  Flip‐Flop FPGA  Field Programmable Gate Array IC  Integrated Circuit IRPP  Integrated Rectangular Parallelpiped LET  Linear Energy Transfer MRED  Monte Carlo Radiative Energy Deposition MRED2LOGIC  Coupling MRED to SPICE to Logic simulator (ModelSim®) in the tool flow for modeling 
  xviii 





































































































































































































































































































































































































































































































































































(µA) PMOSFET  4.8  121 INVx1    Standard Inverter Chain  NMOSFET  4.6  118 Either PMOSFET  3.3  67 IN1 = “Chain”, IN2 = Vdd  Either NMOSFET  4.1  69 Either PMOSFET  3.4  67 IN1 = Vdd, IN2 = “Chain”  NMOSFET #1  3.4  69 Either PMOSFET  4.1  69 
NAND2x1 
  IN1 = IN2 = “Chain”  Either NMOSFET  5.6  137 Either PMOSFET  8.8  122 (v1) IN1 = “Chain”, IN2 = 
Vss  Either NMOSFET  7.4  113 PMOSFET #2  6.5  121 (v2) IN1 = Vss, IN2 = “Chain”  Either NMOSFET  6.5  113 Either PMOSFET  10.7  242 
NOR2x1 







































(µA) Either PMOSFET  8.8  122 (v1) IN1 = “Chain”, IN2 = Vss  Either NMOSFET  7.4  113 PMOSFET #2  6.5  121 (v2) IN1 = Vss, IN2 = “Chain”  Either NMOSFET  6.5  113 Either PMOSFET  10.7  242 
NOR2x1   























The DC‐DFF  is  a modification  of  a  90‐nm  IBM Dual  Interlocked  Cell  (DICE) design  [52],  implemented  to  increase  the  speed  of  its  operations  due  to  faster switching  between  the  complementary  logic.  It  also makes  use  of  its  four  internal nodes  to  transmit data. The  internal  structure  is based upon a  standard  two‐input NAND function (i.e., NAND2), however some input connections are changed to enable redundancy within the internal nodes. 
  84 
Cell Description 












The  nominal  operation  of  the  cell  can  be  understood  by  examining  the procedure  for overwriting  the state of  the memory portion of  the DC‐DFF. Assume 
  86 






















A double exponential current source is used to represent an SET in all of the simulations presented in this chapter. The damping factor for the rise of the current pulse  is  50  ps.  The  length  of  the  pulse  is  sufficent  to  cause  errors  between  clock edges.  The  amplitude  of  the  current  is  1  mA,  so  that  the  effect  of  the  current  is saturated in the circuit level simulation. The tail current damping factor is 500 ps, see Figure 50.c (IO_sink). 
Data Line SET 
SETs on the data line were simulated with the input and memory circuits  in static mode. The SET was generated at internal nodes. Simulations were performed to  determine  if  the  SET was  latched  by  the  next  DC‐DFF.  Several  conditions were evaluated including: (1) an initial logic state 0 in the DC‐DFF with a next logic state 0, (2) an initial logic state 0 with a next logic state 1, (3) an initial logic state 1 with a next  logic state 0, and (4) an  initial  logic state 1 with a next  logic state 1. The  first condition  propagates  a  constant  logic  0  through  the  shift  register,  while  the  last condition  propagates  a  constant  logic  1.  The  middle  two  conditions  represent 
  90 
alternating logic states that propagate through the shift register. No soft errors were observed for any of these conditions on the output of the DC‐DFF.  








SETs on  the clock  line were analyzed  for  this  circuit  (the clock  line was not hardened  to  SETs).  Clock‐line  SET‐induced  upsets  will  not  occur  if  the  input  data signal is held constant (logic state 1 or 0). However, when alternating logic state from 1 to 0 back to 1 (or vice versa), a clock‐line SET occurring at the incorrect time may change the stored state early or cause failure to sample the  logic state correctly.  In general,  SETs  on  the  clock  lines  could  show  up  when  the  input  data  value  is alternated, but not when the input is constant. A comparison of bit errors that occur during  switched  input  versus  constant  input can  determine  errors  induced  on  the clock distribution circuit. If more upsets are observed when using alternating data as opposed  to  constant  data,  then  clock‐line  SETs  are  contributing  to  this  increased upset rate. 
Internal DC­DFF Single Event 
SETs internal to the DC‐DFF that prohibit the memory circuit from loading the proper  state were  simulated  similarly  to  the  SETs  on  the  data  lines.  The  circuit  in Figure 49 was operated in a shift register fashion. As previously stated, there were no  errors  observed  in  the  SET  on  the  data  line  simulations  (Figure  50);  errors observed here result from ion strikes in the DC‐DFF, causing the DC‐DFF input circuit to  be unable  to write  the  correct  data  into  the memory  circuit. All  four  conditions 
  92 
defined above were simulated: a constant input of either logic state 0 or 1 and two alternating  data  patterns  (1   0  and  0   1).  There  were  no  soft  errors  for  the constant data condition, therefore the design of the DC‐DFF is hardened against SETs when the data are constant.  
There  are  many  sources  of  soft  errors  for  the  alternating  data  patterns.  If more  upsets  are  observed  for  alternating  data  as  opposed  to  constant  data,  then internal  DC‐DFF  single  events will  contribute  to  this  increase  in  upset  sensitivity. These  internal DC‐DFF single events  represent a new clock dependent mechanism, and will be discussed in more detail later. 
Input Circuit Single Events 















The  simulation  results  show  that  single  events  on  both  PMOSFETs  and NMOSFETs in the input circuit prevent the input data from being written to the DC‐DFF. The  simulation  results  also  show  that  this would only occur  in one direction, either on the data transition from logic state 0 to logic state 1 or from logic state 1 to logic state 0. This is dependent on the  location of the transistor  in the  input circuit design. In Figure 52, the input data transition from logic state 0 to logic state 1 at the time  of  the  single  event  (at  2.5  ns)  is  output  correctly. However,  on  the next  data input  transition  from  logic  state  1  to  logic  state  0,  the  output  data  is  blocked  and therefore, incorrectly output. 
  95 
Memory Circuit Single Events 


















The  DC‐DFF  cells  were  used  to  design  a  shift  register  string  using  IBM’s CMOS9SF  process.  The  circuit  includes  built‐in  self‐test  (BIST)  to  evaluate  the DC‐DFF at high frequencies [48, 53]. Two circuit layouts (standard and guard‐band) are evaluated during single event effects testing.  
V­CREST Test Chip Design 
The shift register string design was based on the Circuit for Radiation Effects Self Test (CREST) as originally described by Marshall et al. [53]. This original concept implements built‐in self‐test  (BIST) of SiGe  flip‐flops  (FFs) to measure single event upset  in  shift  register  stings.  It  enables SEU experiments  at high operating  speeds, reduced  challenges  with  test  chip  input/output  pad  design  and  packaging,  and removed  requirements  for  high  frequency  cabling  at  the  test  facilities.  It 
  98 
accomplishes these features by integrating the clock and the data pattern from a 127‐bit  pseudo‐random  number  generation  onto  the  test  chip.  It  also  moves  the error/upset detection circuit onto the test chip. This integration significantly reduces the switching frequency needed for the test chip input/output.  





The  V‐CREST  circuit  can  distinguish  between  errors  caused  by  SETs  in  the clock path versus those in the data path [48, 54]. The clock distribution network uses its last buffer to drive four FFs. SETs on the clock distribution network would affect all four FFs, thereby distinguishing SETs in the clock distribution network from other errors.  If  all  four  FF  shift  registers  showed  an  error,  then  the  error  flag  is  not triggered. Finally, the clock distribution design includes both the clock and its inverse so that clock signals are not generated within a FF.  
Two different DC‐DFF  layouts were evaluated, one utilized guard‐bands and the other did not [54, 55]. The transistor placement was the same for both designs. The size of each layout was also exactly the same. 
Heavy Ion Test Results 



















The  susceptibility  of  the  input  and  memory  circuits  was  analyzed  by simulating  ion strikes  to all  circuit nodes. The simulations  show  the DC‐DFF  is not susceptible to data line SETs but is susceptible to clock line SETs and internal DC‐DFF single  events.  The  heavy  ion  testing  of  the  DC‐DFF  shows  a  much  higher  cross‐section when propagating the alternating input data versus constant input data when clocked. Therefore, the higher cross‐section can only be explained by clock line SETs and internal DC‐DFF single events.  
The  SEU  cross‐section,  Figure  56,  for  the  guard‐band  design  (150  MHz  – 1010‐GB) is  lower than that for the non‐guard‐band design (150 MHz – 1010). The guard  band  was  not  applied  to  the  transistors  in  clock  distribution  circuitry. Therefore,  for  the standard design,  the  internal DC‐DFF single event upsets are the 
  102 
largest  contributor  to  the  cross‐section.  If  the  clock  line  SETs  were  the  larger contributor, then the cross‐sections would be approximately equal because the clock distribution network on  the chip was exactly  the same. Therefore,  internal DC‐DFF single event upsets are clock‐dependent and are a significant contributor to the error cross‐section. 
The simulation results reveal that all 32 of the NMOSFETs and PMOSFETs in the two input circuits and all 16 of the NMOSFETs in the two memory circuits were susceptible  to  this  mechanism.  Therefore,  48  potential  transistors  factor  into  the upset cross‐section for this mechanism. Also, SETs that prevent a state change can be longer than SETs that change the state. This factor leads to an increased probability of occurrence. 
NAND2 logic cells were simulated as the fundamenal building block of the DC‐DFF to determine the generated SET pulse widths as a function of collected charge. Dasgupta et al. [42] describe SET currents with a prompt and a shelf component, and that model was implemented with dual double‐exponential current sources, one for the current shelf and one for the prompt component. The shelf level was a function of the node’s restoring current and was independent of the node’s capacitance, but the prompt  component was  dependent  upon  both  the  restoring  current  and  the  node capacitance. If the load on a circuit node is increased, then only the prompt current source will change. When an SET attempts to prevent a state change, it does not have to overcome the node’s capacitance, so there is no prompt current source. 
  103 



















































































































































Black et al. [59]  9 %  14.3%  8.3%  Cell Count x 131075 










Total  Errors  Observed
























(cm2) INVx1  107  3000  1.50 x 10‐7  5.35 x 10‐9 
NAND2x1  128  3000  3.37 x 10‐7  14.40 x 10‐9 
NOR2x1  89  3000  9.91 x 10‐8  2.94 x 10‐9 



























add_1x1x  22         add_2x2x  9         add_6x6x  1         addh_1x1x  2         addh_3x3x  1         and2_1x  17         and2_3x  6         and2_4x  4         and3_1x  3         ao21_1x  1         ao21_3x  2         aoai211_1x  7         aoi21_1x  45         aoi21_2x  11         aoi21_3x  5         aoi21_8x  1         aoi21_b1_1x  6         aoi21_b1_2x  1         aoi21_b2_1x  8         aoi21_b2_2x  1         aoi22_1x  5         aoi22_3x  1         
  130 
buf_10x  6         buf_16x  2         buf_1x  2         buf_3x  3         buf_8x  1         delay1_4x  1         inv_1x  58  0.30  15.0  0.54  0.54 inv_2x  35         inv_30x  1         inv_3x  17         inv_4x  3         inv_6x  1         nand2_1x  114  0.30  33.7  1.44  1.98 nand2_2x  43         nand2_3x  6         nand2_4x  4         nand2_5x  4         nand2_6x  1         nand2_8x  1         nand2b0_1x  27         nand2b0_2x  1         nand2b0_4x  14         nand3_1x  3         nand3_2x  1         nand3b0_1x  47         nand3b0_2x  3         nand4_1x  1         nor2_1x  51  0.19  9.91  0.29  2.26 nor2_2x  1         nor2_3x  6         nor2b0_1x  5         nor2b0_4x  1         nor3_1x  1         nor3b0_1x  1         nor4_1x  1         oa21_1x  2         oai21_1x  50         oai21_2x  2         oai21_3x  3         oai21_4x  8         oai21_6x  2         oai211_1x  1         oai21b0b1_1x  4         oai21b0b1_4x  1         
  131 















































































































































# Loops to set‐up, evaluate and populate output buffer array #‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐  OutputBuffer = []  # Method to dump results buffer to file def clearBuffer(out_buff):   global FNAME,FDEL   f=open(FNAME,'a')   for buff in out_buff:     f.write("%d%s%.3e%s" % (buff[0],FDEL,buff[1],FDEL))     for i in range(len(buff[2])):       f.write("%.4f%s" % (buff[2][i],FDEL))     f.write("%.4f\n" % buff[2][‐1])   f.close()    def singleEventCallback(evt):   global svList,doViewer,OutputBuffer,MAXBUFFER   # Compact notation    Qs = [svList[i].total_energy/0.0225 for i in range(len(svList))]    #### Or, the long way   #Qs = []   #for i in range(len(svList)):   #  Qs.append(svList[i].total_energy/22.5)    if max(Qs) < 1.0: return # if there's nothing more than 0.1 fC, return)    eventNumber = mred.runMgr.GetEventCount()‐1   weight = mred.evtAct.ComputeEventWeight(evt)   variance = weight**2    print "Event #%d:" % (eventNumber),    for i in range(len(svList)):     print "Q%d=%.4f(fC)" % (i,Qs[i]),   print "Statistical Weight=%.3e" % (weight)    OutputBuffer.append([eventNumber,weight,Qs])    if len(OutputBuffer) > MAXBUFFER:     clearBuffer(OutputBuffer)     OutputBuffer = []        sys.stdout.flush()    if doViewer:     mred.dx.displayMredEvent(evt)  # set Particle takes atomic number and atomic mass  mred.gun.setParticle('ion', 8, 18) #Oxygen, 2.2 LET mred.gun.energy=183*MeV  #Spatial sampling "directionalFlux" is like a broadbeam experiment. Randomizes over a plane in the direction # of the gun direction vector.  mred.gun.random_spatial_sampling = "directionalFlux" mred.gun.random_use_device_radius=True mred.gun.direction=vector3d(0,0,‐1)  # There is no need to do this in our case, at least not right now  # Accumlate histograms  #mred.accumulate_histograms = True #mred.hdf5.file_path=("/home/blackda1/hdf5_output") #mred.hdf5.file_name="stack_Random40MeV10Runs.hdf5" #mred.hdf5.write_output_files=True 
  149 




















































// // Module: tb_set_test_structure_8bit_core // // Description: test bench of the 8bit_core // // Author:  DL // // Last created:  4/24/2008  // SET signal added to testbench 04/01/09 // ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ // Modified by AS, 3/2011 // //‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐ // Modified by DAB, 5/2011 //  // Added BS, fault injection library //~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~  module tb_set_test_structure_8bit_core;     parameter PERIOD = 10;     parameter BUS_WIDTH = 8;     real se_delay;     real end_delay;     real range_end;     real se_len;     reg [BUS_WIDTH‐1:0] a_in, b_in, a_in_1, b_in_1, a_in_2, b_in_2;     reg [2:0] func_in, func_in_1, func_in_2;     reg reset_in, clk_in;       wire [BUS_WIDTH*2‐1:0] y_out;   reg [BUS_WIDTH*2‐1:0] compare;   set_test_structure_8bit_core set_test_structure_8bit_core(   .a_in(a_in),   .b_in(b_in),   .func_in(func_in),   .reset_in(reset_in),   .clk_in(clk_in),   .y_out(y_out)   );    initial begin     clk_in = 1'b0;     reset_in = 1'b0;     #(PERIOD);     #(PERIOD);     reset_in = 1'b1;   end      initial begin     forever #(PERIOD/2) clk_in = ~clk_in;   end 
  171 
      //SET Loop     initial begin        $singleEventInit(); //      $pseudoRandomSeed(seed); //      $display ("SET SEED TO %d",seed);        se_delay=($pseudoRandom(range_end*10*1000)/1000.0);       end_delay=se_delay+10.0;       #se_delay begin     $singleEventTransient(tb_set_test_structure_8bit_core.set_test_structure_8bit_core,se_len*1000.0);     $display("UPSET %16d, %16d, %16d, %16d, %16d, %16d, %16f", $time, $stime,$realtime,func_in,a_in,b_in,se_len);       end       #end_delay $stop;   end         always @* begin     case (func_in_2)         //nothing         3'b000:          begin           compare <= 16'd0;         end         //add         3'b001:          begin           compare <= a_in_2 + b_in_2;         end         //sub         3'b010:         begin           compare <= a_in_2 ‐ b_in_2;         end         //multi         3'b011:         begin           compare <= a_in_2 * b_in_2;         end         //div         3'b100:         begin           compare <= a_in_2 / b_in_2;         end             //comp                  3'b101:         begin           if(a_in_2 > b_in_2) begin             compare <= 16'd2;           end else if (a_in_2 < b_in_2) begin             compare <= 16'd1;           end else if (a_in_2 == b_in_2) begin             compare <= 16'd0;           end else  begin             compare <= 16'd3;           end          end         //a 
  172 
        3'b110:         begin           compare <= a_in_2;         end         //b       3'b111:       begin         compare <= b_in_2;       end     endcase   end        //this basically delay the inputs for 2 cycle, and the compare to the output of the core   //it first loops through b, from 127 to 0, then a, from 0 to 127   //then it goes from func from 0 to 7   // if there is a mis compare, it will print out the error   always @ (negedge clk_in) begin     for(func_in = 0; func_in < 8; func_in = func_in + 1) begin       for(a_in = 0; a_in < 127; a_in = a_in + 1) begin         for(b_in = 127; b_in != 0; b_in = b_in ‐1) begin           a_in_1 <= a_in;           a_in_2 <= a_in_1;           b_in_1 <= b_in;           b_in_2 <= b_in_1;               func_in_1 <= func_in;           func_in_2 <= func_in_1;           //$display("TIME %16d, %16d, %16d, %16d, %16d, %16d", $time, $stime,$realtime,func_in,a_in,b_in);           if (y_out != compare) begin             $display("ERROR %16b, %16b, %16d, %16d, %16d, %16d, %16d, %16f", y_out, compare,func_in,a_in,b_in, y_out, compare,se_len);             $stop;           end           #(PERIOD);         end       end     end     $finish;   end  endmodule;      
 
