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

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

?? simpledispatchrule.java

?? 今天為網友提供的是JAVA源碼
?? JAVA
?? 第 1 頁 / 共 3 頁
字號:
package com.power.pipeengine.DispatchReport;

/**
 * <p>Title: PIPE Engine</p>
 * <p>Description: Global Planning Optimization Engine</p>
 * <p>Copyright: Copyright (c) 2002</p>
 * <p>Company: Paraster, Inc.</p>
 * @author not attributable
 * @version 1.0
 */

import java.util.*;
import java.io.*;
import com.power.pipeengine.Report.*;
import com.power.pipeengine.Entity.*;
import com.power.util.Message.*;
import com.power.util.urltools.*;
import com.power.pipeengine.DispatchReportMap.*;
import com.power.pipeengine.InputData.*;
import com.power.pipe.*;
import java.text.*;

public class SimpleDispatchRule {

  private static final SimpleDispatchRule INSTANCE =
      new SimpleDispatchRule();

  // Private constructor supresses
  // default public constructor
  private SimpleDispatchRule() {
  }

  public static SimpleDispatchRule getInstance() {
    return INSTANCE;
  }

  Hashtable distinctOperators = new Hashtable();
  int numOfOperatorsToBeAdded = 0;
  int cycleTime = 4;
  String planningMode = "";

  public int getAnExtraOperator() {
    numOfOperatorsToBeAdded++;
    return - numOfOperatorsToBeAdded;
  }

  public int getCycleTime() {
    return cycleTime;
  }

  public void createReport() {
    try {
      PlanInUse.getInstance().readData();
      OrderDetailsManHourMap.getInstance().readData();
      ProcessCapabilityTable.getInstance().readData();
      SewingOps.getInstance().readData();
      WIP.getInstance().readData();
      LastDayProduction.getInstance().readData();
    }
    catch (Exception e) {
      System.out.println("Reading error: " + e.getMessage());
    }

    if( PlanInUse.getInstance().getNumOfRecords() == 0 ) {
      planningMode = "NEW";
    } else if( PlanInUse.getInstance().getNumOfRecords() != 0 &&
      OrderDetailsManHourMap.getInstance().getStylesByOrderNew().size() != 0 ) {
      planningMode = "MIXED";
    } else {
      planningMode = "REPLAN";
    }

    if( !planningMode.equals( "NEW" ) ) {
      //modify current plan
System.out.println("regenerate a plan" );
      regeneratePlan();
      PlanInUse.getInstance().print();
      if( planningMode.equals( "MIXED" ) ) {
        //generate a new plan
        initStandardCurve();
        roughCapacityRqmtEstimate();
        assignLeftOverOperators();
        writeDispatchList();
      }
    } else {
      //generate a new plan
      initStandardCurve();
      roughCapacityRqmtEstimate();
      assignLeftOverOperators();
      writeDispatchList();
      computeNumOfGroups();
      System.out.println("total number of operators: " + totalOperators);
    }
  }

  public String getPlanningMode() {
    return planningMode;
  }

  double stdCurve[] = new double[60];

  private void regeneratePlan() {
    Vector wips = WIP.getInstance().getWIPs();

    for( int i=0; i<wips.size(); i++ ) {
      Object[] aWip = (Object[]) wips.elementAt( i );
      String orderID = (String) aWip[0];
      String styleID = (String) aWip[1];
      Integer procID = (Integer) aWip[2];
      Integer qty = (Integer) aWip[3];
      String key = orderID+ "&" + styleID + "&" + procID.toString();
      Plan aPlan = PlanInUse.getInstance().getPlan( key );
      if( null == aPlan ) continue;
      aPlan.replan( qty.intValue()  );
    }

    //allocate plan over employees
    PlanInUse.getInstance().genPlanByEmployee();
    schedules = PlanInUse.getInstance().getSchedules();
    writeDispatchList();
    //System.out.println( schedules.toString() );
  }

  private void initStandardCurve() {
    stdCurve[0] = 1.0;
    stdCurve[1] = 1.3;
    stdCurve[2] = 1.5;

    for( int i=3; i<14; i++ ) {
      stdCurve[i] = stdCurve[i-1] + 0.04;
    }

    for( int i=14; i<stdCurve.length; i++ ) {
      stdCurve[i] = 2.0;
    }
  }

