亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? bistpimseqonlinestochastic.java~

?? Java遺傳算法庫
?? JAVA~
字號:
/*
 * BISTIM.java
 *
 * Created on 19 May 2002, 18:56
 */

package es.pj.circuits.control;

import es.evolve.Evolver;
import es.deploy.Deployment;
import es.experiment.*;
import es.control.StandardInteractionModel;
import es.*;
import es.pj.circuits.fpgaft.*;
import es.pj.circuits.SimulatorLogicElement;
import es.pj.circuits.experiment.ConfigurableSequentialCircuitExperiment;

import java.util.Random;
import java.util.Vector;

import islandev.SnapshotPainter;
import islandev.EmptySnapshotPainter;


/** Like BISTPIM but:
 * <ul><li>Only On-Line BIST evaluated (must report first fault affecting outputs)</li>
 * <li>Optimization in SimulatorFaultyCircuitOpt used for sequenial circuits</li>
 * <li>For combinational circuits use BISTPIM</li>
 * <li>Overdetecting always good.
 * </ul>
 *
 */
public class BISTPIMSeqOnline extends StandardInteractionModel
{
    // Config Vars
    
    
    // Variables for finding E
    protected int startAt = 0; // For each input cycle, start at ...
    protected int eSize;
    protected int inputResetLength = 0;
    
    // Variable for extracting value of output (kind of inverse of t_setup)
    protected double threshold = 0.1;
    
    //Working Vars
    protected double currMaxF_e = -1;
    protected SingleFaultModel faultModel;
    protected SingleRandomFaultModel srfm = null; // If its randomness, its randomness will need to be controlled
    protected ConfigurableSequentialCircuitExperiment scexp;
    protected SimulatorFaultyCircuitOpt circuit;
    
    public BISTPIMSeqOnline(Evolver evo, Deployment dep, SimulatorFaultyCircuitOpt cir, ConfigurableSequentialCircuitExperiment exp, int iss, SingleFaultModel fm, int es,SnapshotPainter painter, int startAt, int inputResetLength ) {
        this( evo, dep, cir, exp, iss, fm, es );
        this.painter = painter;
        this.startAt = startAt;
        this.inputResetLength = inputResetLength;
    }
    
    public BISTPIMSeqOnline(Evolver evo, Deployment dep, SimulatorFaultyCircuitOpt cir, ConfigurableSequentialCircuitExperiment exp, int iss, SingleFaultModel fm, int es) {
        super( evo, dep, exp, iss );
        scexp = exp;
        circuit = cir;
        faultModel = fm;
        if( faultModel instanceof SingleRandomFaultModel )
        {
            srfm = ( SingleRandomFaultModel ) fm;
        }        
        eSize = es;
    }
        
    public void evolve()
    {
        super.evolve();
        if( srfm != null )
        {
            srfm.nextRandomSeries(); // Same for all per generation, but != 'tween generations.
        }
        currMaxF_e = -1;
    }
    
