コード例 #1
0
ファイル: input_info.py プロジェクト: h0st1le/gapuff
 def get_met(self, center=None, accident_time=None):
     #In test mode, we generate a simple constant field
     if self.test:
         return self.__simple_test()
     elif self.mode == 4:
         return self.__read_wrf(self.dataset, center=self.sourceinfo.position, accident_time=self.sourceinfo.time)
     elif self.mode == 3 or self.mode == 2:
         return self.__load(self.dataset, mode)
     elif self.mode == 1:
         return self.__read_sam(accident_time=self.sourceinfo.time)
     elif self.mode == 0:
         return met_def(0, self.dataset, [7200])
     raise Exception("mode error!")
コード例 #2
0
ファイル: input_info.py プロジェクト: h0st1le/gapuff
 def __complex_test(self):
     MAXLENGTH = HALF_INTERVAL * math.sqrt(2) + 1
     basedata = np.empty((12,GRID_SIZE,GRID_SIZE,4))
     for t in range(12):
         for i in range(GRID_SIZE):
             for j in range(GRID_SIZE):
                 #start variable section
                 grid = basedata[t,i,j];
                 SPEED = int(math.sqrt((i-HALF_INTERVAL)**2 + (j-HALF_INTERVAL)**2) / MAXLENGTH * 5) + 3
                 STAB = 4 - int(math.sqrt((i-HALF_INTERVAL)**2 + (j-HALF_INTERVAL)**2) / MAXLENGTH * 4)
                 ZSPEED = int(math.sqrt((i-HALF_INTERVAL)**2 + (j-HALF_INTERVAL)**2) / MAXLENGTH * 3) + 1
                 ARC = math.pi / 2 / (GRID_SIZE - 1) * i
                 grid[0] = math.sin(ARC) * SPEED + tindex * 0.2 + tindex * 0.1 #U Speed
                 grid[1] = math.cos(ARC) * SPEED + tindex * 0.2 + tindex * 0.1 #V Speed
                 grid[2] = ZSPEED #Z Speed
                 grid[3] = STAB #Stabilities
                 #end variable section
     seq = range(600,7201,600)
     np.savez(self.dataset, data=result, seq=seq)
     return met_def(2, data, seq)
コード例 #3
0
ファイル: input_info.py プロジェクト: h0st1le/gapuff
 def __simple_test(self):
     data = (3,0,0,4)
     seq = [7200]
     return met_def(0, data, seq)
コード例 #4
0
ファイル: input_info.py プロジェクト: h0st1le/gapuff
 def __read_wrf(self, center, accident_time):
     import wrf_processor
     dataset = wrf_processor.wrf_processor(self.dataset)
     data = dataset.read_met(center, accident_time)
     seq = dataset.read_ticks()
     return met_def(2, data, seq)
コード例 #5
0
ファイル: input_info.py プロジェクト: h0st1le/gapuff
 def __load(self, datafile, mode):
     dataset = np.load(datafile)
     data = dataset['data']
     seq = dataset['seq']
     return met_def(mode-1,data,seq)