コード例 #1
0
ファイル: Main.java プロジェクト: OrgLaridae/WRFServer
  private static void runWRF(ArrayList<Boundary> boundaryArray) {
    ArrayList<Double> clusterTimeArray = new ArrayList<>();
    WRFEnvironment wrfEnvironment = new WRFEnvironment();
    for (int i = 0; i < boundaryArray.size(); i++) {
      long startCluster = System.currentTimeMillis();
      boundary = boundaryArray.get(i);
      // System.out.println(boundary.getMinLatitude()+" "+boundary.getMaxLatitude()+"
      // "+boundary.getMinLongitude()+" "+boundary.getMaxLongitude());
      wrfEnvironment.setRef_lat(NamelistCalc.get_refLat(boundary));
      wrfEnvironment.setRef_lon(NamelistCalc.get_refLon(boundary));

      //            wrfEnvironment.setPole_lat(NamelistCalc.get_pole_lat(boundary));
      //            wrfEnvironment.setPole_lon(NamelistCalc.get_pole_lon());
      //            wrfEnvironment.setStand_lon(NamelistCalc.get_standard_lon(boundary));
      //            wrfEnvironment.setMap_proj("lat-lon");
      //            wrfEnvironment.setDx(0.26);//default : 30000
      //            wrfEnvironment.setDy(0.26);
      //            wrfEnvironment.setResolution(0.26);
      wrfEnvironment.setE_sn(
          String.valueOf(NamelistCalc.get_e_ns(boundary, (int) wrfEnvironment.getResolution())));
      wrfEnvironment.setE_we(
          String.valueOf(NamelistCalc.get_e_we(boundary, (int) wrfEnvironment.getResolution())));

      runScript = new RunScript();

      // initially change the namelist.wps and namelist.input files according to the parameters set
      runScript.changeNamelistWPS(
          wrfEnvironment.getInputWPSPath(),
          wrfEnvironment.getStartDate(),
          wrfEnvironment.getEndDate(),
          wrfEnvironment.getMaxDom(),
          wrfEnvironment.getIntervalSeconds(),
          wrfEnvironment.getE_we(),
          wrfEnvironment.getE_sn(),
          wrfEnvironment.getGeo_data_path(),
          wrfEnvironment.getPrefix(),
          wrfEnvironment.getRef_lat(),
          wrfEnvironment.getRef_lon(),
          wrfEnvironment.getPole_lat(),
          wrfEnvironment.getPole_lon(),
          wrfEnvironment.getStand_lon(),
          wrfEnvironment.getMap_proj(),
          wrfEnvironment.getDx(),
          wrfEnvironment.getDy());
      runScript.changeNamelipsInput(
          wrfEnvironment.getNamelistWRFPath(),
          wrfEnvironment.getRunDays(),
          wrfEnvironment.getRunHours(),
          wrfEnvironment.getStartYear(),
          wrfEnvironment.getStartMonth(),
          wrfEnvironment.getStartDay(),
          wrfEnvironment.getStartHour(),
          wrfEnvironment.getEndYear(),
          wrfEnvironment.getEndMonth(),
          wrfEnvironment.getEndtDay(),
          wrfEnvironment.getEndHour(),
          wrfEnvironment.getIntervalSeconds(),
          wrfEnvironment.getMaxDom(),
          wrfEnvironment.getE_we(),
          wrfEnvironment.getE_sn(),
          wrfEnvironment.getNum_metgrid_levels(),
          wrfEnvironment.getNum_metgrid_soil_levels(),
          wrfEnvironment.getDx(),
          wrfEnvironment.getDy());

      // run the WRF using the shell scripts
      runScript.runScript("sh /home/ruveni/IdeaProjects/Laridae/src/WRF/autoauto.sh");
      long endCluster = System.currentTimeMillis();
      double clusterTime = (endCluster - startCluster) / 1000.0;
      clusterTimeArray.add(clusterTime);

      // find a file name with wrfout_d01_2006-12-19_12:00:00
      File dir = new File(wrfEnvironment.getTest_em_real_path());
      File[] foundFiles =
          dir.listFiles(
              (dir1, name) -> {
                return name.startsWith("wrfout_");
              });

      if (foundFiles.length >= 1) {
        File oldName = new File(foundFiles[0].getPath());
        File newName = new File(wrfEnvironment.getTest_em_real_path() + "wrfOut" + (i + 1));
        if (oldName.renameTo(newName)) {
          System.out.println("renamed");
        } else {
          System.out.println("Error");
        }
      }
    }
    for (int i = 0; i < clusterTimeArray.size(); i++) {
      System.out.println("Cluster " + (i + 1) + " : " + clusterTimeArray.get(i));
    }
  }