  int grandDemand = 0;

  private void computeTotalDemand() {
    //get all big orders
    Hashtable stylesByOrder = OrderDetailsManHourMap.getInstance().getStylesByOrder();
    Enumeration orderIDs = stylesByOrder.keys();
    Date dueDate = null;

    //loop through all orders to get sum of max processing times
    while( orderIDs.hasMoreElements() ) {
      String anOrderID = (String) orderIDs.nextElement();
      Vector allStylesByOrder = OrderDetailsManHourMap.getInstance().
          getDistinctStyleByOrder(anOrderID);
      for (int i = 0; i < allStylesByOrder.size(); i++) {
        Style aStyle = (Style) allStylesByOrder.elementAt(i);
        grandDemand += aStyle.getQuantity();
      }
    }

    System.out.println("TotalDemand = " + grandDemand );
  }

  public void roughCapacityRqmtEstimate() {
    computeTotalDemand();
    OrderDetailsManHourMap.getInstance().computeStartTimeOffset();

    //get all big orders
    Hashtable stylesByOrder = OrderDetailsManHourMap.getInstance().getStylesByOrder();
    //Enumeration orderIDs = stylesByOrder.keys();
    Date dueDate = null;

    Vector orderIDs = OrderDetailsManHourMap.getInstance().getOrderIDByDueDate();

    //loop through all orders to get sum of max processing times
    //while( orderIDs.hasMoreElements() ) {
    for( int t=0; t<orderIDs.size(); t++ ) {
      //String anOrderID = (String) orderIDs.nextElement();
      String anOrderID = (String) orderIDs.elementAt( t );
      double sumMaxProcTime = 0;
      int totalNumOfPieces = 0;
      int numOfOperators = 0;
      double totalRqdMinutes = 0;
      Vector allStylesByOrder = OrderDetailsManHourMap.getInstance().
          getDistinctStyleByOrder(anOrderID);
 System.out.println( "number of distinct styles = " + allStylesByOrder.size() );
      for (int i = 0; i < allStylesByOrder.size(); i++) {
        System.out.println( "debug 2" );
        Style aStyle = (Style) allStylesByOrder.elementAt(i);
        totalNumOfPieces += aStyle.getQuantity();
        dueDate = aStyle.getDueDate();
        //get styles by orderID and styleID
        Vector styles = OrderDetailsManHourMap.getInstance().getStyles(
            anOrderID,
            aStyle.getStyleID());
        System.out.println( "debug 3 style size = " + styles.size() );

        double maxProcTime = 0;
        double operators = 0;
        int styleDmd = 0;
        double minRatio = 100000;
        for (int j = 0; j < styles.size(); j++) {
          Style tmpStyle = (Style) styles.elementAt(j);
          if( ! SewingOps.getInstance().isSewingOp( tmpStyle.getProcessID() ) ) continue;
          Vector capableOperators = ProcessCapabilityTable.getInstance().
              getCapableOperators(tmpStyle.getProcessID());

          double sumCapIdx = 0;
          for( int k=0; k<capableOperators.size(); k++ ) {
            ProcessCapability pc = (ProcessCapability) capableOperators.elementAt( k );
            sumCapIdx += pc.getCapability( tmpStyle.getProcessID() );
          }

          if (  tmpStyle.getProcessingTime() > maxProcTime ) {
            //if (  sumCapIdx / tmpStyle.getProcessingTime() < minRatio ) {
            minRatio = sumCapIdx / tmpStyle.getProcessingTime();
            operators = ProcessCapabilityTable.getInstance().
                getNumOfOperatorsForRoute( new Integer( tmpStyle.getProcessID() ) );
            styleDmd = tmpStyle.getQuantity();
            maxProcTime =  tmpStyle.getProcessingTime();
         }
        }
        System.out.println( "debug 4" );

        numOfOperators += operators;
        //sumMaxProcTime += maxProcTime;
        totalRqdMinutes += styleDmd * maxProcTime;

        Calendar due = Calendar.getInstance();
        due.setTime( dueDate );
        due.add( Calendar.DAY_OF_YEAR, - cycleTime );

        generateAScheduleForAStyle( due.getTime(),
                                    1, //numOfOperators,
                                    totalRqdMinutes,
                                    anOrderID,
                                    aStyle.getStyleID() );


        totalRqdMinutes = 0;

      }



    }



  }

