tag:blogger.com,1999:blog-80855149495570202632023-11-16T16:28:51.244+09:00備忘録ダラダラ書いてます。にしるhttp://www.blogger.com/profile/14158676822605584570noreply@blogger.comBlogger121125tag:blogger.com,1999:blog-8085514949557020263.post-80924217360747571902014-09-11T22:10:00.002+09:002014-09-11T22:10:51.251+09:00Perl最近PDLを使おうかと思ってます。<br />
<br />
いや、仕事ではないですが、せっかくperlの勉強をしたいと思っているので。<br />
<br />
自由度が高いけど、書き手によってコードのエレガント差が変わる部分が大きい言語は結構好きかもしれません。<br />
<br />
学習レベルによってコードが変わるのは、自分の成長度がわかっていいですね。<br />
業務では嫌われる要因でしょうが・・・。<br />
<br />
モダンPerlの新版はいつ出るんでしょうか。<br />
結構楽しみにしてます。<br />
<br />
あと、Perl入学式に参加して、<br />
「書き方は自由です」<br />
というのは、勇気づけられました。<br />
もちろん、技巧をこらしても良い、ということではなく、<br />
「汚く書いても動くし、技巧をこらしても動くけど、ちゃんと考えて書いてね」<br />
と言われてる気がします。<br />
<br />
それはいわば、自然言語に近いのかなと。<br />
<br />
文章の流れを考えて、くどく「私は」「私は」と書くのは、<br />
読みづらいし、大事な所で主語が抜けるのは、本当に意味が分からない。<br />
<br />
話し言葉と文章では異なりますし。<br />
<br />
そういった意味では、使い手のレベルに依存し、<br />
高度なコードも、低度なコードも可能なので、自然言語に似ていると感じます。<br />
<br />
さすが、ラリーさんです。<br />
<br />
今後も発展して欲しいと思いますし、無くなることはないでしょう。<br />
Linuxにはほとんど入ってますし。<br />
<br />
死ぬまでにどれだけ理解出来るか、楽しみです。 にしるhttp://www.blogger.com/profile/14158676822605584570noreply@blogger.com0tag:blogger.com,1999:blog-8085514949557020263.post-85925255706270282162014-06-18T22:54:00.000+09:002014-06-18T22:54:13.393+09:00カルマンフィルタ足立先生の「カルマンフィルタの基礎」を勉強させていただきます。<br />
初心者にとっては非常に良い本だと思ってます。<br />
<br />
その中で、例題プログラムがあり、MATLABなのですが、<br />
ビンボーなため、持っておりません。<br />
<br />
そこでpythonで書いてみました。<br />
最初の例題は、スカラー変数なので、若干弄っております。<br />
コメントはしません。<br />
色々おこられそうなので。。。<br />
<br />
本当に勉強になります。<br />
<br />
<div style="-qt-block-indent: 0; -qt-user-state: 0; margin-bottom: 0px; margin-left: 0px; margin-right: 0px; margin-top: 0px; text-indent: 0px;">
<!--StartFragment-->import numpy as np</div>
<div style="-qt-block-indent: 0; -qt-user-state: 0; margin-bottom: 0px; margin-left: 0px; margin-right: 0px; margin-top: 0px; text-indent: 0px;">
import pylab as pl</div>
<div style="-qt-block-indent: 0; -qt-user-state: 0; margin-bottom: 0px; margin-left: 0px; margin-right: 0px; margin-top: 0px; text-indent: 0px;">
import random</div>
<div style="-qt-block-indent: 0; -qt-paragraph-type: empty; margin-bottom: 0px; margin-left: 0px; margin-right: 0px; margin-top: 0px; text-indent: 0px;">
<br /></div>
<div style="-qt-block-indent: 0; -qt-user-state: 0; margin-bottom: 0px; margin-left: 0px; margin-right: 0px; margin-top: 0px; text-indent: 0px;">
def kf(A,B,Bu,C,Q,R,u,y,xhat,P):</div>
<div style="-qt-block-indent: 0; -qt-user-state: 0; margin-bottom: 0px; margin-left: 0px; margin-right: 0px; margin-top: 0px; text-indent: 0px;">
xhatm = A*xhat+Bu*u</div>
<div style="-qt-block-indent: 0; -qt-user-state: 0; margin-bottom: 0px; margin-left: 0px; margin-right: 0px; margin-top: 0px; text-indent: 0px;">
Am = A;Bm=B;Cm=C;I =1</div>
<div style="-qt-block-indent: 0; -qt-user-state: 0; margin-bottom: 0px; margin-left: 0px; margin-right: 0px; margin-top: 0px; text-indent: 0px;">
Pm = A*P*Am + B*Q*Bm</div>
<div style="-qt-block-indent: 0; -qt-user-state: 0; margin-bottom: 0px; margin-left: 0px; margin-right: 0px; margin-top: 0px; text-indent: 0px;">
G = Pm*C/(C*Pm*Cm+R)</div>
<div style="-qt-block-indent: 0; -qt-user-state: 0; margin-bottom: 0px; margin-left: 0px; margin-right: 0px; margin-top: 0px; text-indent: 0px;">
xhat_new = xhatm + G*(y-C*xhatm)</div>
<div style="-qt-block-indent: 0; -qt-user-state: 0; margin-bottom: 0px; margin-left: 0px; margin-right: 0px; margin-top: 0px; text-indent: 0px;">
P_new = (I-G*C)*Pm</div>
<div style="-qt-block-indent: 0; -qt-user-state: 0; margin-bottom: 0px; margin-left: 0px; margin-right: 0px; margin-top: 0px; text-indent: 0px;">
return xhat_new,P_new,G</div>
<div style="-qt-block-indent: 0; -qt-paragraph-type: empty; margin-bottom: 0px; margin-left: 0px; margin-right: 0px; margin-top: 0px; text-indent: 0px;">
<br /></div>
<div style="-qt-block-indent: 0; -qt-user-state: 0; margin-bottom: 0px; margin-left: 0px; margin-right: 0px; margin-top: 0px; text-indent: 0px;">
A = 1.</div>
<div style="-qt-block-indent: 0; -qt-user-state: 0; margin-bottom: 0px; margin-left: 0px; margin-right: 0px; margin-top: 0px; text-indent: 0px;">
b = 1.</div>
<div style="-qt-block-indent: 0; -qt-user-state: 0; margin-bottom: 0px; margin-left: 0px; margin-right: 0px; margin-top: 0px; text-indent: 0px;">
c = 1.</div>
<div style="-qt-block-indent: 0; -qt-user-state: 0; margin-bottom: 0px; margin-left: 0px; margin-right: 0px; margin-top: 0px; text-indent: 0px;">
Q = 1.</div>
<div style="-qt-block-indent: 0; -qt-user-state: 0; margin-bottom: 0px; margin-left: 0px; margin-right: 0px; margin-top: 0px; text-indent: 0px;">
R = 5.</div>
<div style="-qt-block-indent: 0; -qt-user-state: 0; margin-bottom: 0px; margin-left: 0px; margin-right: 0px; margin-top: 0px; text-indent: 0px;">
N = 300</div>
<div style="-qt-block-indent: 0; -qt-user-state: 0; margin-bottom: 0px; margin-left: 0px; margin-right: 0px; margin-top: 0px; text-indent: 0px;">
x = np.zeros(N)</div>
<div style="-qt-block-indent: 0; -qt-user-state: 0; margin-bottom: 0px; margin-left: 0px; margin-right: 0px; margin-top: 0px; text-indent: 0px;">
y = np.zeros(N)</div>
<div style="-qt-block-indent: 0; -qt-user-state: 0; margin-bottom: 0px; margin-left: 0px; margin-right: 0px; margin-top: 0px; text-indent: 0px;">
v = np.zeros(N)</div>
<div style="-qt-block-indent: 0; -qt-user-state: 0; margin-bottom: 0px; margin-left: 0px; margin-right: 0px; margin-top: 0px; text-indent: 0px;">
w = np.zeros(N)</div>
<div style="-qt-block-indent: 0; -qt-user-state: 0; margin-bottom: 0px; margin-left: 0px; margin-right: 0px; margin-top: 0px; text-indent: 0px;">
xhat = np.zeros(N)</div>
<div style="-qt-block-indent: 0; -qt-user-state: 0; margin-bottom: 0px; margin-left: 0px; margin-right: 0px; margin-top: 0px; text-indent: 0px;">
t = np.zeros(N)</div>
<div style="-qt-block-indent: 0; -qt-user-state: 0; margin-bottom: 0px; margin-left: 0px; margin-right: 0px; margin-top: 0px; text-indent: 0px;">
for i in range(N):</div>
<div style="-qt-block-indent: 0; -qt-user-state: 0; margin-bottom: 0px; margin-left: 0px; margin-right: 0px; margin-top: 0px; text-indent: 0px;">
v[i] = random.normalvariate(0,Q)</div>
<div style="-qt-block-indent: 0; -qt-user-state: 0; margin-bottom: 0px; margin-left: 0px; margin-right: 0px; margin-top: 0px; text-indent: 0px;">
w[i] = random.normalvariate(0,R)</div>
<div style="-qt-block-indent: 0; -qt-user-state: 0; margin-bottom: 0px; margin-left: 0px; margin-right: 0px; margin-top: 0px; text-indent: 0px;">
t[i] = i</div>
<div style="-qt-block-indent: 0; -qt-user-state: 0; margin-bottom: 0px; margin-left: 0px; margin-right: 0px; margin-top: 0px; text-indent: 0px;">
#print v[i],w[i]</div>
<div style="-qt-block-indent: 0; -qt-user-state: 0; margin-bottom: 0px; margin-left: 0px; margin-right: 0px; margin-top: 0px; text-indent: 0px;">
y[0] = c*x[0] + w[0]</div>
<div style="-qt-block-indent: 0; -qt-user-state: 0; margin-bottom: 0px; margin-left: 0px; margin-right: 0px; margin-top: 0px; text-indent: 0px;">
for k in range(1,N):</div>
<div style="-qt-block-indent: 0; -qt-user-state: 0; margin-bottom: 0px; margin-left: 0px; margin-right: 0px; margin-top: 0px; text-indent: 0px;">
x[k] = A*x[k-1]+b*v[k-1]</div>
<div style="-qt-block-indent: 0; -qt-user-state: 0; margin-bottom: 0px; margin-left: 0px; margin-right: 0px; margin-top: 0px; text-indent: 0px;">
y[k] = c*x[k] + w[k]</div>
<div style="-qt-block-indent: 0; -qt-user-state: 0; margin-bottom: 0px; margin-left: 0px; margin-right: 0px; margin-top: 0px; text-indent: 0px;">
P = 0</div>
<div style="-qt-block-indent: 0; -qt-user-state: 0; margin-bottom: 0px; margin-left: 0px; margin-right: 0px; margin-top: 0px; text-indent: 0px;">
xhat[0] = 0.0</div>
<div style="-qt-block-indent: 0; -qt-user-state: 0; margin-bottom: 0px; margin-left: 0px; margin-right: 0px; margin-top: 0px; text-indent: 0px;">
for k in range(1,N):</div>
<div style="-qt-block-indent: 0; -qt-user-state: 0; margin-bottom: 0px; margin-left: 0px; margin-right: 0px; margin-top: 0px; text-indent: 0px;">
xhat[k],P,G = kf(A,b,0,c,Q,R,0,y[k],xhat[k-1],P)</div>
<div style="-qt-block-indent: 0; -qt-user-state: 0; margin-bottom: 0px; margin-left: 0px; margin-right: 0px; margin-top: 0px; text-indent: 0px;">
<br /></div>
<div style="-qt-block-indent: 0; -qt-user-state: 0; margin-bottom: 0px; margin-left: 0px; margin-right: 0px; margin-top: 0px; text-indent: 0px;">
pl.plot(t,y,label='measured')</div>
<div style="-qt-block-indent: 0; -qt-user-state: 0; margin-bottom: 0px; margin-left: 0px; margin-right: 0px; margin-top: 0px; text-indent: 0px;">
pl.plot(t,x,label='ture')</div>
<div style="-qt-block-indent: 0; -qt-user-state: 0; margin-bottom: 0px; margin-left: 0px; margin-right: 0px; margin-top: 0px; text-indent: 0px;">
pl.plot(t,xhat,label='estimate')</div>
<div style="-qt-block-indent: 0; -qt-user-state: 0; margin-bottom: 0px; margin-left: 0px; margin-right: 0px; margin-top: 0px; text-indent: 0px;">
pl.grid(True)</div>
<div style="-qt-block-indent: 0; -qt-user-state: 0; margin-bottom: 0px; margin-left: 0px; margin-right: 0px; margin-top: 0px; text-indent: 0px;">
pl.legend()</div>
<div style="-qt-block-indent: 0; -qt-user-state: 0; margin-bottom: 0px; margin-left: 0px; margin-right: 0px; margin-top: 0px; text-indent: 0px;">
pl.savefig('kf')</div>
<br />
pl.show()<!--EndFragment--><br />
<br />
<div class="separator" style="clear: both; text-align: center;">
<a href="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEhCzjpVvo4Om_Iih9pkIQ6mx8M626FnnOk-kpfGgLqN96lmgtzZLx6lUcS0bcCTFNb-Lipa_TEZE-Jr7cFicGnrXMoZTC3P1gbT5OSknunQ1NkzgEpVfm_jHtY0YihTPKszfrNGI1oRvqNL/s1600/Untitled.png" imageanchor="1" style="margin-left: 1em; margin-right: 1em;"><img border="0" src="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEhCzjpVvo4Om_Iih9pkIQ6mx8M626FnnOk-kpfGgLqN96lmgtzZLx6lUcS0bcCTFNb-Lipa_TEZE-Jr7cFicGnrXMoZTC3P1gbT5OSknunQ1NkzgEpVfm_jHtY0YihTPKszfrNGI1oRvqNL/s1600/Untitled.png" height="240" width="320" /></a></div>
<div class="separator" style="clear: both; text-align: center;">
<br /></div>
<div class="separator" style="clear: both; text-align: left;">
とりあえずうまくいってるようです。</div>
<div class="separator" style="clear: both; text-align: left;">
<br /></div>
<br />にしるhttp://www.blogger.com/profile/14158676822605584570noreply@blogger.com0tag:blogger.com,1999:blog-8085514949557020263.post-74252184671768275662014-06-15T23:43:00.001+09:002014-06-15T23:43:37.872+09:00Harten-Yeeをちょっと修正以前のものを多少修正しました。<br />
もうちょっと美しく出来れば良いんですけど・・・。<br />
1次風上も残してますが、20行くらい少なくなってます。<br />
<br />
<br />
#advection #################################################<br />
# Harten Yee Upwind ########################################<br />
############################################################<br />
#import#####################################################<br />
from pylab import *<br />
def cal_fai(z):<br />
eps = 0.0000000001<br />
if abs(z) > eps:<br />
return abs(z)<br />
else:<br />
return (z*z+eps*eps)/(2*eps)<br />
def cal_sigma(z,dt,dx):<br />
return 0.5*(cal_fai(z)-dt/dx*z*z)<br />
def minmod2(x,y):<br />
if abs(x)<=abs(y) and x*y >=0.0:<br />
return x<br />
elif abs(x)>abs(y) and x*y >= 0.0:<br />
return y<br />
elif x*y<0:<br />
return 0.0<br />
else:<br />
print "Error minmode2"<br />
# Harten Yee ##############################################<br />
class Cell:<br />
def __init__(self,dxl,u,f,fn,fl,fr):<br />
self.dxl = dxl<br />
self.u = u<br />
self.f = f<br />
self.fn = fn<br />
self.fl = fl<br />
self.fr = fr<br />
self.df = 0.0<br />
self.gi = 0.0<br />
self.gamma = 0.0<br />
self.fai = 0.0<br />
def upwind(self,dt,cellup,celldn):<br />
ultmp = 0.5*(u + cellup.u)<br />
urtmp = 0.5*(celldn.u + u)<br />
if self.u > 0:<br />
self.fl = ultmp*cellup.f<br />
self.fr = urtmp*self.f<br />
else:<br />
self.fl = ultmp*self.f<br />
self.fr = urtmp*celldn.f<br />
def caldf(self,celldn):<br />
self.df = celldn.f - self.f<br />
def calgi(self,cellup):<br />
self.gi = minmod2(self.df,cellup.df)<br />
def calgamma(self,dt,celldn):<br />
if self.df != 0:<br />
self.gamma = cal_sigma(self.u,dt,self.dxl)*(celldn.gi - self.gi)/self.df<br />
else:<br />
self.gamma = 0.0<br />
def calfai(self,celldn):<br />
self.fai = cal_sigma(self.u,dt,self.dxl)*(self.gi+celldn.gi)-cal_fai(self.u+self.gamma)*self.df<br />
def yee(self,dt,cellup,celldn):<br />
csdn = 0.5*(celldn.u*celldn.f+self.u*self.f)<br />
csup = 0.5*(self.u*self.f + cellup.u*cellup.f)<br />
cfdn = 0.5*self.fai<br />
cfup = 0.5*cellup.fai<br />
self.fr = csdn+cfdn<br />
self.fl = csup+cfup<br />
def euler(self,dt):<br />
self.fn = self.f - dt/self.dxl*(self.fr - self.fl)<br />
def shift(self):<br />
self.f = self.fn<br />
#set parameters ############################################<br />
in_ff = open('test.txt')<br />
imx=100<br />
dx = 1.0<br />
dt = 0.2<br />
u = 0.2<br />
print "-"*40<br />
print "u =",u<br />
print "dx =",dx<br />
print "dt =",dt<br />
print "-"*40<br />
############################################################<br />
#initial condition ################################<br />
cells = []<br />
fini = []<br />
i = 0<br />
for x in in_ff:<br />
print i<br />
a = x.split("\t")<br />
for k in range(0,1):<br />
print a[k]<br />
cells = cells + [Cell(float(dx),float(u),float(a[1]),float(a[1]),0.0,0.0)]<br />
fini = fini + [float(a[1])]<br />
i=i+1<br />
imx=i<br />
print "imx=",imx<br />
print "*"*40<br />
print "xl,f"<br />
for i in range(0,imx):<br />
print i," ",cells[i].f,cells[i].u<br />
# Time integration ################################<br />
for n in range(0,1000):<br />
#Harten Yee##############################<br />
for i in range(0,imx-1):<br />
cells[i].caldf(cells[i+1])<br />
for i in range(2,imx-1):<br />
cells[i].calgi(cells[i-1])<br />
for i in range(3,imx-2):<br />
cells[i].calgamma(dt,cells[i+1])<br />
for i in range(2,imx-1):<br />
cells[i].calfai(cells[i+1])<br />
for i in range(1,imx-3):<br />
cells[i].yee(dt,cells[i-1],cells[i+1])<br />
for i in range(2,imx-2):<br />
cells[i].euler(dt)<br />
#shift#########################################<br />
for i in range(2,imx-2):<br />
cells[i].shift()<br />
# Exact ###########################################<br />
fout = [0]<br />
fex = [0]<br />
xl = [0]<br />
for i in range(0,imx-1):<br />
if i>=49 and i<=59:<br />
fex = fex +[1.0]<br />
else:<br />
fex = fex +[0.0]<br />
fout = fout + [float(cells[i].f)]<br />
xl = xl + [float(i)]<br />
#output############################################<br />
ff=open("output.dat","w")<br />
for i in range(0,imx-1):<br />
ff.write(str(i))<br />
ff.write(" ")<br />
ff.write(str(fout[i]))<br />
ff.write("\n")<br />
ff.close()<br />
#####################graph#########################<br />
y1=fout<br />
y2=fini<br />
y3=fex<br />
print len(fout),len(fini),len(fex)<br />
plot(xl,y1,label = 'Harten-Yee')<br />
plot(xl,y2,label = 'INITIAL')<br />
plot(xl,y3,label = 'EXACT')<br />
xlabel('x')<br />
ylabel('f')<br />
title('Hatren-Yee')<br />
axis([-0,100.0,-0.2,1.2])<br />
legend()<br />
grid(True)<br />
savefig('Harten-Yee')<br />
show()<br />
###################################################<br />
<div class="separator" style="clear: both; text-align: center;">
<a href="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEjuIklWm7uKiuEHEQgTURkxplSaAuTqWamMptbmf7SpKLHnYHLx9IYvTdgB7qAM5DCf1DWcWQ_Ij4HSSYoix1nYlhYNyglw8b5fLY1Kx9bsWz6q4lIml4XcDYYmhcWzHVaLUMui4kqFFeGJ/s1600/Harten-Yee.png" imageanchor="1" style="margin-left: 1em; margin-right: 1em;"><img border="0" src="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEjuIklWm7uKiuEHEQgTURkxplSaAuTqWamMptbmf7SpKLHnYHLx9IYvTdgB7qAM5DCf1DWcWQ_Ij4HSSYoix1nYlhYNyglw8b5fLY1Kx9bsWz6q4lIml4XcDYYmhcWzHVaLUMui4kqFFeGJ/s1600/Harten-Yee.png" height="240" width="320" /></a></div>
<div>
<br /></div>
<div>
<br /></div>
にしるhttp://www.blogger.com/profile/14158676822605584570noreply@blogger.com0tag:blogger.com,1999:blog-8085514949557020263.post-16752958027564126922014-05-11T16:06:00.001+09:002014-05-11T16:06:02.551+09:00Java今、仕事でJavaを使ってます。<br />
<br />
正直、FortranやC的な書き方しか出来てません・・・。<br />
<br />
今更ですが、自分自身オブジェクト指向が出来ていないと思ってます。<br />
<br />
結城先生のJavaの本を読んで、多少わかった気にはなってますが、<br />
まだまだだなと。<br />
<br />
実装自体は、数値解析的な所かつライブラリを使う所なので難しい部分はありますが・・・。<br />
<br />
<br />にしるhttp://www.blogger.com/profile/14158676822605584570noreply@blogger.com0tag:blogger.com,1999:blog-8085514949557020263.post-76365375624596494092014-03-22T09:50:00.001+09:002014-03-22T09:50:06.479+09:00Fortran新しい会社では全く使わなくなったFortran+本の話です。<br />
<br />
「数値計算のためのFrotran90/95プログラム入門」は以前の会社に入って良く読みました。京都大学の牛島先生の本です。<br />
<br />
特定の分野では77は使われています。<br />
ゼロから書く場合は90/95へのシフトがなされているようです。<br />
<br />
大学の時は77が多くて、<br />
・Windowsかつ小さなプログラムならfcpad+salfordで解く<br />
・Macならg77で解く<br />
だった気がします。<br />
<br />
Fortranは科学技術計算に特化していますが、文法は分っても、「自分が書きたいプログラム」の書き方の参考になるものは少なかった気がします。77だとそんなこと気にすることもないですが・・・。common文は使わない、とかimplicit realは使わないくらいでしょうか。<br />
<br />
当時、90/95の書籍はあったのですが、流体の計算をする場合の書き方みたいなものを提示してある書籍かつインストール方法やgnuplotを使った可視化まで書いてある本はあまりなかった記憶があります。この本は自習用として良いのではないかとすぐ購入した覚えがあります。<br />
<br />
結果、モジュールやサブルーチンの使い方、プログラム規模に応じた使い分け、浅水流方程式の特性曲線法を使ったプログラムまで掲載されており、手垢塗れになりました。付箋もいっぱい貼ってあります。<br />
<br />
77はGOTO文を使わないとLOOPを抜け出せない、文番号をつかったFORMAT文、1行72文字まで等の制限がありますが、90/95は自由形式になり、それなりに使いやすくなってます。配列も使いやすくなってます。<br />
<br />
Fortranを使う人間は、あまりプログラムがメインでない技術者が多く、文法とか書き方にこだわりすぎても仕方ありません。Cだとメモリに気を使わないとダメですし。<br />
その点、Fortranはちょうど良いかと思います。フリーのライブラリも多くありますし。<br />
<br />
フリーのコンパイラならgfortran、商用ならインテルコンパイラやPGIコンパイラがあります。Linuxかつ非商用目的なら、インテルコンパイラはフリーで使えます。<br />
<br />
あとFortran一番の特徴は計算が速いことです。これが利用される目的として一番大きいですかね。 時間の数値積分のための繰り返し回数が多くなると、計算終わるまでに時間がかかります。計算が速いのは重要です。<br />
<br />
<br />
<br />
<br />にしるhttp://www.blogger.com/profile/14158676822605584570noreply@blogger.com0tag:blogger.com,1999:blog-8085514949557020263.post-30403127575130739882014-02-10T10:18:00.002+09:002014-02-10T10:18:31.738+09:00関数プログラミングプログラミングの書き方はいくつかあると思いますが、<br />
私のこれまでの感覚だと、手続き型とオブジェクト指向型がメインだったように思います。<br />
<br />
最近の書籍、雑誌、ネットでは「関数プログラミング」というキーワードが多くあるとおもいます。<br />
<br />
私が関数プログラミングに触れ始めたのはEmacsからです。Emacsを使いこなそうとすると、Elispを使わなければなりません。いや、使わなくてもEmacsは使えるんですが、これがないなら他のエディタを使った方が良いです。<br />
<br />
Elispを見て、それまでの命令型と全く違って面食らいました・・・。<br />
かっこまみれは良いとして、関数型の思想を勉強してないので、頭が大混乱・・・。<br />
<br />
そこから関数型言語としてCommonLispとか、Schemeとかあるんだなと。<br />
ハッカーと画家も買って読みました。読み物として面白いです。<br />
が、その威力が未だに見えてきません。変数書き換え不可!なぜ?<br />
<br />
ある程度大規模な科学技術計算(私は流体解析メイン)はFortran、C/C++で書かれることが多く、空間離散点が数百万、時間積分も長時間やる場合は、Intel、PGIのコンパイラが多いようです。<br />
<br />
中規模であれば、javaやC#なんかも使われているようです。<br />
<br />
小規模であったり、統計解析や定常計算等であれば、Excel、Python、Ruby、R等が使われることが多いようです。<br />
<br />
さて、自分のフィールドである科学技術計算に関数プログラミングを使えないかと考えたのですが、なかなか難しいです・・・。<br />
<br />
その理由の第一は関数プログラミングを十分理解出来ていないことです。これは本読んで、コーディングすれば少しずつ解決しそうです。<br />
<br />
第二に関数プログラミングが適用されている他のフィールドで求められている機能について理解出来ていないことです。これはなかなか難しそうですが、第一の理由を解決する過程で何か答えの断片を得られそうです。<br />
<br />
その上で、第一、第二を踏まえて科学技術計算にどのように適用するのかを考えようと思います。<br />
<br />
一つの機能としては、並列化への適用は可能性がありそうです。科学技術計算をやる上で、「解析時間の短縮」は大きなウェートです。<br />
可読性向上については、厳しいような気がします。計算屋は命令型しか勉強しないですし、オブジェクト指向すら知らない人が多いです。実際、オブジェクト指向で書くと、遅くなることが多いです。<br />
あとは、保守管理、過去の遺産の利用等々、いくつかの側面についても検討する必要があると思います。<br />
<br />
ちなみに、関数プログラミングについては、Twitterで、おそらくその道のプロ(NY先生)であろう方からの返信があって、考え始めました。資料もご提示いただき、少し頭が晴れてきました。このページを見ているとは思いませんが、お礼申し上げます。ありがとうございます。<br />
<br />
また、考えがまとまったら書こうと思います。<br />
<br />
<br />
<br />にしるhttp://www.blogger.com/profile/14158676822605584570noreply@blogger.com0tag:blogger.com,1999:blog-8085514949557020263.post-76055718440785852232014-02-09T01:39:00.003+09:002014-02-09T01:41:00.068+09:00KKスキーム河村・桑原スキームについてです。<br />
<br />
1984年のLESに関する論文だったかと思います。<br />
<br />
数値解析のうち、移流項の解法は以下の流れで勉強しました(私の場合)。<br />
<br />
・中央差分(必ず発散)<br />
・1次精度風上差分(解けるけど解が鈍る)<br />
→中央差分の方が精度が良さそうだが解けない。なぜなら移流項(対流項)は移流速度に乗って情報が上流から下流に伝搬するからである。1次精度風上差分の場合、意図しない所で、拡散的な項(数値粘性)が入っているため解が鈍る。<br />
<br />
・LaxWendroff法(2次精度だが振動が入る)<br />
・MacCormack法(2次精度だが振動が入る)<br />
→1次精度風上差分では数値粘性が入っていたため、安定的に解けた。同様の考え方で人工粘性を入れることで、振動を小さくする。<br />
<br />
・KKスキーム<br />
→3次精度を実現するために4次精度の中央差分+4次の拡散項を入れる。振動は残るが、河村先生の論文以降、実現象解明へ適用されてきた実績がある。<br />
<br />
以降、QUICK、TVD(MUSCL系、Non-MUSCL系)、CIP(オリジナル、有理関数補間、CSL系)の勉強をしました。個人的にはCIP-CSLR1が好きですが、既存のコードの書き換えは結構大変です。マルチモーメントなので・・・。<br />
その後は、小松先生の6Point Scheme、牛島先生のQSIスキーム、ENO、WENO等もかじってます。<br />
<br />
今回、気が向いて、KKスキームについてちょっと勉強し直しました。<br />
ベンチマークで使われる2D-Cavity Flowに適用しようと考えてます。<br />
非圧縮性流体の解析なので、MAC系の解法を使って、移流項にKKスキームをと・・。<br />
<br />
KKスキームは非保存系のスキームでした。ということで、ある論文の方法を使って保存系に変形しました。線形移流方程式に対して、保存系、非保存系で解いた結果、同様の結果を得られたので、適用は出来そうです。<br />
<br />
うまくいったら、結果を載せようと思います。<br />
<br />にしるhttp://www.blogger.com/profile/14158676822605584570noreply@blogger.com0tag:blogger.com,1999:blog-8085514949557020263.post-23559270362998985932014-02-04T21:30:00.001+09:002014-02-05T18:56:08.351+09:00xojo<div class="separator" style="clear: both; text-align: center;">
<a href="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEg6WPG6sGKbE-KGSevIBJkXxGUb4va_eRcv9uxw6vfTR6iSpz7Cy3apMdPvDi95mj3uWXV3GCj1RCtfeXmwueZSAKJbvDwBhhyphenhyphenZGnjpcugMDEUK2hnCXGv_T61xTRbqejUdarUJe5s4Hnls/s1600/140204-0002.png" imageanchor="1" style="margin-left: 1em; margin-right: 1em;"><img border="0" src="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEg6WPG6sGKbE-KGSevIBJkXxGUb4va_eRcv9uxw6vfTR6iSpz7Cy3apMdPvDi95mj3uWXV3GCj1RCtfeXmwueZSAKJbvDwBhhyphenhyphenZGnjpcugMDEUK2hnCXGv_T61xTRbqejUdarUJe5s4Hnls/s1600/140204-0002.png" height="190" width="320" /></a></div>
<br />
<div class="separator" style="clear: both; text-align: center;">
<a href="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEjhIq1mPcZKXq4sViMKaTuKhhKWUjbS_ca_BqH_8yWBY-6O89U4B2B0idv4-EyCSXbLNRnLF3YgPHhxqWWQ4w2ThFBGGMCxDSZMKQ0IK_IJIdKzAQKzeZ_xJEcO-a7pYe_E34dSe8ZUNCDi/s1600/140204-0003.png" imageanchor="1" style="margin-left: 1em; margin-right: 1em;"><img border="0" src="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEjhIq1mPcZKXq4sViMKaTuKhhKWUjbS_ca_BqH_8yWBY-6O89U4B2B0idv4-EyCSXbLNRnLF3YgPHhxqWWQ4w2ThFBGGMCxDSZMKQ0IK_IJIdKzAQKzeZ_xJEcO-a7pYe_E34dSe8ZUNCDi/s1600/140204-0003.png" height="190" width="320" /></a></div>
<br />
<div class="separator" style="clear: both; text-align: center;">
<a href="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEgbJlDCZtvaIeiYlpjOLUaJh4fcXe5oOeJI-8ScHiqJTWlF75kf7Qr3gMOsILGFqeZB1DMe9P8XhGlinD4jFDDBa9post_OtQ6wzIP1cUJ1ANfWqI_awiuK13984EnPL1L4TwlyvGP6dANd/s1600/140204-0004.png" imageanchor="1" style="margin-left: 1em; margin-right: 1em;"><img border="0" src="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEgbJlDCZtvaIeiYlpjOLUaJh4fcXe5oOeJI-8ScHiqJTWlF75kf7Qr3gMOsILGFqeZB1DMe9P8XhGlinD4jFDDBa9post_OtQ6wzIP1cUJ1ANfWqI_awiuK13984EnPL1L4TwlyvGP6dANd/s1600/140204-0004.png" height="190" width="320" /></a></div>
xojoの2月の課題があったのでやってみた。<br />
全然きれいじゃないし分ってないことを認識しているが、<br />
とりあえずやってみみた。<br />
<br />
下記ページを参考にさせていただいた。 <br />
<br />
http://www.geocities.co.jp/SiliconValley/2413/tips.html#16<br />
<br />
なんかプリントスクリーンが巧くいかない・・・。にしるhttp://www.blogger.com/profile/14158676822605584570noreply@blogger.com0tag:blogger.com,1999:blog-8085514949557020263.post-67463877797835135982014-01-24T08:17:00.001+09:002014-01-24T08:17:25.410+09:00河川のシミュレーション!河村先生の書籍です。<br />
現在は絶版になっております。<br />
<br />
大学の時に購入しました。<br />
解析の基本的な説明の後、1次元、2次元、3次元の解析について記述されています。<br />
<br />
偏微分方程式については移流拡散方程式、ポアソン方程式の解法を、<br />
また一般座標系の説明があります。<br />
<br />
河川に焦点を当てた(浅水流方程式に焦点を当てた)書籍は他にないような気がします。<br />
<br />
サンプルプログラムもありますが、実用性は低いように思います。<br />
また、流砂量公式については記述がありません。<br />
<br />
ただし、勉強し始めた人にとっては有用な本の一つであることは間違いないと感じました。最近は大学レベルでも1からプログラムを書くことは少なくなっているようですし、<br />
あくまでソフロウェアのユーザーであっても、知っておいた方が良いように思います。<br />
<br />
<br />
個人的にはKKスキームについて記述されていないのが、ちょっと残念です。<br />
日本人が作った数少ない移流項の解法ですからね。<br />
(河村先生のその他の本には記述されています。河川だから省いたのかなと邪推しています)<br />
<br />
<br />
日本の技術書は薄い本が多いように感じます。<br />
ゼロから勉強しようにも、技術のバックグラウンドや基礎方程式について記述されているだけの本が多いです。基本的には基礎方程式は複雑なことが多く、複雑な方程式を解くには数値計算に頼らざるを得ないことが多いです。そのためには数値解析の基本的事項およびそれを実用的に使う方法まで書くには厚くすべきだと思ってます。<br />
その点、海外の書籍は厚く、読むのが大変ですが、独学に向いています。<br />
日本でもそのような流れにしていただきたいです。<br />
<br />
ちなみに河村先生は多くの書籍を出されています。数値計算の基本的な所を記述した教科書になるものが多いです。私はファンなので買ってしまいます・・・。<br />
エクセルVBAを使った解析について書かれているものもありますので、興味のある人は是非!<br />
<br />
<br />
<br />にしるhttp://www.blogger.com/profile/14158676822605584570noreply@blogger.com0tag:blogger.com,1999:blog-8085514949557020263.post-51254034061624757912014-01-24T07:00:00.001+09:002014-01-24T07:00:28.168+09:00履歴年明け一発目です。<br />
せっかくなので、これまでのプログラミング履歴をまとめておこうと思います。<br />
順番は適当です。<br />
<br />
<br />
<ul>
<li>C/C++</li>
</ul>
Cは大学のときに最初に学んだ言語。その後、数値解析に目覚めて、CIP法を書いてみて、数式を展開して、思いどおりの結果が出てハマる。研究室に所属して、修論ではC++となるが、当時はあまりオブジェクト指向を理解していなかった。社会人になってからはチマチマ勉強して多少理解が進んだ。業務でも扱うこと(VC++)が多く、とりあえず、一番利用していると思う。<br />
<br />
<br />
<ul>
<li>Fortran</li>
</ul>
科学技術計算をやるならFortranは外せない。もちろんゼロから書くならC/C++でも良いが、如何せん、研究室の遺産を利用しようとすると、書けなくても読めなければならなかった。まあ、C/C++に比べれば大したことはない。研究室では77しかなかったが、社会人になってから京都大学の牛島先生の本が出て、90/95を勉強した。当時は配列の動的確保やintent文が使えるなという印象だった。牛島先生の本は90/95の文法だけでなく、科学技術計算のプログラムの書き方について記述してあるのが優れていると思う。<br />
<br />
<br />
<ul>
<li>python</li>
</ul>
初めて存在を知ったのは、研究室に入ってから。共有のパソコンにヘビのアイコンがあったのを記憶している。しばらく忘れていたが、社会人になってみんpyをちょくちょく読みながら少しずつ勉強した。高速な計算でなければ使いやすいと思う。数学者が作成した言語というのも好感度アップ。matplotlibによるグラフ作成や、ベクトルやコンター図も簡単にできるのが良い。また、マルチパラダイムなのも良い。特にFortranユーザーにも使いやすいと思う。海外研修時に簡単な温度応力解析のプログラムをこいつで書いた。<br />
<br />
<br />
<ul>
<li>ruby</li>
</ul>
日本人が作ったとのことで、たのしいRubyを手に取ったのが始まり。pythonに比べて科学技術計算用途のmoduleは少ないと思う。ただし、オブジェクト指向の勉強としては優れていると思う。Railsは使ったことがない・・・。ごめんなさい。データ整理なら特に問題なく使える。業務で使ったことはない。ただし、日本人ならruby使って発展させた方が良い気がする。黒魔術も使えるし。<br />
<br />
<br />
<ul>
<li>perl</li>
</ul>
仕事で海外研修時にO'Reillyの例のやつ(初めてのPerl)を読んでいた。出張中はWindowsしか触れなかったのでPadreを入れていたと記憶している。言語学者が作っているのであまりピンとこなかった。ただし、上記書籍は読んだ方が良いと思う。普通に面白い。業務では科学技術計算用Linuxの設定のついでにLAMPを入れた時に多少触ったくらい。python、ruby、perlについては用途が被るが好みで選択すれば良いと思う。どれが優れているとかは感じなかった。<br />
<br />
<br />
<ul>
<li>xojo</li>
</ul>
real basicだったのxojoになった。勉強会も開かれているようだ。もちろん会社では一切使わない。移流方程式を解いて、図化する程度のプログラムは書いてみた。これも海外出張時に多少勉強した。日本語の情報は少ないが、英語の情報はたくさんあるし、リファレンスやサンプルはしっかりしている。ただ、サードパーティなので一抹の不安はある。Linux、Mac、Windowsの環境で使えるし、ネイティブコードを吐き出せるのは良い所。<br />
<br />
<ul>
<li>VBA</li>
</ul>
いや、プログラム言語じゃない!と言われると思いますが、ごめんなさい。会社ではデータ整理やちょっとした統計解析なんかはVBAでやることが多いです。VBAが優れている点は、Excelがインストールしてあれば細かい設定は関係無しにみんな使える所です。通信関係は触ったことはないです。<br />
<br />
<br />
<ul>
<li>VB.NET</li>
</ul>
メールを読み込んで添付ファイルを抽出するプログラムを業務で書いた。好んで使った訳でなく、遺産がVBだったから使ったまで。文法については「Must Inherits」とかカッコいいと思った。6.0から.NETで強烈に変化してしまったため、ユーザーは減ってるらしい。私の周り?そもそもプログラム書くことに情熱を持ってるやつなんていないっす。<br />
<br />
<br />
<ul>
<li>java</li>
</ul>
javaによるCIP法の本が出てちょっとだけ勉強した。解析結果を表示しながら解析を進めるというもので、結構面白かった。ただ、Fortran的な書き方しかしてないので、javaを勉強した気はしなかった。ほんとはちゃんと勉強したい。Androidアプリも弄ることが出来そうだし。。。<br />
<br />
<br />
<ul>
<li>ELisp</li>
</ul>
Emacsを使い始めると必然的に使わなきゃいけない。今だに使えるようになったとは思わないが、Emacsは楽しい。C/C++から入った私としては、文法に面食らった。何かに使うわけでなくEmacsのカスタマイズのみである。なおWindows環境でのEmacsライクなエディタにxyzzyがあるがこちらはCommon Lispでカスタマイズする。<br />
<br />
<br />
<ul>
<li>AWK</li>
</ul>
読んだ本はプログラミング言語AWK。スクリプト言語はsh、sed、awk等が基本的な所にあると思う。利用としてはテキスト処理しかないが、結構簡単に書けるしパイプラインで繋いで処理していく過程は楽しい。完全な主観だが、ワンラインならはやりのスクリプトよりこっちの方が良いかもしれない。<br />
<br />
<br />にしるhttp://www.blogger.com/profile/14158676822605584570noreply@blogger.com0tag:blogger.com,1999:blog-8085514949557020263.post-33479190256166034362013-12-18T00:38:00.001+09:002013-12-18T00:38:16.267+09:00C++C++はマルチパラダイム言語ですが、<br />
最近、再勉強をしています。<br />
<br />
楽しいです。とりあえず、微分方程式を解くためのアルゴリズムを中心に書いていますが、本当に色々な書き方があるんだなと。<br />
<br />
本も数冊購入しました。一冊は本当に初学者の本です。なぜなら、C++の全体のイメージを思い出すことが必要だと思ったからです。新しい発見でしたが、比較的初学者の本を読んで、ちょっと説明が違うな、と認識できるところがありました。少しは成長していたんだなと。<br />
<br />
別の一冊はSTL中心です。STLは本当にコードが短くなるだけでなく、デバッグすべき項目を減らせるなという印象です。世の中の、どの分野で、どの程度使われているかわかりませんが・・・。加えてBoostの知識も入れておこうと思います。<br />
<br />
最後の一冊はWindowsに特化したMFC中心の本です。<br />
今さら感が強いですが・・・。<br />
VC++はC++とは全然違うものというのが再認識されました・・・。<br />
<br />
ライブラリを含めると、C++という言語はあまりにも広すぎます。<br />
プラットフォームに依存したVC++だと別物です。<br />
<br />
なかなか学習の仕方が難しいですが、今のところ、やりたいことは微分方程式を解くことなので、いろいろな書き方を試したいと思います。<br />
<br />にしるhttp://www.blogger.com/profile/14158676822605584570noreply@blogger.com0tag:blogger.com,1999:blog-8085514949557020263.post-50386131421719491242013-12-12T17:51:00.002+09:002013-12-13T00:32:26.245+09:00全然書けてない・・・。ようやく落ち着いたので、書き始めようと思います。<br />
<br />
次の会社に向けて、C++の復習と統計の勉強を少しずつしています。<br />
<br />
・C++について<br />
プログラミング言語の学習は文法をマスターすることではありません。<br />
その言語がどのような思想で設計され、与えられる課題に対して、どのようにアプローチすべきか?というような「思考方法」を学ぶことだと捉えています。<br />
<br />
C++のようないろんな書き方がある場合、つまりは思考方法が複数あることを意味しています。そのような混沌としたような言語は非常に難しく感じます。<br />
ただし、それが非常に面白いです。<br />
<br />
結局、C言語の思考方法に振り返ることになってます(笑)<br />
でもコーディングする人間が忘れてはならないことは、<br />
「このコードが何をするために使われるか?」<br />
だと思います。<br />
<br />
・統計<br />
「統計学は最・・・」とかいう本が出てますが、読んでません。<br />
個人的には、統計学で説明できる事象とは何か?に興味があります。<br />
特に時系列分析やスペクトル解析でしょうか。<br />
<br />
統計学はあくまで考え方の一つであり、統計学に准ずれば正解、ということではありません。如何せん、現象論は考えていないからです。ただ、現象としては捉えられるけど、メカニズムは不明、という状況において、何らかしら定量的なアプローチをする方法としては有効であるように思います。すべての現象をニュートン力学や微分方程式で表現できる訳ではない(いや、ほとんどは出来るんですが、その場合、時空間解像度を相当確保しなければなりません)ですし、表現できたとしても、実現象を再現できるほど精度がある訳ではありません。<br />
<br />
そういった現象と結果を結びつけたり、そのためのツールとして非常に有効な学問だと思います。平均値、相関、標準偏差とかです。<br />
<br />
でも、中学や高校で確率の勉強が、工場の品質管理に使われるなんて想像もつきませんでした(笑)。鵜呑みにして勉強した結果、あ、そういうことか、と納得したのが大学です。<br />
<br />
さらに言えば、水文学なんかもそうです。母数推定や関数へのフィッティング等。。。<br />
<br />
怖いのは、ツールを使えばなんか答えがでる、ということです。<br />
勉強していない人間がテキトーなことをして、定量的に評価することほど怖いことはありません。<br />
<br />
統計学にはそういう恐ろしさも孕んでます。<br />
<br />
<br />
<br />
<br />
<br />にしるhttp://www.blogger.com/profile/14158676822605584570noreply@blogger.com0tag:blogger.com,1999:blog-8085514949557020263.post-8435713293087209392013-10-20T19:07:00.000+09:002013-10-20T19:08:02.590+09:00RCIP<div class="separator" style="clear: both; text-align: center;">
<a href="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEjOBRZ_LdZbaXYKnxDYyqCkavFsp99E2kHLyFdA04tNsT7L_RggjPgpC6SWDjZO0e46BttVCE9sb6KWNE40YK95eqtxT10ULH6BrVHmlDyXLerw11zo7yrObGQ4HEJnwuAk6OFz5li3IxrU/s1600/RCIP.png" imageanchor="1" style="margin-left: 1em; margin-right: 1em;"><img border="0" height="240" src="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEjOBRZ_LdZbaXYKnxDYyqCkavFsp99E2kHLyFdA04tNsT7L_RggjPgpC6SWDjZO0e46BttVCE9sb6KWNE40YK95eqtxT10ULH6BrVHmlDyXLerw11zo7yrObGQ4HEJnwuAk6OFz5li3IxrU/s320/RCIP.png" width="320" /></a></div>
<br />
<div>
CIPは非常に優秀な移流方程式に対する解法ですが、不連続部に若干のオーバーシュート、アンダーシュートが残ります。</div>
<div>
<br /></div>
<div>
これは補間関数に3次関数を選択したためであり、これを避けるために、別の関数を使えば良いじゃん!というのが、RCIP(Rational CIP)基本的な考え方です。有理関数を使えばオーバーシュートアンダーシュートを抑えられます。</div>
<div>
<br /></div>
<div>
ソースを晒しておきます。まあ、汚いです。</div>
<div>
<br /></div>
<div>
<div>
#advection #################################################</div>
<div>
# RCIP ########### ########################################</div>
<div>
############################################################</div>
<div>
#import#####################################################</div>
<div>
from pylab import * </div>
<div>
#set parameters ############################################</div>
<div>
in_ff = open('test.txt')</div>
<div>
imx=100</div>
<div>
dx=1.0</div>
<div>
dt=0.2</div>
<div>
u=0.2</div>
<div>
alpha = 1.0</div>
<div>
eps = 1.0e-15</div>
<div>
print "-"*40</div>
<div>
print "u =",u</div>
<div>
print "dx =",dx</div>
<div>
print "dt =",dt</div>
<div>
print "-"*40</div>
<div>
############################################################</div>
<div>
#initial condition ################################</div>
<div>
f= [0]</div>
<div>
fn= [0]</div>
<div>
df = [0]</div>
<div>
dfn = [0]</div>
<div>
fini=[0]</div>
<div>
fl= [0]</div>
<div>
fr= [0]</div>
<div>
x= [0]</div>
<div>
abm= [0]</div>
<div>
xl= [0]</div>
<div>
f_tilde = [0]</div>
<div>
fex = [0]</div>
<div>
i=1</div>
<div>
for x in in_ff:</div>
<div>
<span class="Apple-tab-span" style="white-space: pre;"> </span>print i</div>
<div>
<span class="Apple-tab-span" style="white-space: pre;"> </span>a = x.split("<span class="Apple-tab-span" style="white-space: pre;"> </span>")</div>
<div>
<span class="Apple-tab-span" style="white-space: pre;"> </span>for k in range(0,1):</div>
<div>
<span class="Apple-tab-span" style="white-space: pre;"> </span>print a[k]</div>
<div>
<span class="Apple-tab-span" style="white-space: pre;"> </span>xl=xl+[float(a[0])]</div>
<div>
<span class="Apple-tab-span" style="white-space: pre;"> </span>f=f+[float(a[1])]</div>
<div>
<span class="Apple-tab-span" style="white-space: pre;"> </span>fini=fini+[float(a[1])]</div>
<div>
<span class="Apple-tab-span" style="white-space: pre;"> </span>fn=fn+[float(a[1])]</div>
<div>
<span class="Apple-tab-span" style="white-space: pre;"> </span>fl=fl+[float(a[1])]</div>
<div>
<span class="Apple-tab-span" style="white-space: pre;"> </span>fr=fr+[float(a[1])]</div>
<div>
<span class="Apple-tab-span" style="white-space: pre;"> </span>f_tilde = f_tilde + [0]</div>
<div>
<span class="Apple-tab-span" style="white-space: pre;"> </span>fex = fex + [0]</div>
<div>
<span class="Apple-tab-span" style="white-space: pre;"> </span>df = df + [0]</div>
<div>
<span class="Apple-tab-span" style="white-space: pre;"> </span>dfn = dfn + [0]</div>
<div>
<span class="Apple-tab-span" style="white-space: pre;"> </span>i=i+1</div>
<div>
imx=i</div>
<div>
adm=[0.0]</div>
<div>
for i in range(1,imx):</div>
<div>
<span class="Apple-tab-span" style="white-space: pre;"> </span>adm=adm+[0.0]</div>
<div>
print "*"*40</div>
<div>
print "xl,f"</div>
<div>
for i in range(0,imx-1):</div>
<div>
<span class="Apple-tab-span" style="white-space: pre;"> </span>print float(xl[i])," ",float(f[i])</div>
<div>
# set parameter ####################################</div>
<div>
for n in range(0,1000):</div>
<div>
<span class="Apple-tab-span" style="white-space: pre;"> </span>###############################</div>
<div>
<span class="Apple-tab-span" style="white-space: pre;"> </span>for i in range(1,imx-1):</div>
<div>
<span class="Apple-tab-span" style="white-space: pre;"> </span>if u>=0.0:</div>
<div>
<span class="Apple-tab-span" style="white-space: pre;"> </span>ip = i - 1</div>
<div>
<span class="Apple-tab-span" style="white-space: pre;"> </span>dd = -dx</div>
<div>
<span class="Apple-tab-span" style="white-space: pre;"> </span>else:</div>
<div>
<span class="Apple-tab-span" style="white-space: pre;"> </span>ip = i + 1</div>
<div>
<span class="Apple-tab-span" style="white-space: pre;"> </span>dd = dx</div>
<div>
<span class="Apple-tab-span" style="white-space: pre;"> </span>xi = -u*dt</div>
<div>
<span class="Apple-tab-span" style="white-space: pre;"> </span>S = (f[ip]-f[i])/dd</div>
<div>
<span class="Apple-tab-span" style="white-space: pre;"> </span>if S - f[ip] >0.0:</div>
<div>
<span class="Apple-tab-span" style="white-space: pre;"> </span>isgn = 1.0</div>
<div>
<span class="Apple-tab-span" style="white-space: pre;"> </span>else:</div>
<div>
<span class="Apple-tab-span" style="white-space: pre;"> </span>isgn = -1.0</div>
<div>
<span class="Apple-tab-span" style="white-space: pre;"> </span>TS = f[ip]-S</div>
<div>
<span class="Apple-tab-span" style="white-space: pre;"> </span>BB = ((abs(S-df[i])+eps)/(abs(S-df[ip])+eps)-1.0)/dd</div>
<div>
<br /></div>
<div>
<span class="Apple-tab-span" style="white-space: pre;"> </span>a3 = (df[i]-S+(df[ip]-S)*(1.0+alpha*BB*dd))/(dd*dd)</div>
<div>
<span class="Apple-tab-span" style="white-space: pre;"> </span>a2 = S*alpha*BB+(S-df[i])/dd-a3*dd</div>
<div>
<span class="Apple-tab-span" style="white-space: pre;"> </span>a1 = df[i] +f[i]*alpha * BB</div>
<div>
<span class="Apple-tab-span" style="white-space: pre;"> </span>a0 = f[i]</div>
<div>
<span class="Apple-tab-span" style="white-space: pre;"> </span>fn[i] = (a3*xi*xi*xi+a2*xi*xi+a1*xi+a0)/(1.0+alpha*BB*xi)</div>
<div>
<span class="Apple-tab-span" style="white-space: pre;"> </span>dfn[i] = (3.0*a3*xi*xi+2.0*a2*xi+a1)/(1.0+alpha*BB*xi)-(alpha*BB)*(fn[i])/(1.0+alpha*BB*xi)</div>
<div>
<span class="Apple-tab-span" style="white-space: pre;"> </span>#shift#########################################</div>
<div>
<span class="Apple-tab-span" style="white-space: pre;"> </span>for i in range(1,imx-1):</div>
<div>
<span class="Apple-tab-span" style="white-space: pre;"> </span>f[i]=fn[i]</div>
<div>
<span class="Apple-tab-span" style="white-space: pre;"> </span>df[i]=dfn[i]</div>
<div>
print fn</div>
<div>
###################################################</div>
<div>
# Exact ###########################################</div>
<div>
for i in range(0,imx-1):</div>
<div>
<span class="Apple-tab-span" style="white-space: pre;"> </span>if i>=50 and i<=60:</div>
<div>
<span class="Apple-tab-span" style="white-space: pre;"> </span>fex[i] = 1.0</div>
<div>
<span class="Apple-tab-span" style="white-space: pre;"> </span>else:</div>
<div>
<span class="Apple-tab-span" style="white-space: pre;"> </span>fex[i] = 0.0</div>
<div>
#output############################################</div>
<div>
ff=open("output.dat","w")</div>
<div>
for i in range(0,imx-1):</div>
<div>
<span class="Apple-tab-span" style="white-space: pre;"> </span>ff.write(str(xl[i]))</div>
<div>
<span class="Apple-tab-span" style="white-space: pre;"> </span>ff.write(" ")</div>
<div>
<span class="Apple-tab-span" style="white-space: pre;"> </span>ff.write(str(f[i]))</div>
<div>
<span class="Apple-tab-span" style="white-space: pre;"> </span>ff.write("\n")</div>
<div>
ff.close()</div>
<div>
#output</div>
<div>
#for i in range(0,imx-1):</div>
<div>
#<span class="Apple-tab-span" style="white-space: pre;"> </span>print f[i]</div>
<div>
print "-"*100</div>
<div>
print xl</div>
<div>
print f</div>
<div>
#####################graph#########################</div>
<div>
y1=f</div>
<div>
y2=fini</div>
<div>
y3=fex</div>
<div>
plot(xl,y1,label = 'RCIP')</div>
<div>
plot(xl,y2,label = 'INITIAL')</div>
<div>
plot(xl,y3,label = 'EXACT')</div>
<div>
xlabel('x')</div>
<div>
ylabel('f')</div>
<div>
title('RCIP')</div>
<div>
axis([-0,100.0,-0.2,1.2])</div>
<div>
legend()</div>
<div>
grid(True)</div>
<div>
savefig('RCIP')</div>
<div>
show()</div>
<div>
###################################################</div>
</div>
<div>
<br /></div>
<div>
<br /></div>
にしるhttp://www.blogger.com/profile/14158676822605584570noreply@blogger.com0tag:blogger.com,1999:blog-8085514949557020263.post-25591322911281880722013-10-20T13:07:00.003+09:002013-10-20T19:08:02.588+09:00等間隔WENOWENOは格子間をラグランジュ補間して、スムーズインジケーターで修正する手法らしいです。ただ、あくまで私の理解であり、正しい認識を提供するものではありません。<br />
<br />
河川の流れを対象とし、RANSを用いた計算だと、WENOのような高級な手法を用いることはありませんが、勉強がてらやってみました。<br />
<br />
汚いですが、ソースも晒しておきます。たぶん間違いがあると思いますので、あくまで参考ということで。<br />
<br />
あとは不等間隔の場合、係数が異なるように思いますので、座標変換して解くような手法(格子間隔を一定として変換)でない限り、修正が必要かと思います。QUICKと同様ですね。<br />
<br />
<div class="separator" style="clear: both; text-align: center;">
<a href="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEhZQrY1TyuaGxaoloBGz4dJ3mLRvIzOwqlPo5roVbz5kKvqFNCTxfPoWVKAN9-2FjptfZ9y7-0LFdcYN3pxvma2rUDVm9Wj3WVYVGJynadLCXTmxSnqp6oa4xvTaeYN7a67OkjNbyMuxqlJ/s1600/WENO.png" imageanchor="1" style="margin-left: 1em; margin-right: 1em;"><img border="0" height="240" src="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEhZQrY1TyuaGxaoloBGz4dJ3mLRvIzOwqlPo5roVbz5kKvqFNCTxfPoWVKAN9-2FjptfZ9y7-0LFdcYN3pxvma2rUDVm9Wj3WVYVGJynadLCXTmxSnqp6oa4xvTaeYN7a67OkjNbyMuxqlJ/s320/WENO.png" width="320" /></a></div>
<br />
<br />
#advection #################################################<br />
# WENO ########################################<br />
############################################################<br />
#import#####################################################<br />
from pylab import *<br />
def calflux1(u,f,flm,flp):<br />
<span class="Apple-tab-span" style="white-space: pre;"> </span>alpha = 0.0<br />
<span class="Apple-tab-span" style="white-space: pre;"> </span>for i in range(1,imx-1):<br />
<span class="Apple-tab-span" style="white-space: pre;"> </span>alpha_tmp = u<br />
<span class="Apple-tab-span" style="white-space: pre;"> </span>if abs(alpha_tmp) > abs(alpha):<br />
<span class="Apple-tab-span" style="white-space: pre;"> </span>alpha = alpha_tmp<br />
<span class="Apple-tab-span" style="white-space: pre;"> </span>for i in range(1,imx-1):<br />
<span class="Apple-tab-span" style="white-space: pre;"> </span>flm[i] = 0.5*(f[i]*u - alpha*f[i])<br />
<span class="Apple-tab-span" style="white-space: pre;"> </span>flp[i] = 0.5*(f[i]*u + alpha*f[i])<br />
<span class="Apple-tab-span" style="white-space: pre;"> </span>flm[0] = 0.0<br />
<span class="Apple-tab-span" style="white-space: pre;"> </span>flm[imx-1] = 0.0<br />
<span class="Apple-tab-span" style="white-space: pre;"> </span>flp[0] = 0.0<br />
<span class="Apple-tab-span" style="white-space: pre;"> </span>flp[imx-1] = 0.0<br />
def calflux2(i,omegam,omegap,flm,fip,fl2m,fl2p):<br />
<span class="Apple-tab-span" style="white-space: pre;"> </span>print i<br />
<span class="Apple-tab-span" style="white-space: pre;"> </span>fltmpp = [0]<br />
<span class="Apple-tab-span" style="white-space: pre;"> </span>fltmpm = [0]<br />
<span class="Apple-tab-span" style="white-space: pre;"> </span>for k in range(0,3):<br />
<span class="Apple-tab-span" style="white-space: pre;"> </span>fltmpp = fltmpp + [0]<br />
<span class="Apple-tab-span" style="white-space: pre;"> </span>fltmpm = fltmpm + [0]<br />
<br />
<span class="Apple-tab-span" style="white-space: pre;"> </span>fltmpp[0] = 1./3.*flp[i-2] - 7./6.*flp[i-1] + 11./6.*flp[i ]<br />
<span class="Apple-tab-span" style="white-space: pre;"> </span>fltmpp[1] = -1./6.*flp[i-1] + 5./6.*flp[i ] + 1./3.*flp[i+1]<br />
<span class="Apple-tab-span" style="white-space: pre;"> </span>fltmpp[2] = 1./3.*flp[i ] + 5./6.*flp[i+1] - 1./6.*flp[i+2]<br />
<span class="Apple-tab-span" style="white-space: pre;"> </span>fl2p[i] = 0.0<br />
<span class="Apple-tab-span" style="white-space: pre;"> </span>for k in range(0,3):<br />
<span class="Apple-tab-span" style="white-space: pre;"> </span>fl2p[i] = fl2p[i] + omegap[k]*fltmpp[k]<br />
<br />
<span class="Apple-tab-span" style="white-space: pre;"> </span>fltmpm[1] = -1./6. * flm[i-1] + 5./6. * flm[i ] + 2./6. * flm[i+1]<br />
<span class="Apple-tab-span" style="white-space: pre;"> </span>fltmpm[2] = 2./6. * flm[i ] + 5./6. * flm[i+1] - 1./6. * flm[i+2]<br />
<span class="Apple-tab-span" style="white-space: pre;"> </span>fltmpm[3] = 11./6. * flm[i+1] - 7./6. * flm[i+2] + 2./6. * flm[i+3]<br />
<span class="Apple-tab-span" style="white-space: pre;"> </span>fl2m[i] = 0.0<br />
<span class="Apple-tab-span" style="white-space: pre;"> </span>for k in range(0,3):<br />
<span class="Apple-tab-span" style="white-space: pre;"> </span>fl2m[i] = fl2m[i] + omegam[k]*fltmpm[k]<br />
in_ff = open("test.txt")<br />
dx=1.0<br />
dt=0.2<br />
u=0.2<br />
c1 = 1./10.<br />
c2 = 6./10.<br />
c3 = 3./10.<br />
eps = 1.0e-10<br />
print "-"*40<br />
print "u =",u<br />
print "dx =",dx<br />
print "dt =",dt<br />
print "-"*40<br />
############################################################<br />
#initial condition ################################<br />
f= [0]<br />
fn= [0]<br />
fini=[0]<br />
fl= [0]<br />
fr= [0]<br />
fex = [0]<br />
x= [0]<br />
abm= [0]<br />
xl= [0]<br />
flm = [0]<br />
flp = [0]<br />
flux = [0]<br />
flux1 =[0]<br />
flux2 =[0]<br />
flux3 =[0]<br />
fl2m = [0]<br />
fl2p = [0]<br />
i=1<br />
for x in in_ff:<br />
<span class="Apple-tab-span" style="white-space: pre;"> </span>print i<br />
<span class="Apple-tab-span" style="white-space: pre;"> </span>a = x.split("<span class="Apple-tab-span" style="white-space: pre;"> </span>")<br />
<span class="Apple-tab-span" style="white-space: pre;"> </span>for k in range(0,1):<br />
<span class="Apple-tab-span" style="white-space: pre;"> </span>print a[k]<br />
<span class="Apple-tab-span" style="white-space: pre;"> </span>xl=xl+[float(a[0])]<br />
<span class="Apple-tab-span" style="white-space: pre;"> </span>f=f+[float(a[1])]<br />
<span class="Apple-tab-span" style="white-space: pre;"> </span>fini=fini+[float(a[1])]<br />
<span class="Apple-tab-span" style="white-space: pre;"> </span>fn=fn+[float(a[1])]<br />
<span class="Apple-tab-span" style="white-space: pre;"> </span>fl=fl+[float(a[1])]<br />
<span class="Apple-tab-span" style="white-space: pre;"> </span>fr=fr+[float(a[1])]<br />
<span class="Apple-tab-span" style="white-space: pre;"> </span>i=i+1<br />
<span class="Apple-tab-span" style="white-space: pre;"> </span>fex = fex+[float(a[1])]<br />
<span class="Apple-tab-span" style="white-space: pre;"> </span>flux = flux + [0]<br />
<span class="Apple-tab-span" style="white-space: pre;"> </span>flux1 = flux1 + [0]<br />
<span class="Apple-tab-span" style="white-space: pre;"> </span>flux2 = flux2 + [0]<br />
<span class="Apple-tab-span" style="white-space: pre;"> </span>flux3 = flux3 + [0]<br />
<span class="Apple-tab-span" style="white-space: pre;"> </span>flm = flm + [0]<br />
<span class="Apple-tab-span" style="white-space: pre;"> </span>flp = flp + [0]<br />
<span class="Apple-tab-span" style="white-space: pre;"> </span>fl2m = fl2m + [0]<br />
<span class="Apple-tab-span" style="white-space: pre;"> </span>fl2p = fl2p + [0]<br />
<br />
imx=i<br />
adm=[0.0]<br />
alpham = [0]<br />
alphap = [0]<br />
omegam = [0]<br />
omegap = [0]<br />
<br />
<br />
for k in range(0,3):<br />
<span class="Apple-tab-span" style="white-space: pre;"> </span>alpham = alpham + [0]<br />
<span class="Apple-tab-span" style="white-space: pre;"> </span>alphap = alphap + [0]<br />
<span class="Apple-tab-span" style="white-space: pre;"> </span>omegam = omegam + [0]<br />
<span class="Apple-tab-span" style="white-space: pre;"> </span>omegap = omegap + [0]<br />
print "*"*40<br />
print "xl,f"<br />
for i in range(0,imx-1):<br />
<span class="Apple-tab-span" style="white-space: pre;"> </span>print float(xl[i])," ",float(f[i])<br />
# set parameter ####################################<br />
# 1st order upwind ####################################<br />
for n in range(0,1000):<br />
<span class="Apple-tab-span" style="white-space: pre;"> </span>calflux1(u,f,flm,flp)<br />
<span class="Apple-tab-span" style="white-space: pre;"> </span><br />
<span class="Apple-tab-span" style="white-space: pre;"> </span># WENO<br />
<span class="Apple-tab-span" style="white-space: pre;"> </span>for i in range(3,imx-4):<br />
<br />
<span class="Apple-tab-span" style="white-space: pre;"> </span>isp1 = 13./12.*(flp[i-2]-2.0*flp[i-1]+flp[i])*(flp[i-2]-2.0*flp[i-1]+flp[i])+1.0/4.0*(flp[i-2]-4.0*flp[i-1]+3.0*flp[i])*(flp[i-2]-4.0*flp[i-1]+3.0*flp[i])<br />
<span class="Apple-tab-span" style="white-space: pre;"> </span>isp2 = 13./12.*(flp[i-1]-2.0*flp[i]+flp[i+1])*(flp[i-1]-2.0*flp[i]+flp[i+1])+1.0/4.0*(flp[i-1]-flp[i+1])*(flp[i-1]-flp[i+1])<br />
<span class="Apple-tab-span" style="white-space: pre;"> </span>isp3 = 13./12.*(flp[i]-2.*flp[i+1]+flp[i+2])*(flp[i]-2.*flp[i+1]+flp[i+2])+1./4.0*(3.*flp[i]-4.*flp[i+1]+flp[i+2])*(3.*flp[i]-4.*flp[i+1]+flp[i+2])<br />
<span class="Apple-tab-span" style="white-space: pre;"> </span><br />
<span class="Apple-tab-span" style="white-space: pre;"> </span>ism1 = 13./12.*(flm[i+1]-2.0*flm[i+2]+flm[i+3])*(flm[i+1]-2.0*flm[i+2]+flm[i+3])+1.0/4.0*(3.0*flm[i+1]-4.0*flm[i+2]+flm[i+3])*(3.0*flm[i+1]-4.0*flm[i+2]+flm[i+3])<br />
<span class="Apple-tab-span" style="white-space: pre;"> </span>ism2 = 13./12.*(flm[i]-2.0*flm[i+1]+flm[i+2])*(flm[i]-2.0*flm[i+1]+flm[i+2])+1.0/4.0*(flm[i]-flm[i+2])*(flm[i]-flm[i+2])<br />
<span class="Apple-tab-span" style="white-space: pre;"> </span>ism3 = 13./12.*(flm[i-1]-2.0*flm[i ]+flm[i+1])*(flm[i-1]-2.0*flm[i]+flm[i+1])+1./4.0*(flm[i-1]-4.*flm[i]+3.*flm[i+1])*(flm[i-1]-4.*flm[i]+3.*flm[i+1])<br />
<span class="Apple-tab-span" style="white-space: pre;"> </span>#<br />
<span class="Apple-tab-span" style="white-space: pre;"> </span>alpham[0] = c1/(eps + ism1)/(eps+ism1)<br />
<span class="Apple-tab-span" style="white-space: pre;"> </span>alpham[1] = c2/(eps + ism2)/(eps+ism2)<br />
<span class="Apple-tab-span" style="white-space: pre;"> </span>alpham[2] = c3/(eps + ism3)/(eps+ism3)<br />
<span class="Apple-tab-span" style="white-space: pre;"> </span>#<br />
<span class="Apple-tab-span" style="white-space: pre;"> </span>alphap[0] = c1/(eps + isp1)/(eps+isp1)<br />
<span class="Apple-tab-span" style="white-space: pre;"> </span>alphap[1] = c2/(eps + isp2)/(eps+isp2)<br />
<span class="Apple-tab-span" style="white-space: pre;"> </span>alphap[2] = c3/(eps + isp3)/(eps+isp3)<br />
<span class="Apple-tab-span" style="white-space: pre;"> </span>#<br />
<span class="Apple-tab-span" style="white-space: pre;"> </span>sigmaalpham = alpham[0] +alpham[1] +alpham[2]<br />
<span class="Apple-tab-span" style="white-space: pre;"> </span>sigmaalphap = alphap[0] +alphap[1] +alphap[2]<br />
<span class="Apple-tab-span" style="white-space: pre;"> </span>#<br />
<span class="Apple-tab-span" style="white-space: pre;"> </span>omegam[0] = alpham[0] / sigmaalpham<br />
<span class="Apple-tab-span" style="white-space: pre;"> </span>omegam[1] = alpham[1] / sigmaalpham<br />
<span class="Apple-tab-span" style="white-space: pre;"> </span>omegam[2] = alpham[2] / sigmaalpham<br />
<span class="Apple-tab-span" style="white-space: pre;"> </span><br />
<span class="Apple-tab-span" style="white-space: pre;"> </span>omegap[0] = alphap[0] / sigmaalphap<br />
<span class="Apple-tab-span" style="white-space: pre;"> </span>omegap[1] = alphap[1] / sigmaalphap<br />
<span class="Apple-tab-span" style="white-space: pre;"> </span>omegap[2] = alphap[2] / sigmaalphap<br />
<span class="Apple-tab-span" style="white-space: pre;"> </span><br />
<span class="Apple-tab-span" style="white-space: pre;"> </span>calflux2(i,omegam,omegap,flm,flp,fl2m,fl2p)<br />
<span class="Apple-tab-span" style="white-space: pre;"> </span>fl2m[2] = 0.0<br />
<span class="Apple-tab-span" style="white-space: pre;"> </span>fl2m[1] = 0.0<br />
<span class="Apple-tab-span" style="white-space: pre;"> </span>fl2m[0] = 0.0<br />
<span class="Apple-tab-span" style="white-space: pre;"> </span>fl2p[2] = 0.0<br />
<span class="Apple-tab-span" style="white-space: pre;"> </span>fl2p[1] = 0.0<br />
<span class="Apple-tab-span" style="white-space: pre;"> </span>fl2p[0] = 0.0<br />
<span class="Apple-tab-span" style="white-space: pre;"> </span><br />
<span class="Apple-tab-span" style="white-space: pre;"> </span>fl2m[imx-1] = 0.0<br />
<span class="Apple-tab-span" style="white-space: pre;"> </span>fl2m[imx-2] = 0.0<br />
<span class="Apple-tab-span" style="white-space: pre;"> </span>fl2m[imx-3] = 0.0<br />
<span class="Apple-tab-span" style="white-space: pre;"> </span>fl2p[imx-1] = 0.0<br />
<span class="Apple-tab-span" style="white-space: pre;"> </span>fl2p[imx-2] = 0.0<br />
<span class="Apple-tab-span" style="white-space: pre;"> </span>fl2p[imx-3] = 0.0<br />
<span class="Apple-tab-span" style="white-space: pre;"> </span># EULER ##############################<br />
<span class="Apple-tab-span" style="white-space: pre;"> </span>for i in range(3,imx-4):#0~imx-1<br />
<span class="Apple-tab-span" style="white-space: pre;"> </span>fn[i]=f[i]-dt*(fl2p[i]-fl2p[i-1]+fl2m[i]-fl2m[i-1])/(dx)<br />
<span class="Apple-tab-span" style="white-space: pre;"> </span>#shift#########################################<br />
<span class="Apple-tab-span" style="white-space: pre;"> </span>for i in range(2,imx-2):<br />
<span class="Apple-tab-span" style="white-space: pre;"> </span>f[i]=fn[i]<br />
print fn<br />
###################################################<br />
# Exact ###########################################<br />
for i in range(0,imx-1):<br />
<span class="Apple-tab-span" style="white-space: pre;"> </span>if i>=50 and i<=60:<br />
<span class="Apple-tab-span" style="white-space: pre;"> </span>fex[i] = 1.0<br />
<span class="Apple-tab-span" style="white-space: pre;"> </span>else:<br />
<span class="Apple-tab-span" style="white-space: pre;"> </span>fex[i] = 0.0<br />
#output############################################<br />
ff=open("output.dat","w")<br />
for i in range(0,imx-1):<br />
<span class="Apple-tab-span" style="white-space: pre;"> </span>ff.write(str(xl[i]))<br />
<span class="Apple-tab-span" style="white-space: pre;"> </span>ff.write(" ")<br />
<span class="Apple-tab-span" style="white-space: pre;"> </span>ff.write(str(f[i]))<br />
<span class="Apple-tab-span" style="white-space: pre;"> </span>ff.write("\n")<br />
ff.close()<br />
#output<br />
#for i in range(0,imx-1):<br />
#<span class="Apple-tab-span" style="white-space: pre;"> </span>print f[i]<br />
print "-"*100<br />
print xl<br />
print f<br />
#####################graph#########################<br />
y1=f<br />
y2=fini<br />
y3 = fex<br />
plot(xl,y1,label = 'WENO')<br />
plot(xl,y2,label = 'INITIAL')<br />
plot(xl,y3,label = 'EXACT')<br />
xlabel('x')<br />
ylabel('f')<br />
title('WENO')<br />
axis([-0,100.0,-0.2,1.2])<br />
legend()<br />
grid(True)<br />
savefig('WENO')<br />
show()<br />
###################################################<br />
<div>
<br /></div>
にしるhttp://www.blogger.com/profile/14158676822605584570noreply@blogger.com0tag:blogger.com,1999:blog-8085514949557020263.post-4147248339478144042013-10-16T20:52:00.001+09:002013-10-17T09:37:33.395+09:00HartenYee汚いですし、直したいところはたくさんありますが、<br />
晒すことにします。<br />
<br />
HartenYeeの2nd Order Upwindです。<br />
おそらく数値計算ハンドブックにも載ってるような記憶がありますが、<br />
基本的には藤井先生の本をトレースしたものです。<br />
「test.txt」は0〜100の格子番号iに対して10<i<20でf=1.0、その他で0としています。<br />
<br />
あとは[pylab]を入れていればそのまま描画されるはずです。<br />
ない場合は、import以下を消して最後のグラフ描画部分も消して下さい。<br />
<br />
数年前のプログラムに、修正を施しただけですので、<br />
もっと、きれいに書けます(もっとOOPな感じで)が、まあ、残しておきます(笑)<br />
<br />
OOPならC++、Rubyで書いてますが、Rubyが一番オブジェクト指向にしっくりきます。<br />
<br />
ただ、科学技術計算ならPythonが一番使いやすいと思います。描画は特に。<br />
<br />
ちなみにHartenYeeのスキームはあまり利用されていないようですが、<br />
Non-MUSCL系だと好きだったりします。<br />
<br />
「中央差分に修正流束を加算する」というスキームの形になってるのが理解しやすいです。<br />
<br />
<br />
<br />
#advection #################################################<br />
# Harten Yee Upwind ########################################<br />
############################################################<br />
#import#####################################################<br />
from pylab import *<br />
<br />
<br />
# Harten Yee ##############################################<br />
def cal_fai(z):<br />
<span class="Apple-tab-span" style="white-space: pre;"> </span>eps = 0.0001<br />
<span class="Apple-tab-span" style="white-space: pre;"> </span>if abs(z) > eps:<br />
<span class="Apple-tab-span" style="white-space: pre;"> </span>return abs(z)<br />
<span class="Apple-tab-span" style="white-space: pre;"> </span>else:<br />
<span class="Apple-tab-span" style="white-space: pre;"> </span>return (z*z+eps*eps)/(2*eps)<br />
def cal_sigma(z,dt,dx):<br />
<span class="Apple-tab-span" style="white-space: pre;"> </span>return 0.5*(cal_fai(z)-dt/dx*z*z)<br />
def minmod(x,y):<br />
<span class="Apple-tab-span" style="white-space: pre;"> </span>if abs(x)<=abs(y) and x*y >=0.0:<br />
<span class="Apple-tab-span" style="white-space: pre;"> </span>return x<br />
<span class="Apple-tab-span" style="white-space: pre;"> </span>elif abs(x)>abs(y) and x*y >= 0.0:<br />
<span class="Apple-tab-span" style="white-space: pre;"> </span>return y<br />
<span class="Apple-tab-span" style="white-space: pre;"> </span>elif x*y<0:<br />
<span class="Apple-tab-span" style="white-space: pre;"> </span>return 0.0<br />
<span class="Apple-tab-span" style="white-space: pre;"> </span>else:<br />
<span class="Apple-tab-span" style="white-space: pre;"> </span>print "Error minmode2"<br />
#set parameters ############################################<br />
in_ff = open('test.txt')<br />
imx=100<br />
dx = 1.0<br />
dt = 0.2<br />
u = 0.2<br />
print "-"*40<br />
print "u =",u<br />
print "dx =",dx<br />
print "dt =",dt<br />
print "-"*40<br />
############################################################<br />
#initial condition ################################<br />
f= [0]<br />
fn= [0]<br />
fini=[0]<br />
fl= [0]<br />
fr= [0]<br />
x= [0]<br />
abm= [0]<br />
xl= [0]<br />
f_tilde = [0.0]<br />
limiter = [0.0]<br />
fex=[0]<br />
df = [0]<br />
gi = [0]<br />
gamma = [0]<br />
fai = [0]<br />
i=1<br />
for x in in_ff:<br />
<span class="Apple-tab-span" style="white-space: pre;"> </span>print i<br />
<span class="Apple-tab-span" style="white-space: pre;"> </span>a = x.split("<span class="Apple-tab-span" style="white-space: pre;"> </span>")<br />
<span class="Apple-tab-span" style="white-space: pre;"> </span>for k in range(0,1):<br />
<span class="Apple-tab-span" style="white-space: pre;"> </span>print a[k]<br />
<span class="Apple-tab-span" style="white-space: pre;"> </span>xl=xl+[float(a[0])]<br />
<span class="Apple-tab-span" style="white-space: pre;"> </span>f=f+[float(a[1])]<br />
<span class="Apple-tab-span" style="white-space: pre;"> </span>fini=fini+[float(a[1])]<br />
<span class="Apple-tab-span" style="white-space: pre;"> </span>fn=fn+[float(a[1])]<br />
<span class="Apple-tab-span" style="white-space: pre;"> </span>fl=fl+[float(a[1])]<br />
<span class="Apple-tab-span" style="white-space: pre;"> </span>fr=fr+[float(a[1])]<br />
<span class="Apple-tab-span" style="white-space: pre;"> </span>f_tilde = f_tilde+[0.0]<br />
<span class="Apple-tab-span" style="white-space: pre;"> </span>fex = fex+[float(a[1])]<br />
<span class="Apple-tab-span" style="white-space: pre;"> </span>limiter = limiter+[0.0]<br />
<span class="Apple-tab-span" style="white-space: pre;"> </span>df = df + [0.0]<br />
<span class="Apple-tab-span" style="white-space: pre;"> </span>gi = gi +[0.0]<br />
<span class="Apple-tab-span" style="white-space: pre;"> </span>gamma = gamma + [0.0]<br />
<span class="Apple-tab-span" style="white-space: pre;"> </span>fai = fai + [0.0]<br />
<span class="Apple-tab-span" style="white-space: pre;"> </span>i=i+1<br />
imx=i<br />
print "imx=",imx<br />
print "*"*40<br />
print "xl,f"<br />
for i in range(0,imx):<br />
<span class="Apple-tab-span" style="white-space: pre;"> </span>print i," ",float(xl[i])," ",float(f[i])<br />
# Time integration ################################<br />
for n in range(0,1000):<br />
<span class="Apple-tab-span" style="white-space: pre;"> </span>#LAX-WEDNROFF##############################<br />
<span class="Apple-tab-span" style="white-space: pre;"> </span>for i in range(0,imx-1):<br />
<span class="Apple-tab-span" style="white-space: pre;"> </span>df[i] = f[i+1] - f[i]<br />
<span class="Apple-tab-span" style="white-space: pre;"> </span>for i in range(2,imx-1):<br />
<span class="Apple-tab-span" style="white-space: pre;"> </span>gi[i] = minmod(df[i],df[i-1])<br />
<span class="Apple-tab-span" style="white-space: pre;"> </span>for i in range(3,imx-2):<br />
<span class="Apple-tab-span" style="white-space: pre;"> </span>if df[i]!=0.0:<br />
<span class="Apple-tab-span" style="white-space: pre;"> </span>#print i,df[i],gi[i],gi[i+1]<br />
<span class="Apple-tab-span" style="white-space: pre;"> </span>gamma[i] = cal_sigma(u,dt,dx)*(gi[i+1]-gi[i])/df[i]<br />
<span class="Apple-tab-span" style="white-space: pre;"> </span>else:<br />
<span class="Apple-tab-span" style="white-space: pre;"> </span>gamma[i] = 0.0<br />
<span class="Apple-tab-span" style="white-space: pre;"> </span>for i in range(2,imx-1):<br />
<span class="Apple-tab-span" style="white-space: pre;"> </span>fai[i] = cal_sigma(u,dt,dx)*(gi[i]+gi[i+1])-cal_fai(u+gamma[i])*df[i]<br />
<span class="Apple-tab-span" style="white-space: pre;"> </span>for i in range(1,imx-3): # Numerical Flux<br />
<span class="Apple-tab-span" style="white-space: pre;"> </span>CS = 0.5*(u* f[i+1] + u*f[i] ) # CS:Centered Space<br />
<span class="Apple-tab-span" style="white-space: pre;"> </span>CF = 0.5*fai[i]<span class="Apple-tab-span" style="white-space: pre;"> </span> # CF:Correct Flux<br />
<span class="Apple-tab-span" style="white-space: pre;"> </span>f_tilde[i] = CS + CF<span class="Apple-tab-span" style="white-space: pre;"> </span> # Numerical FLUX<br />
<span class="Apple-tab-span" style="white-space: pre;"> </span>#print i,limit<br />
<span class="Apple-tab-span" style="white-space: pre;"> </span>for i in range(2,imx-2):#0~imx-1<br />
<span class="Apple-tab-span" style="white-space: pre;"> </span>fn[i] = f[i] - dt/dx*(f_tilde[i] - f_tilde[i-1])<br />
<span class="Apple-tab-span" style="white-space: pre;"> </span>#shift#########################################<br />
<span class="Apple-tab-span" style="white-space: pre;"> </span>for i in range(2,imx-2):<br />
<span class="Apple-tab-span" style="white-space: pre;"> </span>f[i]=fn[i]<br />
print fn<br />
###################################################<br />
# Exact ###########################################<br />
for i in range(0,imx-1):<br />
<span class="Apple-tab-span" style="white-space: pre;"> </span>if i>=50 and i<=60:<br />
<span class="Apple-tab-span" style="white-space: pre;"> </span>fex[i] = 1.0<br />
<span class="Apple-tab-span" style="white-space: pre;"> </span>else:<br />
<span class="Apple-tab-span" style="white-space: pre;"> </span>fex[i] = 0.0<br />
#output############################################<br />
ff=open("output.dat","w")<br />
for i in range(0,imx-1):<br />
<span class="Apple-tab-span" style="white-space: pre;"> </span>ff.write(str(xl[i]))<br />
<span class="Apple-tab-span" style="white-space: pre;"> </span>ff.write(" ")<br />
<span class="Apple-tab-span" style="white-space: pre;"> </span>ff.write(str(f[i]))<br />
<span class="Apple-tab-span" style="white-space: pre;"> </span>ff.write("\n")<br />
ff.close()<br />
#output<br />
#for i in range(0,imx-1):<br />
#<span class="Apple-tab-span" style="white-space: pre;"> </span>print f[i]<br />
print "-"*100<br />
print xl<br />
print f<br />
#####################graph#########################<br />
y1=f<br />
y2=fini<br />
y3=fex<br />
plot(xl,y1,label = 'Harten-Yee')<br />
plot(xl,y2,label = 'INITIAL')<br />
plot(xl,y3,label = 'EXACT')<br />
xlabel('x')<br />
ylabel('f')<br />
title('Hatren-Yee')<br />
axis([-0,100.0,-0.2,1.2])<br />
legend()<br />
grid(True)<br />
savefig('Harten-Yee')<br />
show()<br />
###################################################<br />
<div>
<br /></div>
にしるhttp://www.blogger.com/profile/14158676822605584570noreply@blogger.com0tag:blogger.com,1999:blog-8085514949557020263.post-22633995604198050932013-10-10T22:51:00.001+09:002013-10-10T22:51:29.873+09:00MUSCL<div class="separator" style="clear: both; text-align: center;">
<a href="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEhaEWH-4ddLyempq2c4NT7-tIonYIXcn1F7b4wc1jWw9FxHyb5DqlReYozEqnWjv5vRC9Of9ZPxsw8K4Hd-Xh58_sQs8dRcr5nAMnjqqRnG0sKExFkkoKS4ZyQk0vgcpbSpgQ6KyPQj4GKu/s1600/MUSCL.png" imageanchor="1" style="margin-left: 1em; margin-right: 1em;"><img border="0" height="232" src="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEhaEWH-4ddLyempq2c4NT7-tIonYIXcn1F7b4wc1jWw9FxHyb5DqlReYozEqnWjv5vRC9Of9ZPxsw8K4Hd-Xh58_sQs8dRcr5nAMnjqqRnG0sKExFkkoKS4ZyQk0vgcpbSpgQ6KyPQj4GKu/s320/MUSCL.png" width="320" /></a></div>
<br />
MUSCLをVBAで書いてみました。<br />
Minmod関数でリミッターを掛けてます。<br />
<br />
緑色はセル境界の内挿した値です。<br />
<br />
河川ならこの程度の精度があれば十分だと解釈してます。<br />
(個人的な意見です)<br />
<br />
ただし、移流項に対してのみTVD条件を満たす(システム系で解かずに、運動方程式の移流項に対してのみTVD条件を満たす)場合、他の項による不連続部に対して、リミッターがかかってしまうのではないかと気になっています。<br />
<br />
そうすると、熱移動と流れの数値解析や数値流体工学に議論されているハイブリット法が良いのか?と思いますが、アレは拡散項ありきなんですよね。河川だと拡散項が省略されることが多く、生成項が効いてきます。ハイブリッド法だと1次風上のみになってしまいます。<br />
<br />
ここら辺の議論については非常に興味深いです。誰も議論しないのだろうか?いや、精度的には意味がないのか?<br />
<br />
おそらく河川の流れの空間刻み幅は小さくしてもせいぜい数mなので、高次精度のスキームは必ず必要だと思ってます。<br />
<br />
勉強します。にしるhttp://www.blogger.com/profile/14158676822605584570noreply@blogger.com0tag:blogger.com,1999:blog-8085514949557020263.post-58017330491183134632013-09-29T22:29:00.002+09:002013-09-29T22:29:11.945+09:00空間2次精度<br />
空間2次精度についての話です。<br />
<br />
河川の流れであれば、<br />
1次精度風上差分では不十分でも、せいぜい2次精度があれば十分なようです。<br />
ダムブレークのような問題を解く必要はあまりないですから。<br />
<br />
2次精度だとベースをオリジナルのLaxWendroff法(2STEPではない)を用い、FluxLimiterを施すことで、大局2次精度を維持できます。<br />
<br />
CIP法を用いた非保存系のスキームも使われているようですが、既存のプログラムがある場合、書き換えるのが煩雑です。<br />
また、CIP法だとわずかに数値振動が残りますがTVDだと1次精度となって振動を抑えます。<br />
TVDだとMUSCLも使われているようですが、TVD-LaxWendroffは使われることは少ないようです。<br />
精度の高い乱流モデルを後々組み込むことを考えると、MUSCLという選択もわるくないと思います。<br />
<br />
以上の話は、ナビエストークス方程式(or レイノルズ方程式)のうちの移流項に対する解法であり、<br />
運動方程式、連続式をシステム系としてとらえた解法ではありません。なぜなら、生成項となる摩擦項や地形勾配項があるためであり、<br />
C-Propertyを満たすことが難しいためです。<br />
アカデミックの世界でも研究されている方はいるようですが、マニアックなまでに研究されている方はいないようです。<br />
すでに解決された問題だと捉えられているのでしょう。<br />
まあ、分っている人は少ないと思いますが・・・。<br />
<br />
<br />
<br />
<br />
にしるhttp://www.blogger.com/profile/14158676822605584570noreply@blogger.com0tag:blogger.com,1999:blog-8085514949557020263.post-40313642965196314312013-09-29T16:45:00.001+09:002013-09-29T16:45:13.528+09:00流体の数値計算法について(2)藤井先生の本についての続編です。<br /><br />一つ面白い記述に<br /><br />「最近の多くの実用的な計算結果を見る限りでは、一般的には2次精度を維持することが必要といえる」<br /><br />というのがあります。<br /><br />乱流の解析では2次精度では不十分な場合がありますが、多くは2次精度程度である程度事足りるとの指摘です。<br /><br />河川の流れの解析のように、平面2次元流れの解析であれば、この指摘は当てはまると思われます。<br /><br />平面2次元流れは、どの程度の流れの解像度を得ることが必要かで乱流モデルを選択する必要がありますが、多くの場合は、ブシネスク近似を使って、ゼロ方程式を用いたモデルが多いようです。<br /><br />①格子形状<br />格子形状は境界適合座標系を使い、スカラー量とベクトル量を互い違いに配置するスタッガード格子を採用します。<br /><br />②解析手法<br />有限体積法を用いることが多いですが、モデルによっては有限差分法が多いです。有限要素法は滅多にありませんが、アカデミックな世界では実施されていることもあります。<br />また、移流項に対しては、1次風上差分が非常に多いはずです。藤井先生の本を読まれる方は「は?」と思われるかもしれませんが、実用的な解析では、計算が飛ばないことが非常に重要です。<br />はっきり言って、解析についてあまり知らなくても、計算結果を確実に得ることが求められます。2次精度以上を確保しようとすると、不安定になる可能性が多くなりますので、1次風上が多いのです。<br />一方、移流項以外は、2次精度の中央差分が多いです。各項の大きさについての議論は別にして、移流項で3次精度以上を確保しようとすると、他の項も同様に3次精度以上を確保する必要があります。<br />したがって、移流項に対しては大局的空間2次精度程度を確保することが適切のようです。<br /><br />さて、藤井先生の本に戻りますが、前述の指摘がある程度的を得ています。<br />分野が違えど、面白い指摘だなと思った次第です。<br /><br /><br />なお、ブシネスク近似のうちk−εやLESを用いる場合はこの指摘は当てはまりません。<br />乱流モデルは、小生の間隔では3次精度以上が必要のようです。<br />にしるhttp://www.blogger.com/profile/14158676822605584570noreply@blogger.com0tag:blogger.com,1999:blog-8085514949557020263.post-49907818225723168362013-09-16T21:25:00.002+09:002013-09-16T21:25:23.956+09:00書籍<br />
「プログラミング言語AWK」<br />
AWKの本です。最近、USP Labから出版されたものです。<br />
もちろん著者はAWKの開発者であり、AWK版のK&Rと考えてもらえれば良いとおもいます。<br />
<br />
ただ、出版といっても、絶版しては再販されている書籍であり、<br />
需要がある書籍と言えましょう。<br />
<br />
読んだ感想ですが、古くさいです。<br />
ただ、K&Rよりも実用的であると感じます。<br />
スクリプト言語であり、ワンライナーによるフィルタをかけるだけであれば、序盤を読めばかなり書けるようになると思います。<br />
<br />
まあ、敢えてAWKを使う人はあまりいないと思います。今であれば、Perl、Python、Rubyを使えば比較的簡単にできます。<br />
それがテキスト処理だとしてもです。<br />
<br />
ただし、プログラミングの歴史を学ぶ点においては、知っておいて損はないかと。<br />
加えて、「プログラミングが、なぜ、今の形になったのか?」ということを理解する一つの助けとなる気がします。<br />
<br />
やはり、周辺知識は独立して使うことが出来るものではないですが、メインの知識と組み合わさって威力を発揮するものだと思います。<br />
<br />
にしるhttp://www.blogger.com/profile/14158676822605584570noreply@blogger.com0tag:blogger.com,1999:blog-8085514949557020263.post-69113449588215052422013-09-16T02:40:00.002+09:002013-09-16T02:48:42.558+09:00等間隔QUICKEST<br />
# 久々にpython<br />
<br />
for i in range(3,imx-3):#0~imx-1<br />
<span class="Apple-tab-span" style="white-space: pre;"> </span>c = u*dt/dx<span class="Apple-tab-span" style="white-space: pre;"> </span>#<br />
<span class="Apple-tab-span" style="white-space: pre;"> </span>if u >0:<br />
<span class="Apple-tab-span" style="white-space: pre;"> </span>fn[i] = f[i] - c/6*(2*f[i+1]+3*f[i]-6*f[i-1]+f[i-2]) \<br />
<span class="Apple-tab-span" style="white-space: pre;"> </span> + c*c/2*(f[i+1]-2*f[i]+f[i-1]) \<br />
<span class="Apple-tab-span" style="white-space: pre;"> </span> - c*c*c/6 *(f[i+1]-3*f[i]+3*f[i-1]-f[i-2])<br />
<span class="Apple-tab-span" style="white-space: pre;"> </span>else:<br />
<span class="Apple-tab-span" style="white-space: pre;"> </span>fn[i] = f[i] - c/6*(2*f[i-1]+3*f[i]-6*f[i+1]+f[i+2]) \<br />
<span class="Apple-tab-span" style="white-space: pre;"> </span> + c*c/2*(f[i+1]-2*f[i]+f[i-1]) \<br />
<span class="Apple-tab-span" style="white-space: pre;"> </span> - c*c*c/6 *(f[i-1]-3*f[i]+3*f[i+1]-f[i+2])<br />
<br />
等間隔にしか使えないですが・・・。<br />
一応、保存則を使っています。<br />
<br />
明日中には不等間隔+TVD化されたQUICKを晒したいです。<br />
<br />
<br />にしるhttp://www.blogger.com/profile/14158676822605584570noreply@blogger.com0tag:blogger.com,1999:blog-8085514949557020263.post-88943737609205470362013-09-13T06:10:00.001+09:002013-09-16T02:44:31.342+09:00書籍<span style="background-color: white; color: #222222; font-family: arial, sans-serif; font-size: 14px;">藤井先生著「流体力学の数値計算法」について書いておこうと思います。</span><br style="background-color: white; color: #222222; font-family: arial, sans-serif; font-size: 14px;" /><br style="background-color: white; color: #222222; font-family: arial, sans-serif; font-size: 14px;" /><span style="background-color: white; color: #222222; font-family: arial, sans-serif; font-size: 14px;">双曲型の数値計算法(保存性を意識した差分法)がメインです。</span><wbr style="background-color: white; color: #222222; font-family: arial, sans-serif; font-size: 14px;"></wbr><span style="background-color: white; color: #222222; font-family: arial, sans-serif; font-size: 14px;">基礎方程式は圧縮性流体を想定したオイラー方程式です。</span><wbr style="background-color: white; color: #222222; font-family: arial, sans-serif; font-size: 14px;"></wbr><span style="background-color: white; color: #222222; font-family: arial, sans-serif; font-size: 14px;">解析手法はTVD系です。</span><span style="background-color: white; color: #222222; font-family: arial, sans-serif; font-size: 14px;">したがって、</span><wbr style="background-color: white; color: #222222; font-family: arial, sans-serif; font-size: 14px;"></wbr><span style="background-color: white; color: #222222; font-family: arial, sans-serif; font-size: 14px;">非圧縮性流体の解析で使われるスタッガード格子やMAC系の解法</span><wbr style="background-color: white; color: #222222; font-family: arial, sans-serif; font-size: 14px;"></wbr><span style="background-color: white; color: #222222; font-family: arial, sans-serif; font-size: 14px;">に関する手法は述べられてません。</span><br style="background-color: white; color: #222222; font-family: arial, sans-serif; font-size: 14px;" /><br style="background-color: white; color: #222222; font-family: arial, sans-serif; font-size: 14px;" /><span style="background-color: white; color: #222222; font-family: arial, sans-serif; font-size: 14px;">ハッキリ言って、</span><wbr style="background-color: white; color: #222222; font-family: arial, sans-serif; font-size: 14px;"></wbr><span style="background-color: white; color: #222222; font-family: arial, sans-serif; font-size: 14px;">これを読んでも実際に解析が出来るようにはなりません。</span><br style="background-color: white; color: #222222; font-family: arial, sans-serif; font-size: 14px;" /><span style="background-color: white; color: #222222; font-family: arial, sans-serif; font-size: 14px;">実用的な解析をするならもっと簡単な本を読んだ方が良いでしょうし、初心者は読まない方が良いかもしれません。</span><br style="background-color: white; color: #222222; font-family: arial, sans-serif; font-size: 14px;" /><br />
<span style="color: #222222; font-family: arial, sans-serif;"><span style="font-size: 14px;">ただし、味わい深い本だと思います。</span></span><br />
<span style="color: #222222; font-family: arial, sans-serif;"><span style="font-size: 14px;">小生が購入したのは2004年頃ですが、最近ようやく「あ、これのこと言ってたんだ!」と気づかされることが多いです。</span></span><span style="color: #222222; font-family: arial, sans-serif; font-size: 14px;">FDSやFVSの基本的な考え方が書いてある本はこれくらいだと思います。</span><br />
<span style="color: #222222; font-family: arial, sans-serif;"><span style="font-size: 14px;">浅水流方程式への応用はちゃんと鉛筆動かさないとダメですけどね。</span></span><br />
<span style="color: #222222; font-family: arial, sans-serif;"><span style="font-size: 14px;">正直、まだ、すべてを理解してません(笑)</span></span><br />
<span style="color: #222222; font-family: arial, sans-serif;"><span style="font-size: 14px;">ただ、「わかんねぇなー」と思いながら、日々少しずつ理解が深まるところに、楽しさを感じてます。</span></span><br />
<span style="color: #222222; font-family: arial, sans-serif;"><span style="font-size: 14px;"><br /></span></span>
<span style="color: #222222; font-family: arial, sans-serif;"><span style="font-size: 14px;"><br /></span></span>
<span style="color: #222222; font-family: arial, sans-serif;"><span style="font-size: 14px;">ところで、</span></span><br />
<span style="color: #222222; font-family: arial, sans-serif;"><span style="font-size: 14px;"><br /></span></span>
<span style="color: #222222; font-family: arial, sans-serif;"><span style="font-size: 14px;">「わかりやすいほにゃらら」</span></span><br />
<span style="color: #222222; font-family: arial, sans-serif;"><span style="font-size: 14px;">「初心者のためのほにゃらら」</span></span><br />
<span style="color: #222222; font-family: arial, sans-serif;"><span style="font-size: 14px;">「10日でほにゃらら」</span></span><br />
<span style="color: #222222; font-family: arial, sans-serif;"><span style="font-size: 14px;"><br /></span></span>
<span style="color: #222222; font-family: arial, sans-serif;"><span style="font-size: 14px;">等々。分りやすいのでスイスイ読めますが、長くは読めません(否定している訳ではありません)。</span></span><br />
<span style="color: #222222; font-family: arial, sans-serif;"><span style="font-size: 14px;"><br /></span></span>
<span style="color: #222222; font-family: arial, sans-serif;"><span style="font-size: 14px;">結局、簡単に理解できることは、それだけの価値しかありませんし、他人もすぐ理解できます。</span></span><br />
<span style="color: #222222; font-family: arial, sans-serif;"><span style="font-size: 14px;">苦しんで覚えたことや、時間をかけて学んだことは忘れませんし、他人もすぐには理解できないことです。</span></span><br />
<span style="color: #222222; font-family: arial, sans-serif;"><span style="font-size: 14px;"><br /></span></span>
<span style="color: #222222; font-family: arial, sans-serif;"><span style="font-size: 14px;">良書を見分ける一つの指標として、「古いけど絶版にならない技術書は良い」というのがあります。</span></span><br />
<span style="color: #222222; font-family: arial, sans-serif;"><span style="font-size: 14px;">ただし、理解に時間がかかるものが多いです。</span></span><br />
<span style="color: #222222; font-family: arial, sans-serif;"><span style="font-size: 14px;"><br /></span></span>
<span style="color: #222222; font-family: arial, sans-serif;"><span style="font-size: 14px;">技術書に限らず、死ぬまでに多くの良書に出会いたいですね。</span></span><br />
<span style="color: #222222; font-family: arial, sans-serif;"><span style="font-size: 14px;"><br /></span></span>
<span style="color: #222222; font-family: arial, sans-serif;"><span style="font-size: 14px;"><br /></span></span>
<span style="color: #222222; font-family: arial, sans-serif;"><span style="font-size: 14px;"><br /></span></span>
<span style="color: #222222; font-family: arial, sans-serif;"><span style="font-size: 14px;"><br /></span></span>
<span style="color: #222222; font-family: arial, sans-serif;"><span style="font-size: 14px;"><br /></span></span>
<span style="color: #222222; font-family: arial, sans-serif;"><span style="font-size: 14px;"><br /></span></span>
<span style="color: #222222; font-family: arial, sans-serif;"><span style="font-size: 14px;"><br /></span></span>
<span style="color: #222222; font-family: arial, sans-serif;"><span style="font-size: 14px;"><br /></span></span>にしるhttp://www.blogger.com/profile/14158676822605584570noreply@blogger.com0tag:blogger.com,1999:blog-8085514949557020263.post-80267543785010676852013-09-04T00:45:00.003+09:002013-09-04T00:45:51.638+09:00蛙跳び2<div class="separator" style="clear: both; text-align: center;">
<a href="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEj0mkGMV34j96ovxaymvqITjiVpV6mzn9mB1TphjWKLzvCXRgvosRziIMupPfkGgx7u5GA2T-V9w9AXJJzIE1PCijiiB8m3BTVx_TDhJwdJAZHUix1n2vxabzzLxtb7xZpk8WXRlrGOS3Dm/s1600/%E6%99%82%E9%96%93%E7%A9%8D%E5%88%86%E6%89%8B%E6%B3%95%E3%81%AE%E6%AF%94%E8%BC%83.png" imageanchor="1" style="margin-left: 1em; margin-right: 1em;"><img border="0" height="145" src="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEj0mkGMV34j96ovxaymvqITjiVpV6mzn9mB1TphjWKLzvCXRgvosRziIMupPfkGgx7u5GA2T-V9w9AXJJzIE1PCijiiB8m3BTVx_TDhJwdJAZHUix1n2vxabzzLxtb7xZpk8WXRlrGOS3Dm/s320/%E6%99%82%E9%96%93%E7%A9%8D%E5%88%86%E6%89%8B%E6%B3%95%E3%81%AE%E6%AF%94%E8%BC%83.png" width="320" /></a></div>
<br />
<div>
こんな感じでした。鈍るんです。</div>
<div>
LeapFrogは空間積分の右辺をf^{n+1}とf^{n-1}の平均値である0.5*(f^{n+1}とf^{n-1})を使うような良い加減な方法なんであまり好きではないのですが、これ見ると、RungeKuttaを使って計算コスト書けるなら、LeapFrogの方が楽だし、鈍らないし、と判断してしまいますね。何か間違ってることを信じたいです(笑)</div>
<div>
<br /></div>
<div>
<br /></div>
にしるhttp://www.blogger.com/profile/14158676822605584570noreply@blogger.com0tag:blogger.com,1999:blog-8085514949557020263.post-85577958573716543422013-09-03T13:42:00.000+09:002013-09-04T00:45:57.111+09:00蛙跳び<br />
' Leap Frog Method<br />
dim n as Integer<br />
dim i as Integer<br />
dim f(100) as double<br />
dim fo(100) as double<br />
dim fn(100) as double<br />
dim mojiretsu as String<br />
<br />
'Initial Condition<br />
For i = 1 to ixmx<br />
if i > 10 And i<20 then<br />
fo(i) = 1.0<br />
f(i) = 1.0<br />
fn(i) = 1.0<br />
else<br />
fo(i) = 0.0<br />
f(i) = 0.0<br />
fn(i) = 0.0<br />
end if<br />
next i<br />
'Time Marching<br />
for n =1 to itmx<br />
'Leap Frog<br />
for i = 2 to ixmx<br />
fn(i) = fo(i) - 2*u*dt/dx*(f(i) - f(i-1))<br />
next i<br />
<br />
'Shift Variables<br />
for i = 2 to ixmx<br />
f(i) = 0.5*(fn(i)+fo(i))<br />
fo(i) = fn(i)<br />
next i<br />
next n<br />
<br />
'Output<br />
for i = 1 to ixmx<br />
mojiretsu = Str(i) +"," + Str(f(i))<br />
ListBox2.AddRow(mojiretsu)<br />
next i<br />
<br />
4次精度ルンゲクッタと比較すると、2次精度の蛙飛びの方が、鈍りが少ないです。<br />
<br />
なぜなんだろう・・・。にしるhttp://www.blogger.com/profile/14158676822605584570noreply@blogger.com0tag:blogger.com,1999:blog-8085514949557020263.post-68210756709380003582013-09-02T22:17:00.000+09:002013-09-02T22:17:32.109+09:00ListBox//ListBoxのクリア<br />
<br />
Listbox1.deleteAllRows<br />
<br />
Winで作ったバイナリファイルをMacで初めて開きました。<br />
OS依存の機能を使ってないことはありますが、特に問題なく開きました。<br />
<br />
ただし、r2でも日本語入力がおかしい箇所がありました。<br />
まあ、日本語使わなければいいんですけどね(笑)<br />
<br />
ホビー用途なら、すごくいい環境ですが、<br />
日本語の解説書が充実しないと広まらない気がします。<br />
勿体ない・・・。<br />
<br />
<br />
<br />
<br />
<br />
<br />にしるhttp://www.blogger.com/profile/14158676822605584570noreply@blogger.com0tag:blogger.com,1999:blog-8085514949557020263.post-40944675727812995272013-09-01T06:08:00.000+09:002013-09-01T06:08:26.678+09:00値への変換とか(Xojo)FortranやCを使ってると、値の読み込み時点で型指定をするが、<br />
その他の言語だと、すべて文字列で読み込んで、キャストすることが多いみたいです。<br />
<br />
Xojoの型変換は下記のとおり。<br />
<br />
Str(数値等):値をstringに変換<br />
Val(文字列):文字列を値に変換<br />
<br />
使わないとすぐ忘れます・・・。<br />
<br />
ところで、下記に値のやり取りの記録を書きます。<br />
<br />
/////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////<br />
1.ListBox1を配置して、表示の場合。<br />
<br />
//ListBoxの表示をすべて消す。<br />
<br />
ListBox1.deleteAllRows<br />
<br />
//ListBox1に文字列Program START!を追加<br />
ListBox1.AddRow("Program START!")<br />
<br />
2.TextField1に書き込まれた値を変数に代入<br />
<br />
//TextField1に書き込まれた文字列を、別途定義した文字列「strings」に代入<br />
//その後、数値型に変換<br />
<br />
Dim strings as string<br />
Dim i as Integer<br />
strings = TextField1.Text<br />
i = Val(strings)<br />
/////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////<br />
<br />
早くいろいろ晒したいです。<br />
にしるhttp://www.blogger.com/profile/14158676822605584570noreply@blogger.com0