コード例 #2
0
ファイル: Main.java プロジェクト: OrgLaridae/WRFServer
  public void runScenarioOne() {
    WRFEnvironment wrfEnvironment = new WRFEnvironment();
    long start = System.currentTimeMillis();
    double wrfTime = 0;

    wrfEnvironment.setE_sn("75");
    wrfEnvironment.setE_we("70");

    runScript = new RunScript();

    // initially change the namelist.wps and namelist.input files according to the parameters set
    runScript.changeNamelistWPS(
        wrfEnvironment.getInputWPSPath(),
        wrfEnvironment.getStartDate(),
        wrfEnvironment.getEndDate(),
        wrfEnvironment.getMaxDom(),
        wrfEnvironment.getIntervalSeconds(),
        wrfEnvironment.getE_we(),
        wrfEnvironment.getE_sn(),
        wrfEnvironment.getGeo_data_path(),
        wrfEnvironment.getPrefix(),
        wrfEnvironment.getRef_lat(),
        wrfEnvironment.getRef_lon(),
        wrfEnvironment.getPole_lat(),
        wrfEnvironment.getPole_lon(),
        wrfEnvironment.getStand_lon(),
        wrfEnvironment.getMap_proj(),
        wrfEnvironment.getDx(),
        wrfEnvironment.getDy());
    runScript.changeNamelipsInput(
        wrfEnvironment.getNamelistWRFPath(),
        wrfEnvironment.getRunDays(),
        wrfEnvironment.getRunHours(),
        wrfEnvironment.getStartYear(),
        wrfEnvironment.getStartMonth(),
        wrfEnvironment.getStartDay(),
        wrfEnvironment.getStartHour(),
        wrfEnvironment.getEndYear(),
        wrfEnvironment.getEndMonth(),
        wrfEnvironment.getEndtDay(),
        wrfEnvironment.getEndHour(),
        wrfEnvironment.getIntervalSeconds(),
        wrfEnvironment.getMaxDom(),
        wrfEnvironment.getE_we(),
        wrfEnvironment.getE_sn(),
        wrfEnvironment.getNum_metgrid_levels(),
        wrfEnvironment.getNum_metgrid_soil_levels(),
        wrfEnvironment.getDx(),
        wrfEnvironment.getDy());

    // run the WRF using the shell scripts
    runScript.runScript("sh /home/ruveni/IdeaProjects/Laridae/src/WRF/autoauto.sh");

    // find a file name with wrfout_d01_2006-12-19_12:00:00
    File dir = new File(wrfEnvironment.getTest_em_real_path());
    File[] foundFiles =
        dir.listFiles(
            (dir1, name) -> {
              return name.startsWith("wrfout_");
            });

    if (foundFiles.length >= 1) {
      File oldName = new File(foundFiles[0].getPath());
      File newName = new File(wrfEnvironment.getTest_em_real_path() + "wrfOutScenario1");
      if (oldName.renameTo(newName)) {
        System.out.println("renamed");
      } else {
        System.out.println("Error");
      }
    }

    long end = System.currentTimeMillis();
    wrfTime = (end - start) / 1000.0;
    System.out.println("WRF Time without Preprocessing Data : " + wrfTime + " seconds");
  }