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

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

?? simpledispatchrule.java

?? 這可是全球著名IT公司ILog的APS高級排產優化引擎
?? 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一区二区三区免费野_久草精品视频
欧美一区二区三区电影| 日本一区二区三区国色天香| 成人综合日日夜夜| 国产黄色91视频| 精品亚洲国内自在自线福利| 日本大胆欧美人术艺术动态| 日本91福利区| 精彩视频一区二区三区| 久久成人免费日本黄色| 精品一区二区三区在线播放视频| 麻豆91在线看| 国产福利91精品| 91天堂素人约啪| 在线亚洲欧美专区二区| 欧美日本一区二区| 91精品国产综合久久久久久久| 91麻豆精品国产| 精品美女被调教视频大全网站| 国产亚洲精品7777| 亚洲欧洲www| 亚洲bt欧美bt精品777| 免费在线观看不卡| 国产盗摄一区二区三区| 色综合天天综合网天天看片| 欧美日韩一区在线| 欧美一区二区三区播放老司机| 精品黑人一区二区三区久久| 国产欧美一区在线| 亚洲综合成人在线| 男人的天堂久久精品| 国产大陆精品国产| 精品视频一区二区不卡| 久久久另类综合| 亚洲国产日韩一级| 精品一区免费av| 一本大道综合伊人精品热热| 日韩一区二区影院| 国产精品成人午夜| 免费观看91视频大全| bt7086福利一区国产| 欧美久久久一区| 中文字幕乱码亚洲精品一区| 亚洲高清中文字幕| 不卡的看片网站| 亚洲你懂的在线视频| 日本三级韩国三级欧美三级| 91在线国产观看| 久久亚洲综合av| 亚洲国产成人91porn| 菠萝蜜视频在线观看一区| 5月丁香婷婷综合| 自拍av一区二区三区| 裸体歌舞表演一区二区| 色呦呦日韩精品| 中文字幕中文字幕一区二区| 精品一区二区三区在线播放视频| 在线观看亚洲精品视频| 国产精品免费免费| 国内精品伊人久久久久av影院| 欧美三级午夜理伦三级中视频| 欧美国产精品劲爆| 国产一区欧美一区| 精品区一区二区| 婷婷开心激情综合| 欧美人与性动xxxx| 午夜伦欧美伦电影理论片| 91成人看片片| 夜夜精品浪潮av一区二区三区| 国产91丝袜在线观看| 久久精品视频免费观看| 美腿丝袜亚洲一区| 91精品国产综合久久小美女| 亚洲高清视频在线| 欧美性猛片xxxx免费看久爱| 夜夜嗨av一区二区三区| 一本色道久久综合亚洲91 | 日韩欧美一卡二卡| 亚洲一区二区三区视频在线| 91视频免费播放| 一区二区三区在线看| 欧美性猛交一区二区三区精品 | 亚洲成人免费视| 欧美精品在欧美一区二区少妇 | 5566中文字幕一区二区电影| 亚洲国产wwwccc36天堂| 欧美精品一级二级| 久草精品在线观看| 久久久久久久久久久99999| 国产高清无密码一区二区三区| 国产午夜亚洲精品理论片色戒| 国产盗摄女厕一区二区三区 | 91激情在线视频| 午夜久久福利影院| 精品福利视频一区二区三区| 国产乱对白刺激视频不卡| 国产精品国产三级国产普通话蜜臀| 成年人午夜久久久| 一区二区三区欧美日韩| 在线电影国产精品| 国精产品一区一区三区mba桃花| 久久美女艺术照精彩视频福利播放 | 国产精品五月天| 色综合天天综合在线视频| 男人的j进女人的j一区| 国产欧美视频一区二区| 91丨porny丨最新| 日韩精品亚洲专区| 欧美激情综合在线| 欧美日韩精品一区二区三区四区| 免费看欧美美女黄的网站| 欧美国产乱子伦| 7799精品视频| 成人av网在线| 日本不卡免费在线视频| 精品成人免费观看| 色综合天天视频在线观看| 日韩黄色小视频| 中文字幕日韩一区二区| 日韩三级在线观看| 91搞黄在线观看| 精品一区二区久久久| 亚洲国产另类精品专区| 国产精品女同互慰在线看| 8x福利精品第一导航| 一本一道久久a久久精品 | 国产精品成人免费| 久久久久久麻豆| 91麻豆精品国产自产在线观看一区 | 欧美xxxxx牲另类人与| 99精品视频中文字幕| 九九视频精品免费| 三级久久三级久久久| 一区二区三区中文字幕| 中文字幕国产精品一区二区| 欧美变态tickling挠脚心| 欧美色图第一页| 精品电影一区二区| 91原创在线视频| 国产成人精品一区二区三区网站观看 | 国产精品伦理在线| 国产日韩欧美激情| 久久婷婷国产综合国色天香| 777a∨成人精品桃花网| 欧美色成人综合| 欧美日韩国产经典色站一区二区三区| 成人综合婷婷国产精品久久免费| 国产美女一区二区| 精品一区二区在线看| 久久爱另类一区二区小说| 免费不卡在线观看| 免费在线视频一区| 免费看欧美女人艹b| 久久99热这里只有精品| 久久99精品国产麻豆婷婷| 免费在线观看不卡| 九九视频精品免费| 精品影视av免费| 国产伦精品一区二区三区免费| 久久精品国产精品亚洲精品| 蜜臀av性久久久久蜜臀aⅴ| 欧美一区欧美二区| 色999日韩国产欧美一区二区| 大胆亚洲人体视频| av在线一区二区三区| 91首页免费视频| 91久久精品一区二区| 欧美日韩国产一级片| 91麻豆精品国产无毒不卡在线观看| 在线成人午夜影院| 久久久久久久性| 日本一区二区三区国色天香| 亚洲欧美偷拍另类a∨色屁股| 亚洲精品国产视频| 亚洲高清免费观看高清完整版在线观看 | 国产欧美精品一区二区色综合 | 亚洲高清在线精品| 免费成人性网站| 豆国产96在线|亚洲| 在线影院国内精品| 欧美一区二区女人| 精品国产乱码久久久久久浪潮| 国产亚洲欧洲997久久综合| 综合欧美亚洲日本| 亚洲成人一二三| 国产成人亚洲综合色影视| 91麻豆swag| 欧美一区二区三区视频免费播放| 久久久噜噜噜久久中文字幕色伊伊| 成人免费在线播放视频| 日韩精品一区第一页| 北岛玲一区二区三区四区| 欧美在线视频全部完| 337p粉嫩大胆噜噜噜噜噜91av| 亚洲日本在线观看| 久久se精品一区精品二区| 欧美伊人久久久久久久久影院| 久久综合久久综合亚洲| 亚洲国产sm捆绑调教视频| 成人性生交大片免费| 正在播放亚洲一区|