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

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

?? simpledispatchrule.java

?? 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一区二区三区免费野_久草精品视频
国内精品伊人久久久久影院对白| 国产精品视频一二三| 99精品国产视频| 床上的激情91.| 日本高清无吗v一区| 99视频精品免费视频| 成人免费看的视频| 97久久超碰国产精品| 色综合天天做天天爱| av男人天堂一区| youjizz国产精品| gogo大胆日本视频一区| 97超碰欧美中文字幕| 色综合中文字幕国产 | 麻豆国产欧美一区二区三区| 日韩成人av影视| 老司机一区二区| 国产精品自拍毛片| 成人高清视频免费观看| 色婷婷久久综合| 欧美一区二区大片| 久久久久久久久一| 亚洲精品一二三| 美国毛片一区二区| 国产a精品视频| 欧美日韩国产一级二级| 精品国产一区二区精华| 1区2区3区欧美| 青青草原综合久久大伊人精品| 久久精品国产77777蜜臀| 成人免费毛片片v| 欧美亚洲国产一区在线观看网站| 欧美日韩的一区二区| 久久这里只有精品6| 亚洲黄色小说网站| 精品一区二区三区香蕉蜜桃| 91蜜桃视频在线| 精品剧情在线观看| 一区二区三区日韩精品视频| 捆绑紧缚一区二区三区视频| 91美女福利视频| 精品久久一二三区| 亚洲一区二区三区激情| 国产夫妻精品视频| 欧美精品第1页| 国产精品国产三级国产a| 全国精品久久少妇| 91浏览器在线视频| 久久久国产一区二区三区四区小说 | 成人丝袜高跟foot| 日韩一二在线观看| 亚洲午夜在线电影| proumb性欧美在线观看| 欧美mv和日韩mv的网站| 一二三四社区欧美黄| 粉嫩aⅴ一区二区三区四区五区| 欧美日本韩国一区| 亚洲精品国产视频| 成人免费视频app| 国产日韩欧美精品一区| 精品一区二区精品| 欧美日产国产精品| 亚洲高清不卡在线| 91精品办公室少妇高潮对白| 国产精品欧美一区二区三区| 久久99国产精品尤物| 在线成人av影院| 午夜精品久久久久久久久久| 91美女精品福利| 亚洲免费观看在线观看| 成人性色生活片免费看爆迷你毛片| 欧美岛国在线观看| 日本三级亚洲精品| 91麻豆精品国产自产在线观看一区 | 2020日本不卡一区二区视频| 日韩精品福利网| 欧美电影在线免费观看| 视频在线观看国产精品| 欧美日韩免费不卡视频一区二区三区| 亚洲日本在线观看| 色综合久久天天| 亚洲一区国产视频| 欧美亚洲动漫精品| 丝袜美腿亚洲色图| 精品久久久久99| 国产成人在线视频免费播放| 国产亚洲精品中文字幕| 不卡一区中文字幕| 亚洲精品久久久蜜桃| 色久优优欧美色久优优| 亚洲国产美国国产综合一区二区| 欧美日韩一区二区三区在线看| 亚洲福中文字幕伊人影院| 欧美精品亚洲一区二区在线播放| 日本vs亚洲vs韩国一区三区二区| 日韩女优制服丝袜电影| 国产成人福利片| 亚洲女爱视频在线| 538在线一区二区精品国产| 美女视频黄久久| 国产欧美视频一区二区三区| 色综合久久久久久久久| 秋霞电影网一区二区| 亚洲国产精品精华液2区45| 色综合激情五月| 久久精品国产精品亚洲红杏 | 色中色一区二区| 奇米影视一区二区三区小说| 久久久99久久精品欧美| 91久久线看在观草草青青| 全国精品久久少妇| 亚洲日本va在线观看| 欧美一区二区三区在线| 成人性生交大片免费看中文| 午夜精品在线视频一区| 欧美激情综合网| 欧美片在线播放| 处破女av一区二区| 肉色丝袜一区二区| 成人欧美一区二区三区白人| 欧美一区二区三区思思人| 99久久亚洲一区二区三区青草| 日韩激情一区二区| 亚洲图片激情小说| 久久嫩草精品久久久精品| 欧美中文字幕不卡| 一区二区三区四区在线| 日本福利一区二区| 国产精品69久久久久水密桃| 日一区二区三区| 国产精品久久久久久久浪潮网站| 91精品国产色综合久久| 色先锋久久av资源部| 国产成人自拍在线| 精品在线免费视频| 三级欧美在线一区| 亚洲国产一区二区视频| 中文字幕一区二区三区在线观看| 亚洲精品成人天堂一二三| 2023国产一二三区日本精品2022| 欧美日韩在线播| 日本电影亚洲天堂一区| 99精品视频一区| 高清不卡一二三区| 国产精品亚洲а∨天堂免在线| 美女视频黄频大全不卡视频在线播放| 一个色在线综合| 亚洲一区二区在线免费看| 自拍偷拍国产精品| 亚洲少妇30p| 亚洲免费三区一区二区| 亚洲三级免费观看| 亚洲免费av在线| 一区二区三区国产精品| 亚洲欧美偷拍卡通变态| 亚洲人成影院在线观看| 亚洲免费资源在线播放| 亚洲在线免费播放| 亚洲成人1区2区| 午夜精品在线视频一区| 免费国产亚洲视频| 老司机免费视频一区二区| 精品在线视频一区| 国产成人亚洲综合a∨婷婷图片| 韩国精品主播一区二区在线观看| 久久91精品久久久久久秒播| 九色综合狠狠综合久久| 国产成人av电影免费在线观看| 成人app在线观看| 色老头久久综合| 在线播放日韩导航| 欧美精品一区二区久久婷婷| 国产欧美精品一区aⅴ影院| 中文字幕一区三区| 亚洲国产精品精华液网站| 日韩av一区二区在线影视| 国产麻豆精品95视频| www.99精品| 欧美二区三区91| 久久久精品国产免大香伊| 亚洲欧美影音先锋| 日韩精品福利网| 成人av电影观看| 91精品国产色综合久久不卡蜜臀| 久久久久久久久免费| 亚洲综合视频网| 国产在线国偷精品产拍免费yy| 99精品热视频| 日韩欧美一级在线播放| 中文字幕欧美日本乱码一线二线| 亚洲综合一区二区精品导航| 国产在线视频不卡二| 欧洲一区二区三区在线| www国产亚洲精品久久麻豆| 亚洲乱码中文字幕| 国产美女精品在线| 制服丝袜一区二区三区| 亚洲女厕所小便bbb| 国产999精品久久久久久| 欧美军同video69gay|