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

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? vergleich.py

?? Sfdtd Simple finite-difference time-domain
?? PY
字號:
# vergleich.py## Some comparison of vergleich*.plt, verlauf*.plt, cube*.data # and poynting*.data output files from Sfdtd## (This is a quite dirty python code... )##    Copyright (C) 2007  Paul Panserrieu, < peutetre@cs.tu-berlin.de >##    This program is free software: you can redistribute it and/or modify#    it under the terms of the GNU General Public License as published by#    the Free Software Foundation, either version 3 of the License.## last modified: 26-10-2007 05:59:54 PM CESTimport ostry:    import Numericexcept ImportError:    import sys    # if you have installed Numeric in a different directory, change the path    sys.path.append('/home/p/peutetre/bin/lib/python/Numeric')    try:        import Numeric    except ImportError:        print "Numeric module not available..."        passprint """ >~~~~~~~~~~~~~~~~>>~~~~~~~~>>>~~~~~~~~>>>> """print """ python vergleich.py """print """ Vergleich von Dateien aus Sfdtd """print """ Comparison of files from Sfdtd """print """ Paul Panserrieu <peutetre@cs.tu-berlin.de> """print """ >~~~~~~~~~~~~~~~~>>~~~~~~~~>>>~~~~~~~~>>>> """file_id_1 = '_1_vergleich_%s_00%i0%i.plt'file_id_2 = '_2_vergleich_%s_00%i0%i.plt'verlauf_id_1 = '_1_verlauf2d_%s_0090%i.plt'rela_id_1 = '_1_rela_%s_0090%i.plt'def w():    print os.getcwd()def l():    print os.listdir('.')def cd(path='~'):    os.chdir(path)def up():    os.chdir('..')def down():    files = os.listdir('.')     dirs = []    for i in files:      if os.path.isdir(i):          dirs.append(i)    n = 0    for i in dirs:        print n, i        n += 1    if n > 0:        print 'change dir to ?'        n = raw_input(':  ')        if n in range(0, len(dirs)):            os.chdir(os.getcwd() + '/' + str(dirs[n]))class curve:    def __init__(self):        self.data = dict()        self.scale = dict()        self.title = ""        return None    def __repr__(self):        chaine = "keys: \n"        for i in self.data.keys():            if i != self.data.keys()[-1]:                 chaine += ' %s\n' %(i)            else:                chaine += ' %s' %(i)        return chaine    def show(self, key):        return self.data[key]    def set_scale(self, key, factor):        if self.data.has_key(key):            self.scale[key] = factor            return None        else:            return None      def set_title(self, title):        self.title = title    def write(self, key_list, file_name, line_title=""):        for i in key_list:            if not self.data.has_key(i):                print 'key %s does not exist' %i                return None        try:            f = open(file_name, 'w')        except IOError:            print "does not manage to create file %s" % file_name            return None                f.write("$ DATA = CURVE2D \n")        f.write("%"+" toplabel= '%s' \n" % self.title)        f.write("% xlabel= 'time-step'\n")        f.write("% ylabel= ' ' \n")        a = 1        for i in key_list:            if line_title != "" and int(i.split('_')[1]) == 1:                f.write("%"+" linelabel = %s \n" % line_title)            else:                try:                    f.write("%"+" linelabel = %s \n" % i.split('_')[3])                except IndexError:                    f.write("%"+" linelabel = %s \n" % i)            f.write("%"+" linecolor = %i linetype = 1 \n" % a)            b = 0; scale = 1.0            if i in self.scale.keys():                scale = self.scale[i]            for j in self.data[i]:                f.write("%i  %s\n" %(b*scale, j))                b += 1            f.write("\n")            a += 1        f.write(" $END \n")        f.close()    def read(self, file_name):        try:            f = open(file_name, 'r')        except IOError:            print "%s cannot be opened..." % file_name            return 13        chaine = ""        self.data['_1_' + file_name] = []        for i in range(1,9):             chaine = f.next()        while not chaine.startswith('\n') or chaine.find('$') == -1:            try:                try:                    self.data['_1_' + file_name].append(float(chaine.split()[-1]))                    chaine = f.next()                except ValueError:                    break            except IndexError:                break        if chaine.startswith(' $ END'):            return None        else:            self.data['_2_' + file_name] = []            for i in range(1,4):                chaine = f.next()            while chaine.find('$') == -1:                try:                    self.data['_2_' + file_name].append(float(chaine.split()[-1]))                    chaine = f.next()                except IndexError:                    break        f.close()        return None    def add(self, array_id, array):        self.data[array_id]=array    def find_max(self, array_id, offset = 0):        if array_id in self.data.keys():            pass        else: return None        tmp = 0.0e0        for i in self.data[array_id][offset:]:            if abs(float(i)) > abs(tmp):                tmp = float(i)        return tmp      def subtract(self, first_id, second_id, new_id):        if (len(self.data[first_id]) == len(self.data[second_id])):            pass        else:            print '%s and %s do not have the same size' %(first_id, second_id)            return None        tmp = []        first = self.show(first_id)        second = self.show(second_id)                for i in range(0, len(first)):            tmp.append(first[i]-second[i])        self.add(new_id, tmp)        return None    def sub_rela(self, first_id, second_id, new_id, maxi):        if (len(self.data[first_id]) == len(self.data[second_id])):            pass        else:            print '%s and %s do not have the same size' %(first_id, second_id)            return None        tmp = []        first = self.show(first_id)        second = self.show(second_id)        for i in range(0, len(first)):            tmp.append(100.0*abs(first[i]-second[i])/maxi)        self.add(new_id, tmp)        return None     def norm(self, d, new_id):        tmp = []        first = self.show(d)        maxi = self.find_max(d)        for i in first:            tmp.append(i/maxi)        self.add(new_id, tmp)        def error_1(offset=0):    """ local error: numerical result v.s. analytical solution """    a = os.listdir('.')    files = []    for i in a:        if i.endswith('.plt') and i.startswith('ver'):            files.append(i)    del(a)    ids = []    for i in files:        tmp = i.split('_')[1]        if tmp not in ids:            ids.append(tmp)    f = curve()    maxi = dict()    for i in files:        f.read(i)    for j in [1,2]:        for k in [1,2,3]:            plots = []            for i in ids:                if ids.index(i) == 0:                    plots.append(file_id_1%(i,j,k))                    maxi[file_id_1%(i,j,k)]=\                    (f.find_max(file_id_1%(i,j,k), offset))                    plots.append(file_id_2%(i,j,k))                else:                    maxi[file_id_1%(i,j,k)]=\                    (f.find_max(file_id_1%(i,j,k), offset))                    plots.append(file_id_2%(i,j,k))            f.write(plots, 'all_%i0%i.plt'%(j,k), 'analytic')             for k in range(1,6):        plots = []        for i in ids:            tmp = f.show(verlauf_id_1%(i,k))            tmp1 = []            for j in tmp:                tmp1.append(100.0*abs(j)\                            /abs(maxi[file_id_1%(i,oups(k),chut(k))]))            f.add(rela_id_1%(i,k), tmp1)            plots.append(rela_id_1%(i,k))            if k == 3:                print 'abso', i, f.find_max(verlauf_id_1%(i,k),offset)                print 'rela', i, f.find_max(rela_id_1%(i,k), offset)        f.write(plots, 'all_error_rela_analytic_1_90%i.plt'%(k))    return Nonedef error_1_bis(ref_id, abso = 1):    """ local error: numerical result v.s. reference solution """    a = os.listdir('.')    files = []    for i in a:        if i.endswith('.plt') and i.startswith('vergleich'):            files.append(i)    del(a)    ids = []    for i in files:        tmp = i.split('_')[1]        if tmp not in ids:            ids.append(tmp)    if ref_id not in ids:        print 'ref_id:%s is not available' % ref_id        return 13    f = curve()    for i in files:        f.read(i)    for j in [1,2]:        for k in [1,2,3]:            plots = []            for i in ids:                if i == ref_id:                    if abso == 1:                        pass                    else:                        maxi = 0.0                        for l in f.show(file_id_2%(ref_id,j,k)):                            if abs(l) > maxi: maxi = abs(l)                else: pass            for i in ids:                if i !=  ref_id:                    if abso == 1:                        f                        f.subtract(  file_id_2%(i,j,k)\                                   , file_id_2%(ref_id,j,k)\                                   , 'sub_%s_00%i0%i.plt'%(i,j,k) )                          plots.append('sub_%s_00%i0%i.plt'%(i,j,k))                    else:                        f.sub_rela(  file_id_2%(i,j,k)\                                   , file_id_2%(ref_id,j,k)\                                   , 'sub_%s_00%i0%i.plt'%(i,j,k)\                                   , maxi )                        plots.append('sub_%s_00%i0%i.plt'%(i,j,k))                else:                    pass            if abso == 1:                f.write(plots, 'sub_abs_%i0%i.plt'%(j,k))            else:                f.write(plots, 'sub_rela_%i0%i.plt'%(j,k))    return None            class cube:    def __init__(self):        self.limit = 0        return None    def read(self, file_name):        try:            f = open(file_name, 'r')        except IOError:            print "%s cannot be opened..." % file_name            return 13        self.limit = int(f.next())        self.data = Numeric.zeros((2*self.limit+1 \                                 , 2*self.limit+1 \                                 , 2*self.limit)  \                                 , typecode='fd')        f.next()        for k in range(-self.limit, self.limit):            for j in range(-self.limit, self.limit+1):                for i in range(-self.limit, self.limit+1):                    self.data[i][j][k] = float(f.next().split()[-1])        f.close()        return Nonedef error_2(ref_id):    """ global error: numerical result v.s. reference solution """    a = os.listdir('.')    files = []    for i in a:        if i.endswith('.data') and i.startswith('cube'):            files.append(i)    del(a)    files.sort()    ids = []    for i in files:        tmp = i.split('_')[1]        if not tmp in ids:            ids.append(tmp)    if ref_id not in ids:        print 'ref_id:%s is not available' % ref_id        return 13    maxi = dict()    for i in ids:        maximum = 0        for j in files:            if j.split('_')[1] == i:                if int(j.split('_')[-1].split('.')[0]) > maximum:                    maximum = int(j.split('_')[-1].split('.')[0])        maxi[i] = maximum    max_timestep = min(maxi.values())    ids.remove(ref_id)    data = dict()    print "available ids: %s" %ids    max_ref=[]    for t in range(1, max_timestep+1):        ref = cube()        ref.read('cube_%s_%s.data' %(ref_id, str(t).zfill(5)))        tmp1 = 0.0        for i in range(-ref.limit, ref.limit+1):                for j in range(-ref.limit, ref.limit+1):                    for k in range(-ref.limit, ref.limit):                        tmp1 += pow(ref.data[i][j][k],2)        max_ref.append(tmp1)        for d in ids:            tmp = cube()            tmp.read('cube_%s_%s.data' %(d, str(t).zfill(5)))            value = 0.0            for i in range(-ref.limit, ref.limit+1):                for j in range(-ref.limit, ref.limit+1):                    for k in range(-ref.limit, ref.limit):                        value += pow(tmp.data[i][j][k] - ref.data[i][j][k],2)            del(tmp)            if t == 1:                data[d] = [0.0]            data[d].append(value)        del(ref)        print "time step %i done" %t    m_ref = max(max_ref)    for d in ids:        tmp = []        for n in data[d]:            tmp.append(100.0*n/m_ref)        data[d] = tmp    plot = curve()    for d in data.keys():        plot.add(d,data[d])    plot.write(data.keys(), 'global_error.plt')    del(plot)    return Nonedef chut(a):  if a < 4: return a  else: return a-3def oups(a):  if a in [1,2,3]: return 1  else: return 2class fluss:    def __init__(self):        self.data = []        return None    def read(self, file_name):        try:            f = open(file_name, 'r')        except IOError:            print "%s cannot be opened..." % file_name            return 13        f.next()        tmp = f.next()        self.data.append(float(tmp.split()[-1]))        f.close()        return Nonedef error_3(ref_id):    """ energy flow error: numerical result v.s. reference solution """    a = os.listdir('.')    files = []    for i in a:        if i.endswith('.data') and i.startswith('poynting'):            files.append(i)    del(a)    files.sort()    ids = []    for i in files:        tmp = i.split('_')[1]        if not tmp in ids:            ids.append(tmp)    if ref_id not in ids:        print 'ref_id:%s is not available' % ref_id        return 13    maxi = dict()    for i in ids:        maximum = 0        for j in files:            if j.split('_')[1] == i:                if int(j.split('_')[-1].split('.')[0]) > maximum:                    maximum = int(j.split('_')[-1].split('.')[0])        maxi[i] = maximum    max_timestep = min(maxi.values())    ids.remove(ref_id)    data = dict()    print "available ids: %s" %ids    max_ref= 0.0    ref = fluss()    ref_data = []    result = dict()    for t in range(0, max_timestep):        ref.read('poynting_%s_%s.data' %(ref_id, str(t).zfill(5)))        if abs(ref.data[t]) > abs(max_ref):            max_ref = ref.data[t]    print ref_id, 'max abs(flow):', max_ref    ref_data = ref.data    del(ref)    for d in ids:        tmp = fluss()        for t in range(0, max_timestep):            tmp.read('poynting_%s_%s.data' %(d, str(t).zfill(5)))        data[d] = tmp.data         del(tmp)    for d in ids:        tmp = []        for t in range(0, max_timestep):            tmp.append(100.0*abs(data[d][t] - ref_data[t])/abs(max_ref))        result[d] = tmp        print d, max(result[d])    plot = curve()    for d in result.keys():        plot.add(d,result[d])    plot.write(result.keys(), 'energy_error.plt')    del(plot)    return None

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲精品成人在线| 亚洲欧洲性图库| 91在线视频在线| 天堂一区二区在线| 国产精品国产三级国产专播品爱网| 欧美性猛交xxxxxx富婆| 国产在线不卡视频| 七七婷婷婷婷精品国产| 亚洲欧美精品午睡沙发| 久久这里只有精品6| 欧美精品高清视频| 99免费精品在线| 国产精选一区二区三区| 亚洲大片精品永久免费| ●精品国产综合乱码久久久久| 日韩午夜电影av| 欧美日韩国产另类一区| 91免费在线看| 波多野结衣精品在线| 韩国三级在线一区| 免费高清成人在线| 免费高清不卡av| 偷拍与自拍一区| 亚洲h精品动漫在线观看| 亚洲另类中文字| 亚洲人一二三区| 国产精品成人免费精品自在线观看| 久久一区二区视频| 精品成人佐山爱一区二区| 日韩一区二区三区三四区视频在线观看 | 国产成人aaa| 精品一区二区三区香蕉蜜桃| 亚洲成av人影院在线观看网| 亚洲精品国产精品乱码不99| 国产精品电影一区二区三区| 国产精品国产三级国产| 亚洲丝袜美腿综合| 亚洲欧美在线另类| 亚洲三级免费观看| 国产精品久久精品日日| 国产精品不卡视频| 亚洲女同ⅹxx女同tv| 亚洲欧美电影一区二区| 一区二区三区在线观看欧美| 亚洲一区二区不卡免费| 亚洲综合色噜噜狠狠| 午夜精品久久久久久久99水蜜桃| 亚洲高清在线精品| 蜜桃一区二区三区在线| 精品一区二区在线视频| 国产激情偷乱视频一区二区三区| 国产黄色精品网站| 色综合一区二区| 69成人精品免费视频| 欧美一卡二卡三卡| 精品国产一二三| 亚洲国产精品ⅴa在线观看| 成人欧美一区二区三区小说| 亚洲一区二区精品3399| 麻豆精品视频在线观看| 国产福利电影一区二区三区| 色婷婷久久综合| 欧美日韩国产成人在线免费| 欧美一区二区三区在线电影| 欧美mv日韩mv国产网站app| 国产精品系列在线| 亚洲自拍偷拍网站| 国产在线不卡一卡二卡三卡四卡| 国产v日产∨综合v精品视频| 欧洲一区二区三区免费视频| 日韩欧美你懂的| 国产精品高潮呻吟| 午夜激情一区二区三区| 国产资源在线一区| 色狠狠一区二区三区香蕉| 91精品国产入口在线| 国产亚洲综合色| 一区二区成人在线观看| 紧缚奴在线一区二区三区| 成人久久视频在线观看| 在线91免费看| 国产精品午夜在线观看| 秋霞影院一区二区| 99精品欧美一区二区蜜桃免费 | 久久精品男人的天堂| 一区二区三区成人| 韩国视频一区二区| 欧美天天综合网| 久久婷婷综合激情| 舔着乳尖日韩一区| www.成人在线| 欧美一区二区日韩| 亚洲精品视频免费看| 老司机午夜精品| 日本精品免费观看高清观看| 久久天堂av综合合色蜜桃网| 亚洲成av人片一区二区| 粉嫩av一区二区三区在线播放| 91精品麻豆日日躁夜夜躁| 国产精品久久久久一区二区三区 | 日本韩国欧美一区| 久久中文字幕电影| 日韩电影一二三区| 在线免费不卡电影| 国产精品无人区| 久久99蜜桃精品| 欧美一区二区三区男人的天堂| 亚洲精品亚洲人成人网| 国产.精品.日韩.另类.中文.在线.播放| 欧美日韩一级黄| 一区二区三区在线高清| 成人白浆超碰人人人人| 久久精品人人做| 国产一区二区在线看| 欧美一级理论片| 五月开心婷婷久久| 欧美三电影在线| 亚洲激情欧美激情| 91成人免费在线| 亚洲人成影院在线观看| 不卡一区二区三区四区| 精品国产一区二区国模嫣然| 蜜臀av一区二区| 日韩欧美在线影院| 天堂蜜桃91精品| 欧美精品aⅴ在线视频| 亚洲成a人v欧美综合天堂| 在线观看国产一区二区| 亚洲欧美激情插| 色哟哟在线观看一区二区三区| 国产精品人人做人人爽人人添| 国产成人精品1024| 久久久久9999亚洲精品| 国产激情精品久久久第一区二区 | 亚洲三级电影网站| av男人天堂一区| 最新成人av在线| 一本色道久久综合亚洲aⅴ蜜桃| 自拍视频在线观看一区二区| 色综合久久综合网欧美综合网| 亚洲天堂免费看| 欧美午夜精品一区二区蜜桃| 夜夜亚洲天天久久| 欧美日韩在线亚洲一区蜜芽| 亚洲福利电影网| 日韩一区二区三区电影 | 国产a久久麻豆| 国产精品美女久久久久aⅴ| 成人免费视频播放| 一区二区三区资源| 欧美精品日日鲁夜夜添| 九九**精品视频免费播放| 久久丝袜美腿综合| 成人丝袜高跟foot| 亚洲色图.com| 7777精品伊人久久久大香线蕉的 | 在线观看国产91| 图片区小说区区亚洲影院| 日韩欧美电影一区| 国产精品自拍在线| 亚洲欧美日韩成人高清在线一区| 色婷婷综合久久久久中文| 亚洲va韩国va欧美va| 欧美刺激午夜性久久久久久久| 韩国v欧美v日本v亚洲v| 中文字幕久久午夜不卡| 色狠狠桃花综合| 男女性色大片免费观看一区二区 | 日韩精品一二三| 精品黑人一区二区三区久久| 成人美女在线视频| 天堂一区二区在线免费观看| 久久久久88色偷偷免费| 色综合一区二区三区| 蜜臀av一区二区| 亚洲精选一二三| 精品区一区二区| 91色porny在线视频| 蜜臀久久久99精品久久久久久| 国产日产精品1区| 精品视频全国免费看| 国产suv精品一区二区6| 日日夜夜精品视频免费| 国产偷国产偷亚洲高清人白洁 | 久久电影国产免费久久电影| 中文字幕乱码一区二区免费| 欧美日本一道本| 成人免费视频网站在线观看| 午夜欧美在线一二页| 欧美国产视频在线| 日韩一区二区三区电影 | 在线一区二区三区四区五区| 裸体健美xxxx欧美裸体表演| 中文字幕在线一区免费| 欧美一区二区高清| 色婷婷亚洲婷婷| 国产盗摄女厕一区二区三区| 青青草国产成人av片免费| 亚洲男人电影天堂| 欧美激情在线看|