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

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? bistpimseqonline.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( int samples2ignore, 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;
    }
}

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
成人动漫一区二区在线| 美女性感视频久久| 色偷偷久久人人79超碰人人澡| 日本一区二区免费在线| 成人久久18免费网站麻豆| 日本一区二区不卡视频| 91视视频在线观看入口直接观看www| 中文字幕在线观看一区| 色拍拍在线精品视频8848| 亚洲成av人片在线观看无码| 91麻豆精品国产91久久久久久久久 | 亚洲免费在线观看| 欧美性猛片xxxx免费看久爱| 日韩国产一二三区| 久久综合色鬼综合色| 成人av电影在线网| 亚洲成a人片在线观看中文| 精品久久一区二区三区| 成人激情免费网站| 亚洲成人自拍偷拍| 国产午夜精品一区二区三区视频| 99re热这里只有精品免费视频| 午夜精品久久久久久久| 久久久久久久一区| 色屁屁一区二区| 麻豆国产91在线播放| 中文字幕永久在线不卡| 7878成人国产在线观看| 国产aⅴ综合色| 亚洲电影第三页| 国产清纯美女被跳蛋高潮一区二区久久w| eeuss鲁片一区二区三区在线看| 亚洲风情在线资源站| 久久综合九色综合久久久精品综合| 成人av综合一区| 麻豆精品久久精品色综合| 亚洲人成伊人成综合网小说| 精品久久一区二区三区| 欧洲日韩一区二区三区| 国产一区欧美日韩| 日韩福利电影在线| 综合久久久久久久| 久久久久97国产精华液好用吗| 欧美亚洲国产一区二区三区| 国产麻豆精品theporn| 亚洲网友自拍偷拍| 国产精品欧美一级免费| 欧美一区二区视频在线观看2020| 99热99精品| 国产东北露脸精品视频| 美国毛片一区二区| 午夜精彩视频在线观看不卡| 亚洲色图视频网| 久久久精品一品道一区| 日韩一区二区在线免费观看| 欧美中文字幕亚洲一区二区va在线 | 欧美高清视频在线高清观看mv色露露十八 | 久久综合九色欧美综合狠狠| 欧美日韩综合在线| 色综合一区二区三区| 国产99久久久国产精品免费看| 日韩av网站免费在线| 亚洲韩国精品一区| 亚洲欧美偷拍卡通变态| 国产精品网站导航| 久久精品一区二区三区av | 精品久久人人做人人爽| 91麻豆精品国产91久久久久 | 日韩在线a电影| 亚洲香蕉伊在人在线观| 有码一区二区三区| 日韩美女精品在线| 中文字幕中文字幕一区二区| 中文字幕免费在线观看视频一区| xnxx国产精品| 久久久久国色av免费看影院| 91精品国产欧美一区二区18| 欧美精品久久久久久久久老牛影院| 色偷偷成人一区二区三区91| 91亚洲永久精品| 91行情网站电视在线观看高清版| 色婷婷亚洲精品| 欧美在线一区二区| 欧美蜜桃一区二区三区| 欧美精品一二三四| 欧美一区二区在线免费观看| 日韩久久免费av| 久久久精品国产免费观看同学| 国产调教视频一区| 日韩美女视频19| 亚洲一本大道在线| 日韩av中文字幕一区二区 | 337p日本欧洲亚洲大胆精品| 精品国产乱码久久久久久牛牛| 欧美成人女星排行榜| 久久久久久免费毛片精品| 中文字幕欧美日韩一区| 亚洲视频一区二区在线观看| 一区二区三区四区亚洲| 丝袜美腿亚洲综合| 狠狠色狠狠色综合| 成人涩涩免费视频| 欧美三级一区二区| 精品欧美乱码久久久久久1区2区| 国产欧美日韩中文久久| 亚洲品质自拍视频| 日本aⅴ免费视频一区二区三区 | 国产露脸91国语对白| 东方aⅴ免费观看久久av| eeuss国产一区二区三区| 91高清视频免费看| 日韩欧美国产小视频| 中文天堂在线一区| 亚洲综合激情另类小说区| 日本sm残虐另类| 99久久伊人精品| 欧美一区二区在线不卡| 国产精品日韩成人| 日本特黄久久久高潮| 成人黄色一级视频| 4438x成人网最大色成网站| 国产亚洲成aⅴ人片在线观看| 一区二区三区免费网站| 国产一区二区0| 欧美性受xxxx| 国产精品久久久久一区二区三区| 夜夜嗨av一区二区三区四季av| 蜜臀精品一区二区三区在线观看| 国产99精品国产| 日韩欧美在线一区二区三区| 亚洲欧洲精品一区二区三区| 日av在线不卡| 在线观看成人免费视频| 国产亚洲欧美日韩俺去了| 亚洲成人免费影院| 97精品国产露脸对白| 日韩免费观看高清完整版在线观看| 中文字幕中文字幕在线一区| 久久97超碰色| 欧美日韩日日摸| 亚洲黄色尤物视频| 成人精品高清在线| 久久久三级国产网站| 午夜国产精品一区| 欧美午夜电影一区| 亚洲女同一区二区| 高清不卡一区二区| 亚洲精品一区二区三区四区高清| 性感美女极品91精品| 色噜噜狠狠色综合欧洲selulu| 久久久久久**毛片大全| 狠狠网亚洲精品| 欧美电影免费观看高清完整版在| 婷婷开心激情综合| 欧美性极品少妇| 一级中文字幕一区二区| 91在线观看高清| 亚洲欧洲综合另类在线| 波多野结衣亚洲一区| 国产精品毛片久久久久久久| 国产一区二区按摩在线观看| 精品国产91久久久久久久妲己| 日韩av一区二区三区| 欧美日韩aaaaaa| 婷婷开心激情综合| 91精品国产综合久久久久久久| 午夜精品一区二区三区电影天堂| 91久久一区二区| 亚洲影视在线播放| 欧美日韩在线播放三区| 亚洲自拍另类综合| 欧美日韩大陆一区二区| 天堂成人国产精品一区| 欧美一级二级在线观看| 精品写真视频在线观看| 伊人婷婷欧美激情| 91老师国产黑色丝袜在线| ...xxx性欧美| 欧美亚洲综合色| 蜜臀久久99精品久久久久宅男| 日韩精品在线一区| 国产999精品久久| 亚洲女同一区二区| 欧美日韩成人激情| 韩国女主播成人在线| 国产女主播一区| 91性感美女视频| 亚洲成人精品影院| 日韩欧美一二三| 大陆成人av片| 亚洲午夜电影在线| 精品国产不卡一区二区三区| 国产福利91精品一区| 专区另类欧美日韩| 欧美精品乱码久久久久久按摩| 理论电影国产精品| 国产精品免费看片| 欧美日韩国产首页| 国产综合一区二区| 亚洲男女一区二区三区|