  StringBuffer schedules = new StringBuffer();
  private void assignOperator( Style style, int operator, int[] qty, Date start, int numOfDaysRqd ) {
    SimpleDateFormat sdf = new SimpleDateFormat( "yyyy-MM-dd HH:mm:ss" );
    Calendar cal = Calendar.getInstance();
    cal.setTime( start );
    for( int i=0; i<numOfDaysRqd; i++ ) {
      schedules.append( "-1,"); //equipment
      schedules.append( style.getOrderID() + ","); //orderID
      schedules.append( style.getStyleID() + "," ); //style ID
      schedules.append( style.getProcessID() + "," ); //process ID
      schedules.append( operator + "," ); //employee ID
      schedules.append( qty[i] + ","); //qty
      schedules.append( "0," ); //finished qty
      cal.set( Calendar.HOUR_OF_DAY, 8 );
      cal.set( Calendar.MINUTE, 0 );
      cal.set( Calendar.SECOND, 0 );
      cal.add( Calendar.DAY_OF_MONTH, 1 );
      Date startHours = cal.getTime();
      schedules.append( sdf.format( startHours ) + "," );
      cal.set( Calendar.HOUR_OF_DAY, 17 );
      Date endHours = cal.getTime();
      schedules.append( sdf.format( endHours ) + "," );
      schedules.append( "null,"); //null value
      schedules.append( "1\n"); //line number
    }
  }