    /** Evaluates these individuals using the deployment and experiments and
     * procedure of this model.
     */
    synchronized public double[] evaluate(Genotype[] inds)
    {
        Genotype ind = inds[ 0 ];

        // 1) Evaluate Ind with no faults.
        deployment.program( ind );
        SampleData[] input = experiment.generateInput( inputSampleSeparation );
        int insertFaultAt = scexp.rndStatePos();
        
        //TI//if( !stateNoise )
        //TI//{
            //TI//circuit.reset();
        //TI//}else
        //TI//{
        circuit.randomReset();
        //TI//}
        
        SampleData[] noFQWithE = deployment.run( input );
        int nrOuts = noFQWithE.length - 1;
        SampleData[] noFQNoE = ESLib.getLines( noFQWithE, 0, nrOuts );
        double f_e = experiment.getFitness( input, noFQNoE );
        double f_b = 0;
        boolean mainTaskOK = f_e > currMaxF_e - threshold;

        // 2) Compute f_b now.
        if( mainTaskOK && !getE( noFQWithE ) ) // Check that E low for no faults! If it isn't, then discard.
        {
            currMaxF_e = Math.max( f_e, currMaxF_e );
            
            // 2.1) Init variables.
            boolean[] used = getUsed( nrOuts ); // Skipping faults in unused elements.

            int nrFaults = 1; // how many faults tested for 
            int diagFaults = 1; // how many correctly diagnosed, including no faults.
            int[] rv2 = { 0 };

            // 2) Check if faults are detected at the right moment.  Ie: if
            // at the first moment the circuit gives out a wrong output the
            // error line is high.  
            // 2.2) Iterate through faults
            faultModel.reset();
            while( faultModel.hasMoreElements() )
            {
                java.awt.Point fPosVal = ( java.awt.Point ) faultModel.nextElement();
                if( used[ fPosVal.x ] ) // Skipping faults in unused elements.
                {
                    //circuit.setFault( fPosVal.x, fPosVal.y );// Set it during run so randomize state inserted at

                    //TI//if( !stateNoise )
                    //TI//{
                        //TI//circuit.reset();
                    //TI//}else
                    //TI//{
                    circuit.randomReset();
                    //TI//}

                    // 2.2.2) Run Circuit with Fault.
                    circuit.run( input, noFQWithE, rv2, fPosVal, insertFaultAt );
                    if( rv2[ 0 ] == SimulatorFaultyCircuitOpt.NORMAL )
                    {
                        circuit.run( input, noFQWithE, rv2, insertFaultAt ); // Run again because fault hasn't affected Q
                    }
                    
                    switch( rv2[ 0 ] )
                    {
                        case SimulatorFaultyCircuitOpt.LINE_HIGH:
                        {
                            // Fault detected, score point
                        };
                        case SimulatorFaultyCircuitOpt.NORMAL:
                        {
                            // No Fault, No detection, score point
                            diagFaults++;
                        }
                        case SimulatorFaultyCircuitOpt.OUTPUT_DIFFERENT:
                        {
                            // Undetected Fault, no points
                        };
                    }
                    nrFaults++;
                    circuit.removeFault( fPosVal ); // clear fault
                }
            }
            f_b = 1d / ( ( nrFaults - diagFaults ) / 25d + 1d );
        }       
        ind.setProperty( 0, new Double( f_b ) );
        ind.setProperty( 1, new Double( f_b ) );
        houseWork( ind, f_e );
        double[] rv = { f_e };
        return rv;        
    }
    
    /** Returns the value of E for this segment */
    protected boolean getE( SampleData[] output )
    {
        SampleData E = output[ output.length - 1 ];
        int outLen = E.length();
        int inputCycles = outLen / inputSampleSeparation;
        for( int idl = inputResetLength; idl < inputCycles; idl++ )
        {
            int conc = 0;
            for( int odl = startAt; odl < inputSampleSeparation; odl++ )
            {
                if( E.get( idl * inputSampleSeparation + odl ) )
                {
                    conc++;
                    if( conc == eSize )
                    {
                        return true;
                    }
                }else
                {
                    conc = 0;
                }
            }
        }
        return false;
    }
            
    public String toString()
    {
        String narrator = "BIST Sequential Online Interaction Model with:";
        narrator += "\n  Threshold = " + threshold;
        narrator += "\n  Error Line Start At = " + startAt;
        narrator += "\n  Error High Minimum Size = " + eSize;
        narrator += "\n  Input Reset Pattern Length = " + inputResetLength;
        narrator += "\n  Fault Model: " + faultModel;
        narrator += "\n\nExperiment: " + experiment;
        narrator += "\n\nDeployment: " + deployment;
        narrator += "\n\nEvolver: " + evolver;
        narrator += "\n";
        return narrator;
    }
    
