我的新博客

SOS: gnuplot fdtd的一个问题求助 perl vs python

我用perl和python写了相同功能的一段程序,计算一维fdtd,用gnuplot动态显示,可是python的数据没有显示出来,看横纵坐标的变化数据是正确收到了的,如最后的图片,求大神指点,谢谢。

  1 #!/usr/bin/perl
  2 
  3 # Author : Leon  Email: yangli0534@gmail.com
  4 # fdtd simulation , plotting with gnuplot, writting in perl  
  5 # perl and gnuplot software packages should be installed before running this program
  6 # 1d fdtd with absorbing boundary and TFSF boundary between [49] and [50]
  7 # lossy dielectric material localted at > ez[150]
  8 #use Time::HiRes qw(sleep);
  9 #use autodie qw(:all);
 10 use strict;
 11 use warnings;
 12 
 13 #print "\@\n";
 14 #my $terminal = "";
 15 #    open GNUPLOT_TERM, "echo 'show terminal;' | gnuplot 2>&1 |";
 16 #    while (<GNUPLOT_TERM>) {
 17 #    if (m/terminal type is (\w+)/) {
 18 #        $terminal=$1;
 19 #    }
 20 #    }
 21 #    close GNUPLOT_TERM;
 22 
 23     # unfortunately, the wxt terminal type does not support positioning. 
 24     # hardcode it...
 25 #    $terminal  = "x11";
 26 
 27 open my $PIPE ,"| gnuplot " || die "Can't initialize gnuplot number \n";
 28 
 29 print $PIPE "set size 0.85, 0.85\n";
 30 print $PIPE "set term png size 600, 400\n";
 31 
 32 my $title = "fdtd simulation by leon,yangli0534\\\\@"."gmail.com";
 33 print $PIPE "set terminal gif animate\n";# terminal type: png
 34 print $PIPE "set output \"fdtd_simulation_abc_tfsf_match_diel.gif\"\n";#output file name 
 35 print $PIPE  "set title \"{/Times:Italic $title}\"\n";# title name and font
 36 #print $PIPE  "set title  \"fdtd simulation by leon,yangli0534\\\\@ gmail.com\"\n";# title name and font
 37 print $PIPE  "set title  font \",10\"  norotate tc rgb \"white\"\n";
 38 print $PIPE "unset key\n";
 39 print $PIPE "set tics textcolor rgb \"white\"\n";# text color
 40 print $PIPE "set border lc rgb \"orange\"\n";
 41 print $PIPE "set grid lc rgb\"orange\"\n";
 42 print $PIPE "set object 1 rectangle from screen 0,0 to screen 1,1 fc rgb \"gray10\" behind\n";#background color
 43 print $PIPE "set xlabel\" {/Times:Italic distance: wave length}\" tc rgb \"white\" \n";# xlabel
 44 print $PIPE "set ylabel\"{/Times:Italic amplitude: v}\" tc rgb \"white\"\n";#ylabel
 45 print $PIPE "set autoscale\n"; 
 46 
 47 my $size = 400;#physical distance
 48 my @ez;#electric field
 49 my @hy;#magnetic field
 50 my @ceze;# 
 51 my @cezh;# 
 52 my @chye;# 
 53 my @chyh;# 
 54 my $LOSS_LAYER = 250;
 55 
 56 #my @epsR; 
 57 my $LOSS = 0.01;
 58 my $imp0 = 377.0;
 59 #initalization
 60 for (my $i = 0; $i < $size; $i++){
 61     $ez[$i] = 0.0;
 62     $hy[$i] = 0.0;
 63     if ($i < 100)    {
 64         #$epsR[$i] = 1.0;
 65         $ceze[$i] = 1.0;
 66         $cezh[$i] = $imp0;
 67     }
 68     elsif($i < $LOSS_LAYER){
 69         #$epsR[$i] = 1.0;
 70         $ceze[$i] = 1.0;
 71         $cezh[$i] = $imp0/9.0;
 72     }
 73     else {
 74         #$epsR[$i] = 9.0;
 75         $ceze[$i] = (1.0-$LOSS)/(1.0+$LOSS);
 76         $cezh[$i] = $imp0 / 9 /(1.0+$LOSS); 
 77     } 
 78 } 
 79 
 80 for ( my $i = 0; $i < $size; $i++){
 81     
 82     
 83     if($i < $LOSS_LAYER){
 84         #$epsR[$i] = 1.0;
 85         $chye[$i] = 1.0/$imp0;
 86         $chyh[$i] = 1.0;
 87     }
 88     else {
 89         #$epsR[$i] = 9.0;
 90         $chye[$i] = 1.0/ $imp0 /(1.0+$LOSS);
 91         $chyh[$i] = (1.0-$LOSS)/(1.0+$LOSS); 
 92     } 
 93 } 
 94 my $qTime;
 95 my $MaxTime = 18050;
 96 my $pi = 3.141592563589793;
 97 print $PIPE "set xrange [0:$size-1]\n";
 98 my $mm = 0;
 99 