  int totalOperators = 0;
  private void computeNumOfGroups() {
    totalOperators = distinctOperators.size();
    int numOfGrps = (int) Math.floor( totalOperators / 25.0 + .5 );
    System.out.println( "Recommended number of groups = " + numOfGrps );
  }

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
粉嫩13p一区二区三区| 欧美成人一区二区| 日韩精品一区二区三区在线播放| 久久久久国产免费免费| 一级精品视频在线观看宜春院| 日日摸夜夜添夜夜添亚洲女人| 97久久超碰国产精品| 精品少妇一区二区| 五月天视频一区| 色综合天天天天做夜夜夜夜做| 日韩欧美精品三级| 五月天久久比比资源色| 色偷偷88欧美精品久久久| 久久久综合九色合综国产精品| 午夜av区久久| 色欧美片视频在线观看| 欧美国产日韩亚洲一区| 国产一区二区三区蝌蚪| 欧美一级高清大全免费观看| 亚洲综合一区二区精品导航| 成人激情校园春色| 中文av一区特黄| 国产精品影视在线| 精品嫩草影院久久| 久久99国产精品麻豆| 宅男在线国产精品| 五月天激情综合| 欧美日韩国产经典色站一区二区三区 | 亚洲超碰精品一区二区| 99久久精品国产毛片| 中文字幕第一区第二区| 国产米奇在线777精品观看| 久久只精品国产| 极品少妇xxxx精品少妇| 久久久久久9999| 国产精品18久久久久久久久久久久| 精品国产91亚洲一区二区三区婷婷| 久久精品99国产国产精| 久久亚洲春色中文字幕久久久| 黄色成人免费在线| 国产欧美日韩一区二区三区在线观看| 懂色av一区二区夜夜嗨| 国产精品久久久久久久蜜臀| 97精品超碰一区二区三区| 国产精品久久久久久一区二区三区| 国产精品99久久久久久似苏梦涵| 欧美一区二区三区播放老司机 | 成人av小说网| 国产免费久久精品| 韩国精品久久久| 欧美韩日一区二区三区| 成人精品免费看| 国产精品人成在线观看免费| 成人午夜av在线| 国产精品天干天干在线综合| 成人av免费在线观看| 亚洲丝袜制服诱惑| 91在线一区二区三区| 亚洲欧美日韩在线播放| 在线免费观看视频一区| 夜夜嗨av一区二区三区网页| 日本精品裸体写真集在线观看| 亚洲丶国产丶欧美一区二区三区| 欧美性猛片aaaaaaa做受| 亚洲国产欧美日韩另类综合| 在线播放日韩导航| 激情综合色播激情啊| 久久久久久一级片| www.av亚洲| 亚洲国产毛片aaaaa无费看| 717成人午夜免费福利电影| 久久疯狂做爰流白浆xx| 久久久国产精品麻豆| 99国产精品久久| 亚洲人一二三区| 日韩欧美电影一二三| 成人少妇影院yyyy| 亚洲国产综合91精品麻豆| 日韩一区二区在线观看视频播放| 国产成人免费av在线| 亚洲欧美一区二区视频| 欧美日韩的一区二区| 国产剧情一区二区三区| 亚洲精品一卡二卡| 日韩欧美在线网站| 97精品久久久久中文字幕| 视频一区中文字幕| 久久久久久亚洲综合影院红桃 | 自拍偷拍亚洲综合| 国产一区二区免费看| 国产精品日韩精品欧美在线| 欧美色综合影院| 国产成人三级在线观看| 亚洲一区二区三区四区在线免费观看 | 日本高清无吗v一区| 韩国v欧美v亚洲v日本v| 夜夜亚洲天天久久| 26uuu亚洲综合色| 欧美一级专区免费大片| 欧美亚洲日本国产| 成人午夜私人影院| 经典一区二区三区| 亚洲午夜免费电影| 欧美国产日韩精品免费观看| 欧美片网站yy| 99re视频精品| 国产麻豆视频一区| 日韩av成人高清| 亚洲午夜激情av| 亚洲国产精品黑人久久久| 久久你懂得1024| 欧美一级在线免费| 精品视频全国免费看| av在线播放一区二区三区| 精品一区二区三区的国产在线播放| 一区二区在线观看av| 中文字幕第一页久久| 337p日本欧洲亚洲大胆精品| 国产日本欧美一区二区| 久久毛片高清国产| 欧美大片在线观看| 5月丁香婷婷综合| 欧美日韩免费一区二区三区 | 日韩精彩视频在线观看| 中文字幕精品一区二区精品绿巨人| 3d成人动漫网站| 在线播放中文一区| 欧美一区二区三区系列电影| 91精品国产91久久久久久一区二区| 91成人在线免费观看| 色婷婷国产精品| 欧美专区亚洲专区| 成人中文字幕合集| 9i看片成人免费高清| www.性欧美| 91丨porny丨户外露出| 99热99精品| 91视频你懂的| 欧美视频精品在线| 欧美丰满嫩嫩电影| 日韩一级免费观看| 日韩美女在线视频| 久久午夜色播影院免费高清| 在线播放亚洲一区| 91.麻豆视频| 久久久国产综合精品女国产盗摄| 久久精品网站免费观看| 国产日韩精品一区二区三区在线| 国产日韩精品一区| 亚洲天堂av一区| 婷婷国产v国产偷v亚洲高清| 青青草97国产精品免费观看无弹窗版 | 五月天精品一区二区三区| 青娱乐精品视频| 国产精品一卡二卡在线观看| 成人午夜在线免费| 91高清在线观看| 欧美疯狂做受xxxx富婆| 久久综合色鬼综合色| 国产精品久久久久久久裸模| 尤物在线观看一区| 日本怡春院一区二区| 国产一区二区毛片| 色先锋aa成人| 精品国产一区久久| 日韩一区在线看| 日韩主播视频在线| 东方欧美亚洲色图在线| 91香蕉国产在线观看软件| 欧美电影免费观看完整版| 国产精品久久久久7777按摩| 午夜精品影院在线观看| 国产成人8x视频一区二区| 欧美日韩在线电影| 日韩欧美电影在线| 中文字幕av资源一区| 三级一区在线视频先锋 | 欧美一区二区三区免费| 国产精品久久午夜| 免费成人av资源网| 成人毛片视频在线观看| 欧美日韩aaaaa| 国产精品国产三级国产aⅴ入口| 亚洲国产精品麻豆| 成人免费高清视频| 日韩欧美国产电影| 亚洲图片自拍偷拍| 不卡一区二区三区四区| 欧美一级搡bbbb搡bbbb| 亚洲日本在线看| 人人超碰91尤物精品国产| 精品一区二区三区视频在线观看| 欧美高清一级片在线| 亚洲精品欧美专区| 成人美女在线观看| 国产欧美视频一区二区三区| 日本亚洲免费观看| 欧美日韩视频专区在线播放| 亚洲人被黑人高潮完整版| 国产精品一区二区黑丝|