    // Snapshot so far does normal thing
    
    protected boolean[] getUsed( int outs )
    {
        SimulatorLogicElement[] els = circuit.getElements();
        boolean[] rv = new boolean[ els.length ];
        for( int ol = 0; ol < outs; ol++ )
        {
            addConnectedGates( rv, els[ ol ], els );
        }
        return rv;
    }

    protected void addConnectedGates( boolean[] added, SimulatorLogicElement el, SimulatorLogicElement[] els )
    {
        int elinels = es.ESLib.indexOf( el, els );
        if( elinels >= 0 && !added[ elinels ] )
        {
            added[ elinels ] = true;
            SimulatorLogicElement[] ins = el.getInputs();
            if( ins != null )
            {
                for( int il = 0; il < ins.length; il++ )
                {
                    addConnectedGates( added, ins[ il ], els );
                }
            }
        }
    }
    
    public Genotype getMaxFitness()
    {
        Genotype rv = super.getMaxFitness();
        rv.setProperty( 0, new Double( 1 ) );
        rv.setProperty( 1, new Double( 1 ) );
        return rv;
    }
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产99精品视频| 91国偷自产一区二区开放时间| 色综合色狠狠综合色| 国产午夜精品理论片a级大结局| 日韩精品五月天| 欧美一区二区三区日韩视频| 蜜桃av噜噜一区| 欧美电影免费观看高清完整版在 | 精品久久久久久亚洲综合网| 国产一区二区在线看| 国产女人18毛片水真多成人如厕| 国产乱码精品一区二区三区av| 久久久久久久一区| 91亚洲国产成人精品一区二三| 亚洲精品视频自拍| 日韩欧美国产电影| 97精品国产露脸对白| 久久成人综合网| 久久久久久久久久久久久久久99| 国产真实乱对白精彩久久| 中文字幕的久久| 欧美白人最猛性xxxxx69交| 91日韩精品一区| 成人污污视频在线观看| 性感美女久久精品| ●精品国产综合乱码久久久久| 日韩免费电影网站| 欧美日本在线播放| 欧美综合在线视频| av不卡免费在线观看| 成人免费的视频| 国产久卡久卡久卡久卡视频精品| 一区二区三区在线播| 国产精品人妖ts系列视频| 制服视频三区第一页精品| 欧美艳星brazzers| 欧美日韩国产另类一区| 欧美伊人久久大香线蕉综合69| 99re这里只有精品视频首页| www.亚洲色图.com| 99麻豆久久久国产精品免费| 国产综合色视频| 久久福利资源站| 成人中文字幕电影| 波多野结衣视频一区| 色综合av在线| 欧美精品色一区二区三区| 国产亚洲欧洲997久久综合| 欧美国产日产图区| 亚洲激情五月婷婷| 日本伊人色综合网| av资源网一区| 欧美在线一区二区三区| 欧美区视频在线观看| 亚洲精品一区二区三区蜜桃下载 | 99久久伊人精品| 欧美一区二区在线看| 欧美一区二区三区免费视频| 亚洲国产精品黑人久久久| 亚洲欧美二区三区| 韩国中文字幕2020精品| 欧美三级中文字幕| 亚洲丝袜另类动漫二区| 国产精品18久久久久久vr| 欧美日韩精品系列| 国产精品久久久久久久久晋中| 亚洲3atv精品一区二区三区| 成人不卡免费av| 中文字幕精品综合| 久久99久久久久久久久久久| 99久久免费视频.com| 精品国产一区二区三区不卡| 五月天婷婷综合| 在线91免费看| 午夜精品久久久久久久| 色狠狠av一区二区三区| 1024成人网| 色欧美日韩亚洲| 亚洲gay无套男同| 日韩视频在线永久播放| 精品综合免费视频观看| 亚洲国产精品av| 97精品电影院| 视频精品一区二区| 5566中文字幕一区二区电影| 青椒成人免费视频| 日韩一卡二卡三卡| 成人精品高清在线| 久久国产综合精品| 国产欧美一区二区精品性色超碰| 丰满少妇久久久久久久| 中文字幕在线观看不卡视频| 欧美视频精品在线| 国产成人综合在线| 午夜精品影院在线观看| 久久久久久久久久久电影| 色婷婷一区二区| 久久成人免费网| 亚洲一区二区三区视频在线播放| 欧美精品一区视频| 欧美亚洲图片小说| 国产精品69久久久久水密桃| 亚洲综合色自拍一区| 亚洲国产高清不卡| 久久久亚洲午夜电影| gogogo免费视频观看亚洲一| 久久草av在线| 午夜精品久久久久久久蜜桃app| 亚洲欧美在线视频观看| 日韩精品中午字幕| 色偷偷一区二区三区| 91蜜桃婷婷狠狠久久综合9色| 狠狠色狠狠色综合| 一区二区三区在线观看欧美| 久久久一区二区| 日韩精品中午字幕| 日韩欧美国产1| 欧美成人三级电影在线| 欧美一区二区三区在| 欧美妇女性影城| 91精品一区二区三区久久久久久 | 黄页网站大全一区二区| 日韩国产精品久久久久久亚洲| 夜夜精品浪潮av一区二区三区| 亚洲成人激情社区| 成人精品视频一区二区三区| 日韩欧美国产麻豆| 国产欧美日本一区视频| 午夜精品一区在线观看| 国产精品18久久久久久久久久久久 | 久久草av在线| 国产精品综合二区| 91丝袜美腿高跟国产极品老师 | 一区二区三区欧美日| 精品一区二区三区久久久| 成人性生交大片| 日韩一区二区在线观看| 亚洲黄一区二区三区| 国产一区二区导航在线播放| 国产91对白在线观看九色| 日韩欧美中文字幕公布| 亚洲精品久久久久久国产精华液| 亚洲一区在线观看免费| 国产成人精品免费一区二区| 欧美精品高清视频| 亚洲第一久久影院| 欧美日韩激情在线| 亚洲少妇最新在线视频| 韩国欧美国产一区| 欧美xxx久久| 激情综合五月婷婷| 精品久久久久久久久久久院品网| 亚洲成人自拍偷拍| heyzo一本久久综合| 一区二区三区四区乱视频| 在线视频亚洲一区| 亚洲欧美日韩小说| 91亚洲精品久久久蜜桃网站 | 国产精品丝袜久久久久久app| 视频一区二区欧美| 在线不卡a资源高清| 亚洲欧美视频在线观看视频| 国产成人av电影在线观看| 精品国产一区a| 欧美日韩不卡一区| 国产不卡视频在线播放| 精品第一国产综合精品aⅴ| 99久久99久久综合| 毛片av一区二区三区| 一区二区三区在线免费视频| 欧美一级在线免费| 欧美日本一区二区三区四区| 国产精品自在欧美一区| 日韩电影在线一区| 亚洲一区免费视频| 亚洲最新视频在线观看| 国产精品久久久久久久久免费丝袜| 欧美一区二区性放荡片| 欧美日韩中字一区| 欧美在线观看视频一区二区| 成人av资源在线观看| 粉嫩aⅴ一区二区三区四区| 精品在线一区二区| 国产真实乱子伦精品视频| 国产在线视频精品一区| 国产一区二区在线视频| 成人国产精品免费| 色久优优欧美色久优优| 欧美性猛交xxxx黑人交| 欧美日韩成人在线一区| 精品日韩一区二区三区免费视频| 在线观看国产91| 成人免费观看av| 在线中文字幕一区| 日韩三区在线观看| 国产精品成人一区二区三区夜夜夜| 中文字幕一区三区| 日韩精彩视频在线观看| 成人午夜又粗又硬又大| 欧美亚洲一区三区|