100 #do time stepping
101 for($qTime = 0; $qTime < $MaxTime; $qTime+=1){
102 
103     # update magnetic field
104     #$hy[$size - 1] = $hy[$size - 2 ];#abc
105     for( $mm = 0; $mm < $size - 1; $mm++){
106         $hy[$mm] = $hy[$mm]*$chyh[$mm] + ($ez[$mm+1] - $ez[$mm])*$chye[$mm];
107     }
108     $hy[49] -=exp(-($qTime - 30.0)*($qTime - 30.0)/100.0)/$imp0;
109     # update electric field
110     $ez[0] = $ez[1];#abc
111     #$ez[$size-1] = $ez[$size-2];
112     for( $mm = 1; $mm < $size-1 ; $mm++){
113         $ez[$mm] = $ez[$mm]*$ceze[$mm] + ($hy[$mm] - $hy[$mm-1])*$cezh[$mm];
114     }
115     
116     if($qTime % 20 == 0){
117 
118         print $PIPE "plot \"-\" w l  lw 1.5 lc rgb \"green\"\n";
119         my $cnt = 0;
120         for my $elem ( @ez) {
121         #print " ".$elem;
122             print $PIPE $cnt." ".$elem."\n";
123             $cnt += 1;
124         }
125         print $PIPE "e\n";
126     } 
127     #hardwire a source
128     $ez[50] += exp(-($qTime +0.5-(-0.5)- 30.0)*($qTime +0.5-(-0.5)- 30.0)/100.0);
129 }
130 
131 #print $PIPE "set terminal x11\n";
132 
133 print $PIPE "set output\n";
134 
135 close($PIPE);

正常结果

python的程序

 1 #!/usr/bin/env python
 2 
 3 import sys
 4 import math
 5 import os
 6 # Author : Leon  Email: yangli0534@gmail.com
 7 # fdtd simulation , plotting with gnuplot, writting in python  
 8 # perl and gnuplot software packages should be installed before running this program
 9 # 1d fdtd with absorbing boundary and TFSF boundary between [49] and [50]
10 # lossy dielectric material localted at > ez[150]
11 gp = os.popen('gnuplot','w')
12 #gp .write('plot sin(x)\n');
13 #gp .flush();
14 #p .close();
15 gp.write('set size 0.85, 0.85\n')
16 gp.write('set term png size 600, 400\n')
17 title = 'fdtd simulation by leon,yangli0534\\\\@gmail.com'
18 gp.write('set terminal gif animate\n')
19 gp.write('set output "fdtd_simulation_abc_tfsf_match_diel_py.gif"\n')
20 gp.write(''.join(['set title "{/Times:Italic ',title, '}"\n']))
21 gp.write('set title  font ",10"  norotate tc rgb "white"\n')
22 gp.write('unset key\n')
23 gp.write('set tics textcolor rgb "white"\n')
24 gp.write('set border lc rgb "orange"\n')
25 gp.write('set grid lc rgb"orange"\n')
26 gp.write('set object 1 rectangle from screen 0,0 to screen 1,1 fc rgb "gray10" behind\n')
27 gp.write('set xlabel" {/Times:Italic distance: wave length}" tc rgb "white" \n')
28 gp.write('set ylabel"{/Times:Italic amplitude: v}" tc rgb "white"\n')
29 gp.write('set autoscale\n');
30 
31 size = 400#physical distance
32 ez=size * [0.00]#electric field
33 hy=size * [0.00]#magnetic field
34 ceze=size * [0.00]# 
35 cezh=size * [0.00]# 
36 chye=size * [0.00]# 
37 chyh=size * [0.00]# 
38 imp0 = 377.00
39 LOSS = 0.01
40 LOSS_LAYER = 250
41 MaxTime = 18000
42 cnt = 0
43 elem = 0.00000
44 gp.write(''.join(['set xrange [0:',str(size),'-1]\n']));
45 for i in range(0,size):
46     ez[i] = 0.0
47     hy[i] = 0.0
48     if (i < 100):
49         #$epsR[$i] = 1.0;
50         ceze[i] = 1.0
51         cezh[i] = imp0    
52     elif(i < LOSS_LAYER):
53         #$epsR[$i] = 1.0;
54         ceze[i] = 1.0
55         cezh[i] = imp0/9.0    
56     else :
57         #$epsR[$i] = 9.0;
58         ceze[i] = (1.0-LOSS)/(1.0+LOSS)
59         cezh[i] = imp0 / 9 /(1.0+LOSS)
60     if( i < LOSS_LAYER):
61         chye[i] = 1.0/imp0
62         chyh[i] = 1.0
63     else:
64         chye[i] = 1.0/imp0/(1.0+LOSS)
65         chyh[i] = (1.0-LOSS)/(1.0+LOSS)
66 for qTime in range(0, MaxTime):    
67     # update magnetic field
68     for mm in range(0, size-1):
69         hy[mm] = hy[mm]*chyh[mm] + (ez[mm+1]-ez[mm])*chye[mm]
70     hy[49] = hy[49]-math.exp(-(qTime - 30.0)*(qTime - 30.0)/100.0)/imp0
71     # update electric field
72     ez[0] = ez[1]#abc
73     #$ez[$size-1] = $ez[$size-2];
74     for mm in range(1, size-1):
75         ez[mm] = ez[mm]*ceze[mm] + (hy[mm] - hy[mm-1])*cezh[mm]    
76     if(qTime % 20 == 0):
77         gp.write('plot "-" w l  lw 1.5 lc rgb "white"\n')
78         cnt = 0
79         for elem in ez:       
80             #gp.write([cnt,' ',elem,'\n'])
81             gp.write(''.join([str(cnt),' ',str(elem),'\n']))
82             #gp.write(' ')
83             #gp.write(str(elem))
84             #gp.write('\n')
85             cnt += 1        
86         gp.write('e\n')
87     ez[50] = ez[50]+math.exp(-(qTime +0.5-(-0.5)- 30.0)*(qTime +0.5-(-0.5)- 30.0)/100.0);
88 gp.write('set output\n')
89 gp.close()

结果就是

posted @ 2016-09-14 13:07  Leon#0534  阅读(323)  评论(0编辑  收藏  举报

我的新博客

专注天线学习,欢迎交流 yangli0534@gmail.com - 创建于 2010年

我永远是茫茫EE领域的一名小学生。