[表示 : 全て 最新50 1-99 101- 201- 301- 2chのread.cgiへ]
Update time : 06/21 19:50 / Filesize : 120 KB / Number-of Response : 304
[このスレッドの書き込みを削除する]
[+板 最近立ったスレ&熱いスレ一覧 : +板 最近立ったスレ/記者別一覧] [類似スレッド一覧]


↑キャッシュ検索、類似スレ動作を修正しました、ご迷惑をお掛けしました

くだすれFORTRAN(超初心者用)その2



1 名前:デフォルトの名無しさん [2006/11/22(水) 00:00:36 ]
このスレッドは、他のスレッドでは書き込めない超低レベル、
もしくは質問者自身何が何だか分からない質問を勇気を持って書き込むスレッドです。
FORTRAN使いが優しくコメントを返しますが、
お礼はFORTRANの布教と初心者の救済と次期Fortran2008規格でのCOMEFROM文採用をお願いします。

●注意事項
・質問する前にGoogle等の検索サイトで検索しましょう。
・回答者にわかりやすい様に、質問内容はできる限り詳しく書きましょう。
・エラーの場合は起きた状況、環境(OS・コンパイラ)、エラーメッセージも詳しく書きましょう。


●前スレ
くだすれFORTRAN(超初心者用)
pc8.2ch.net/test/read.cgi/tech/1138063703/

●関連スレ
FORTRAN W
pc8.2ch.net/test/read.cgi/tech/1163319215/


152 名前:age [2007/01/05(金) 21:55:11 ]
おお!こんな奇跡のスレがあるとは…
まじヘルプお願いします。


        え-------------か
      /
    い
  /   \
あ       お-------------き
  \
      / 
    う -------------------く


上記のような図がある。
あ〜くはそれぞれ独立した乱数である。

あ〜くで、次の経路の距離は(例:あ−い間はあ・いの積を小数点第3位で四捨五入したもの
)とする。

終点までの全経路の距離の合計を表示し、(例:あ+い+え+か、あ+う+く etc)
もっとも合計距離が小さいものを選ぶプログラムを作りなさい。


なんか上のほうにも似たようなものたくさんあるけど、応用力がなさすぎて作れない…
助けてください…orz

153 名前:デフォルトの名無しさん mailto:sage [2007/01/06(土) 05:53:37 ]
>>152
Fortranで挑戦、途中で挫折・・・
その後、rubyで作成しました。
あいうえおかきく→abcdefghと置き換えて
tree[]にabc...fghの値を入れると答えを見つけてくれます

#------------------------------
a=0; b=1; c=2; d=3; e=4; f=5; g=6; h=7;
null = nil
$ans = []

# a,b,c,d,e,f,g,h
tree=[1,2,3,4,5,6,7,8]

aa = [b,c]; bb = [e,d]
cc = [d,h]; dd = [g,null]
ee = [f,null]; ff = [f,null]
gg = [g,null]; hh = [h,null]

node = [aa,bb,cc,dd,ee,ff,gg,hh]

def len(tree,node,i,n)
tree[i]*tree[node[i][n]]
end

def path(x)
pair = ["a","b","c","d","e","f","g","h"]
pair[x]
end




154 名前:デフォルトの名無しさん mailto:sage [2007/01/06(土) 05:54:24 ]
>>153

def get_ans(node,tree,i,n,sum,_path_)
_next = node[i][n]
if _next == i then
a = [[sum,_path_]]
$ans = $ans + a
elsif _next == nil
nil
else
x = len(tree,node,i,n)
for j in 0..1
get_ans(node,tree,_next,j,sum+x,_path_+path(_next))
end
end
end

# --- main ---
for i in 0..1
get_ans(node,tree,0,i,0,path(0))
end
p $ans.sort
# --- end main ---

#[[27, "ach"], [38, "abdg"], [42, "abef"], [43, "acdg"]]


155 名前:デフォルトの名無しさん mailto:sage [2007/01/06(土) 20:59:33 ]
>>152
real function distance(path)
common /rval/ rval
real rval(10)
integer path(*), i

distance = 1.0
do i=1,1000
if (path(i) .lt. 1) then
distance = int((distance + 0.5) * 100) / 100.0
return
endif
distance = distance * rval(path(i))
enddo
write(*,*) 'internal error'
stop
end


156 名前:デフォルトの名無しさん mailto:sage [2007/01/06(土) 21:00:26 ]
>>155
program f152
common /rval/ rval
real d(6), minimum
integer i, path(10,6)
data path /
+ 1,2,4,6,0,0,0,0,0,0, ! あいえか
+ 1,3,5,2,4,6,0,0,0,0, ! あうおいえか
+ 1,2,5,7,0,0,0,0,0,0, ! あいおき
+ 1,3,5,7,0,0,0,0,0,0, ! あうおき
+ 1,3,8,0,0,0,0,0,0,0, ! あうく
+ 1,2,5,3,8,0,0,0,0,0 ! あいおうく
+ /
real rval(10)
rval(1) = rand(1) ! seed
do i=1,10
rval(i) = rand(0) * 10
enddo
minimum = 3.40282347E+38
do i=1,6
d(i) = distance(path(1,i))
if(minimum .gt. d(i)) minimum = d(i)
write(*,'(i10,f10.3)') i,d(i)
enddo
write(*,'(a10,f10.3)') 'mininum :',minimum
stop
end

157 名前:デフォルトの名無しさん [2007/01/07(日) 17:59:33 ]
質問させてください.
Windowsのgfortranだとコンパイルも実行もできるソースが,
Linux版のgfortranではコンパイルは通るのに実行時に
  At line 91 of file LHDmake.f90
  fortran runtime error;Bad adress
となって止まってしまいます.

LHDmake.f90はMODULEで,その91行目は「WRITE(21,*) ''」という文(データを改行するため)
なのですが,なにがおかしいのでしょうか?

ちなみにUNIT=21は
「OPEN(UNIT=21,file='Result/plotLHD1_polygon.dat',status='unknown')」
です.

コンパイラのバージョンは
Win:gcc version 4.2.0 20060401 (experimental)
Linux:gcc version 4.0.4 20060507 (prerelease) (Debian 4.0.3-3)
です

158 名前:デフォルトの名無しさん mailto:sage [2007/01/07(日) 20:33:38 ]
>>157
こんなのがあった
ttp://gcc.gnu.org/ml/gcc-bugs/2006-01/msg00595.html


159 名前:デフォルトの名無しさん [2007/01/08(月) 16:12:05 ]
「0.360e-10」は0.360×(10の-10乗)ですよね。

eがなくて、「0.360+250」のように表示されるのは
どういう意味でしょうか?

160 名前:デフォルトの名無しさん mailto:sage [2007/01/08(月) 16:51:03 ]
指数が3桁になって表示を切り詰めたんじゃないのかな?



161 名前:デフォルトの名無しさん mailto:sage [2007/01/08(月) 19:14:02 ]
>>159
マニュアルでFORMAT文のところを嫁

162 名前:デフォルトの名無しさん [2007/01/09(火) 15:52:01 ]
すいません…どなたか150の回答お願いします…


163 名前:デフォルトの名無しさん [2007/01/09(火) 18:18:55 ]
課題で、

-4(V/x)^2*a^3-2*(V/x)^2*3a^2+λv3a^2+a{2-2*(V/x)^2+4λV}+1+λV=0

V=0.1、xは0.1-1.0、
未定乗数λ=1,2,…t適当に入れて決める
求めたいのがaなのですが、
3次方程式なのでまったくプログラムが解りません
お助けねがえないでしょうか?
フォートランのバージョンはFujitsu Fortran V4.0L10です。
知恵をおかしください。 

164 名前:デフォルトの名無しさん mailto:sage [2007/01/09(火) 20:45:15 ]
>>162
program hoge
integer, parameter :: N=6; real :: X(N), Y(N); integer :: Z(N)
character(len=8) :: f(N) = "行けない"
call random_seed(); call random_number(X); call random_number(Y)
Z = int(X*6 + 1) + int(Y*6 + 1); where (Z >= 7) f = "行ける"
print "(1X,A,A,I2,A,A)",(char(ichar("A")+i-1),"は",Z(i),"だから",f(i),i=1,N)
end program hoge

165 名前:デフォルトの名無しさん mailto:sage [2007/01/09(火) 23:29:07 ]
>>163
安直にはニュートン法でとくべし。

1個は必ず実の解がある。残りはたとえば2次方程式として公式で。


166 名前:デフォルトの名無しさん [2007/01/10(水) 00:10:01 ]
fortran77 でのプログラム作成なんですが、

x=1でのf(x)=exp(x)の一次微係数を2点微分方と4点微分法を用いて、
hを0.1から0.01ずつ掛けながら数値微分するプログラムを作れ。
hは10^(ー15)まで変化させ各hでの値と厳密値とを比較せよ。

f(1)(x)を一次微係数を表す式としますと

2点微分法は

f(1)(x)=(f(x+h)-f(x))/2h

4点微分法は

f(1)(x)=(8f(x+h)-f(x+2h)-8f(x-h)+f(x-2h))/12h

で表されています。

どなたか分かる方お願いします。

167 名前:デフォルトの名無しさん mailto:sage [2007/01/10(水) 02:31:47 ]
double precision f,dx2,dx4,h,x
integer i
f(x) = exp(x)
dx2(h,x) = (f(x+h)-f(x)) / (2*h)
dx4(h,x) = (8*f(x+h)-f(x+2*h)-8*f(x-h)+f(x-2*h)) / (12*h)
x = 1.0
write(*,*) 'exp(1) = ', exp(1.0D0)
do 10 i=1, 15, 2
h = 0.1D0 * 10.0D0**(1-i)
write(*,*) h, dx2(h,x), dx4(h,x)
10 continue
end


168 名前:デフォルトの名無しさん [2007/01/10(水) 15:35:09 ]
>>165
ニュートン法は使ってはいけない
ということなので、
他の方法はないのでしょうか?

169 名前:デフォルトの名無しさん mailto:sage [2007/01/10(水) 17:00:29 ]
>>168
つ ニュートンラプソン法

170 名前:デフォルトの名無しさん mailto:sage [2007/01/10(水) 17:26:19 ]
三次方程式なら普通に代数的解法があるんだからそれを使えばいいんじゃね?



171 名前:デフォルトの名無しさん mailto:sage [2007/01/12(金) 04:54:06 ]
   REAL*8 FM(6),X(6),H,T,TI,TF
   WRITE(*,201)
 201 FORMAT(' ',5X,'T',9X,'X',11X,'Y',11X,'U',11X,'V')
   OPEN(8,FILE='b:alinda.dat')
CALL ICOND(N,TI,TF,H,X)
DO 20 T=TI,TF,H
WRITE(*,'('' '',F8.1,4F12.7)')T,(X(I),I=1,N)
WRITE(8,'(2F10.5)')X(1),X(2)
CALL RUNGE(N,H,T,X,FM)
DO 30 I=1,N
30 X(I) = X(I) + FM(I)*H
20 CONTINUE
CLOSE(8)
END


上記のプログラムで、理解できないところがありまして。
>WRITE(*,'('' '',F8.1,4F12.7)')T,(X(I),I=1,N)
ここの括弧内なのですが、[4F12.7]は4回実数を繰り返し表示する、という意味であっているのでしょうか?
あと、Tが何のためにあるのかがわかりません。

172 名前:デフォルトの名無しさん [2007/01/12(金) 12:26:52 ]
退職金1000万を源資とし、毎年100万ずつ引き出して使用した場合
預金が無くなるまでの毎年の元利合計を計算するプログラムを作れ
なお、年利率が0.1%、1%、5%の3種類について計算を実行して
預金が無くなるまでの年数を比較しなさい
(預け入れ時点では引き出さず、1年後から引き出すものとする)

という課題が出たのですが、分らなくて困っています。
教えて下さい。

173 名前:デフォルトの名無しさん [2007/01/12(金) 12:50:45 ]
program report11_2
implicit none
integer :: a(3),n,i,j,b
real :: r(3)

read(*,*) a(1)
do i=2,3
a(i)=a(1)
end do
do i=1,3
read(*,*) r(i)
end do
read(*,*) n

b=100.0
do i=2,n
do j=1,3
a(j)=a(j)+a(j)*r(j)/100.0-b
end do
write(*,*) i,(int(a(j)),j=1,3)
end do

stop
end program report11_2

ここまでやってみました。

174 名前:デフォルトの名無しさん [2007/01/12(金) 13:00:11 ]
n原子分子を構成する各原子の質量Miと座標(Xi、Yi、Zi)を読み込み、
質量中心を計算するプログラムを作れ。

っていう問題なんですが、どのようにすればいいでしょうか?
If文とDo文と配列を使わないといけないのですが・・・。
よろしくお願いします。

175 名前:デフォルトの名無しさん [2007/01/12(金) 23:51:10 ]
三つの数値データを与えてその三つの数値の最大値、最小値、中央値、
平均値、標準偏差、不偏分散を求められるプログラムを作成せよ。
という問題が出されてわからなくて大変です。
お願いします

176 名前:デフォルトの名無しさん [2007/01/13(土) 00:48:37 ]
超素人な俺が考えてみた
 PROGRAM DISTS
C
C
C
real x,y,z,max,min,mid,hyoujun,heikin,wa
print *,'enter x,y,z
read x,y,z
wa=x+y+z
***heikinti***
heikin=wa/3
print *,'heikin=wa/3
***max***
if (x .gt. y) .and. (x .gt. z)
print *,'max=x
elseif (y .gt. x) .and. (y .gt. z)
print *,'max=y
elseif (z .gt. y) .and. (z .gt. x)
print *,'max=z
endif
***min***
if (x .gt. z) .and. (y .gt. z)
print *,'min=z
elseif (y .gt. x) .and. (z .gt. x)
print *,'max=x
elseif (z .gt. y) .and. (x .gt. y)
print *,'max=y
endif
***mid***

177 名前:デフォルトの名無しさん mailto:sage [2007/01/13(土) 01:06:20 ]
>>175
program hage
real :: a(3),b,c(1),d(3)=3;read *,a
c=maxloc(a);d(int(c(1)))=0;print *,maxval(a)
c=minloc(a);d(int(c(1)))=0;print *,minval(a)
print *,pack(a,d>1);b=sum(a)/3;print *,b
print *,sqrt(sum((a-b)**2)/3);print *,sum((a-b)**2)/2
end program hage


178 名前:デフォルトの名無しさん [2007/01/13(土) 01:46:19 ]
177を初心者向けのプログラムに出来ませんか?

179 名前:デフォルトの名無しさん mailto:sage [2007/01/13(土) 07:47:54 ]
>>178
十分初心者向け

180 名前:デフォルトの名無しさん mailto:sage [2007/01/13(土) 11:55:23 ]
>>178 >>177は筋が悪い、学んでもかえって馬鹿になるからやめとけ。




181 名前:デフォルトの名無しさん [2007/01/13(土) 12:53:05 ]
fortran90の課題なのですが、分からなくて困っています。
どなたか優しい方、よろしくお願いします。

数字1.2.・・・.nを様々な順序に並べたものを置換という。
例えば、1.2.3の置換は次の6通りである。
(1.2.3)(1.3.2)(2.1.3)(2.3.1)(3.1.2)(3.2.1)
1.2.・・・.nの置換はn!通り存在するが、これらを全て重複なくリストアップする
プログラムを作れ。

というものです。

182 名前:181 [2007/01/13(土) 13:08:34 ]
追加です。

nはデータとして読み込むものとする。

ってのを忘れてました。
よろしくお願いします。

183 名前:デフォルトの名無しさん mailto:sage [2007/01/13(土) 13:23:09 ]
順列 再帰 でググるといいかも

184 名前:デフォルトの名無しさん [2007/01/13(土) 13:43:50 ]
三つの数値データを与えてその三つの数値の最大値、最小値、中央値、
平均値、標準偏差、不偏分散を求められるプログラムを作成せよ。
という問題が出されてわからなくて大変です。
誰か教えてください。


185 名前:デフォルトの名無しさん mailto:sage [2007/01/13(土) 13:57:58 ]
> 数字1.2.・・・.nを様々な順序に並べたものを置換という。
なぜ教育課程でも使われている順列という定義があるのに、独自の定義をするのだろう?

186 名前:172 [2007/01/13(土) 15:13:59 ]
どなたかお願いしますorz

187 名前:デフォルトの名無しさん [2007/01/13(土) 15:41:25 ]
184頼みます

188 名前:デフォルトの名無しさん mailto:sage [2007/01/13(土) 18:52:53 ]
>>184
UZEEE
一般性を考慮しないF90の糞プログラム例だ。
PROGRAM vip
IMPLICIT NONE
REAL :: x(3), xmin, xmax, xmed, xmean, sigma, usigma
x = (/10.0, 1.0, 5.0/)
xmin = MINVAL(x)
xmax = MAXVAL(x)
xmed = SUM(x) - xmin - xmax
xmean = SUM(x) / SIZE(x)
sigma = SUM( (x - xmean)**2 ) / SIZE(x)
usigma = SUM( (x - xmean)**2 ) / ( SIZE(x) - 1 )
WRITE(*, *) xmin, xmax, xmed
WRITE(*, *) xmean, sigma, usigma
STOP
END PROGRAM vip


189 名前:デフォルトの名無しさん mailto:sage [2007/01/13(土) 18:55:28 ]
>>185
有限群論とかでは置換群とか呼ぶから、そっち方面の方言だべ

190 名前:デフォルトの名無しさん mailto:sage [2007/01/13(土) 19:02:08 ]
>>172
subroutine calc(x)
real rate
integer balance, years, interest

balance = 10000000
years = 0
write(*,*) 'rate = ', x, '%'
rate = x / 100.0

10 continue
interest = int(balance * rate + 0.5)
if (interest .ge. 1000000) then
write(*,*) 'rate too much'
stop
endif

balance = balance + interest - 1000000
years = years + 1
if (balance .le. 0) return
write(*,*) years, balance
goto 10
end

program report172
call calc(0.1)
call calc(1.0)
call calc(5.0)
stop
end




191 名前:デフォルトの名無しさん mailto:sage [2007/01/13(土) 19:12:33 ]
>>186
超適当。0.1%, 1%の時は10年後に残金約50万円。5%の時は14年後に残金20万円。


PROGRAM no_dream
IMPLICIT NONE
REAL, PARAMETER :: rinterest(3) = (/0.1, 1.0, 5.0/), rstart = 1.0e7
REAL :: deposit
INTEGER :: i, j
DO i = 1, 3
WRITE(*, *) 'Case', i, 'Interest =', rinterest(i), '%'
WRITE(*, *) '----------------------------------------------'
deposit = rstart
j = 1
DO
deposit = deposit * (1.0 + rinterest(i) / 100.0) - 1.0e6
WRITE(*, *) 'Year', j, ' Remaining Money ', deposit
j = j + 1
IF (deposit < 1.0e6) EXIT
END DO
WRITE(*, *) '=============================================='
END DO
STOP
END PROGRAM no_dream



192 名前:デフォルトの名無しさん [2007/01/13(土) 22:01:56 ]
x = (/10.0, 1.0, 5.0/) 
この文章の意味を教えてください


193 名前:デフォルトの名無しさん [2007/01/13(土) 22:47:05 ]
n原子分子を構成する各原子の質量Miと座標(Xi、Yi、Zi)を読み込み、
質量中心を計算するプログラムを作れ。

という問題なんですが、どうしていいか分かりません。
If文とDo文と配列を使わないといけないのですが・・・。
よろしくお願いします。

194 名前:デフォルトの名無しさん mailto:sage [2007/01/14(日) 00:12:32 ]
どなたか171お願いします

195 名前:デフォルトの名無しさん mailto:sage [2007/01/14(日) 00:37:31 ]
>>171
>[4F12.7]は4回実数を繰り返し表示する、という意味であっているのでしょうか?
はい、幅12小数部7桁の実数を4回表示する、という意味です。

>あと、Tが何のためにあるのかがわかりません。
何ででしょうね。 時間も表示させたかったんじゃないですかね。

196 名前:デフォルトの名無しさん mailto:sage [2007/01/14(日) 00:39:09 ]
>>194
4F12.7の4は反復数、Tは出力するREAL*8型の変数。

197 名前:デフォルトの名無しさん mailto:sage [2007/01/14(日) 00:48:03 ]
>>192
配列構成子を使って配列に値を代入する。

198 名前:デフォルトの名無しさん mailto:sage [2007/01/14(日) 01:43:43 ]
>>192
x(1)=10.0
x(2)=1.0
x(3)=5.0
と同じこと。

199 名前:デフォルトの名無しさん mailto:sage [2007/01/14(日) 01:45:33 ]
>>193
解法とプログラムのどちらが解らないのかはっきりしたまえ。

200 名前:193 [2007/01/14(日) 08:13:45 ]
>>199
プログラムが分かりません。
よろしくお願いします。



201 名前:デフォルトの名無しさん mailto:sage [2007/01/14(日) 09:45:27 ]
>>200
我輩が知っている解法ではdo文と配列は使用するが、
if文は使用しないのだ。
その、解法を提示しろ。

202 名前:193 [2007/01/14(日) 11:33:59 ]
>>201
i<=2までの場合と2<iの場合で質量による
重心のバランスの出し方って変わりませんかね?
すいません。
ちょっと間違ってるかもしれません。

203 名前:馬鹿ですいません [2007/01/14(日) 13:55:06 ]
198ってx(1)が10、x(2)が1,x(3)が5、という定数だという事を示しているんですよね?
定数を指定してしまうと最初から各値が決まってる気がするんですけど・・



204 名前:デフォルトの名無しさん mailto:sage [2007/01/14(日) 14:43:11 ]
>>203
変数x(1)に10を格納する。
変数なので格納される値は書き換える事ができる。

205 名前:馬鹿ですいません [2007/01/14(日) 16:09:39 ]
204>>なんとなくわかりました。
もしx(1)に10を格納しなかったらプログラムとして不成立?

206 名前:デフォルトの名無しさん [2007/01/16(火) 12:51:51 ]
>>202
重心の出し方は n<=2 だろうが 2<n だろうが変わらないはず。
(M1×y1 + M2×y2 + ... + Mk×yk)
-------------------------------- (y座標)
k

x座標もz座標もyをx、yに変更すればO.K.

おそらくif文を使うのは、何個の原子があるかを判定するところで使うのでは?
つまり、プログラムに原子の個数をあらかじめ与えておくのではなく、与えられた初期データを読み込むときに原子が何個あるかをプログラムがカウントするということね。

207 名前:デフォルトの名無しさん [2007/01/16(火) 16:24:45 ]
あるプログラムを作っているのですが、
配列に入れる値をテキストファイルから読み込むことが何度もあります。
その部分をサブルーチン化したいのですが、うまくいきません。
次のようなエラーが出るのですが、どう改善すればようでしょうか?

変数'x'の宣言において,整数式であるべきところが整数式ではありません.
'UNIT'指定子の値または型が正しくありません.
'FILE'指定子の値または型が正しくありません.
'UNIT'指定子の値または型が正しくありません.
'UNIT'指定子の値または型が正しくありません.

subroutine data(x,n,unit,file)

real,intent(inout),dimension(n) :: x
real,intent(in) :: n, unit, file

open(unit,file)
do i = 1,n
read(unit,*) x(i)
end do
close(unit)

end subroutine

208 名前:207 [2007/01/16(火) 17:34:39 ]
xは値を入れたい1次元配列
nは配列の要素数
unitはファイルに付ける番号
fileは読み込むテキストファイルの名前です。

↑の形にこだわらなくてもいいので、
同じことができる方法があれば教えてください。

209 名前:デフォルトの名無しさん mailto:sage [2007/01/16(火) 18:04:40 ]
>>207
fortran90は使ったことないが、
> real,intent(in) :: n, unit, file
realじゃいやーん
といってるんだろ。

210 名前:デフォルトの名無しさん mailto:sage [2007/01/16(火) 22:29:53 ]
>>208
漏れは>>207は釣かとオモタよ。
本気で聞いてるなら、しょん便で顔を洗って出直してくるべき。




211 名前:デフォルトの名無しさん [2007/01/17(水) 00:41:03 ]
y(x)=F(x)*cos(m*x)の形をした関数を数値積分(積分範囲0〜2pi)
をシンプソン則で計算させようと思っているんですが
試しに、F(x)=1、x軸上のサンプリングポイント2000点とし、自然数mを1から1000まで連続的に増やして計算させたところ、
あるm=650近傍で積分値が大幅に振動し、それ以降では振動がある程度収まるという結果になりました。
この振動を抑えるための解決策があればご教授お願いします。

212 名前:デフォルトの名無しさん mailto:sage [2007/01/17(水) 10:37:07 ]
>>211
三角関数の振動の周期と積分のステップ幅の関係を考えねば。
たぶん2π/650〜Δ1/1000くらいなんだろ。
積分範囲が分からんので断言できないが・


213 名前:デフォルトの名無しさん [2007/01/17(水) 18:19:49 ]
>>209
ありがとうございます。
これ書いたときはだいぶ疲れてて気がつきませんでした。

そもそも文字列(ファイル名)を引数にしようとしていました。

214 名前:デフォルトの名無しさん mailto:sage [2007/01/17(水) 22:37:20 ]
>>213
>そもそも文字列(ファイル名)を引数にしようとしていました。
それは可能姉妹

215 名前:デフォルトの名無しさん [2007/01/19(金) 17:30:31 ]
某サイトからの引用ですが

CHARACTER::f*63,q=""""
f="('CHARACTER::f*63,q=',4A/'f=',3A/'PRINT f,q,q,q,q,q,f,q'/'END')"
PRINT f,q,q,q,q,q,f,q
END

を,まわすとプログラムソースと同じ答えが返ってきます.
そこの解説読んでも何故そうなるのかわかりません.
誰か詳しく解説してください.お願いします


216 名前:デフォルトの名無しさん mailto:sage [2007/01/19(金) 21:19:25 ]
CHARACTER(LEN=43) :: f="('hoge',A,A,A,A/'huge',A,A,A/'hage'/'hige')"
WRITE(*,FMT=f) '"', '"', '"', '"', '"', f, '"'
END


217 名前:デフォルトの名無しさん [2007/01/20(土) 01:19:34 ]
>>215
1)FORMATは文字列として与えても良い。 fはFORMAT文としてと文字列としてと
  2回違う意味で使用されいる。

2)PRINT fmt、text = WRITE(*、fmt) text
  PRINT文の1個目の引数?はフォーマットを表している。

3)文字変数 q = ” (引用符中の2連発の同じ引用符は1個の文字扱いとなる。)

4)PRINT f,q,q,q,q,q,f,q の意味は、以下と同じ。
100 FORMAT('CHARACTER::f*63,q=',4A/'f=',3A/'PRINT f,q,q,q,q,q,f,q'/'END')
    WRITE(*、100) q、q、q、q、q、f、q  

5)FORMAT文の斜線は改行。 
  文字列は文字列としてそのまま出力。
  Aは文字変数qに対応する文字型指定子。



218 名前:デフォルトの名無しさん mailto:sage [2007/01/20(土) 01:25:00 ]
f2cで変換したソースを読む気がしない

219 名前:デフォルトの名無しさん mailto:sage [2007/01/21(日) 02:04:51 ]
exe にしたファイルを元に戻したいのですが何か良いツールはないでしょうか?
20行くらいの簡単なファイルなのですが数がめちゃくちゃあって一から入力する気になれないです
どなたかそんなツール知っている方いましたらレスお願いします

220 名前:デフォルトの名無しさん [2007/01/21(日) 10:59:47 ]
>>219
つ 「逆アセンブラ」「逆コンパイラ」

まあ、こいつらの出力を見たら一から入力する気になると思うがな。



221 名前:215 [2007/01/21(日) 18:04:45 ]
>>216
>>217
なるほど...fortran奥が深いですね

222 名前:デフォルトの名無しさん mailto:sage [2007/01/22(月) 22:44:47 ]
>>220

それをやってくれるツールみたいなのはないのでしょうか?
フリー・シェアのどちらでも構わないのですが・・・


223 名前:デフォルトの名無しさん mailto:sage [2007/01/23(火) 00:32:55 ]
>>222
Googleで「逆アセンブラ」とか「逆コンパイラ」で検索すれば色々見つかるよ。
Fortranの逆コンパイラは知らんが。

但し、実行ファイルから完全に元のソースにもどしてくれるようなものを期待しているのなら
そんなのもは無い。

224 名前:デフォルトの名無しさん mailto:sage [2007/01/25(木) 06:14:36 ]
 来週の月曜までが期限の課題なのですが全く分からなくて困っています。
 内容としては、以下のプログラムでは行列の対角成分に0があると逆行列を
計算できないので、それをできるように改良するというものです。
 行列の対角成分の絶対値が大きくなるように行を入れ替えるピボット選択を
すればいいみたいなのですが…
 2chに書き込むのは初めてなのでおかしな点があったら申し訳ありません
が、何かヒントをいただければ助かります。


225 名前:デフォルトの名無しさん mailto:sage [2007/01/25(木) 06:18:26 ]
>>224のプログラムです。
   PROGRAM INVERSE MATRIX

   INTEGER I,J,K
REAL A(3,6)

PRINT *,'Input matrix A'
DO 1000 I=1,3
READ *,(A(I,J),J=1,3)
DO 2000 J=4,6
IF (I+3 .EQ. J) THEN
A(I,J)=1.0
ELSE
A(I,J)=0.0
ENDIF
2000 CONTINUE
1000 CONTINUE

226 名前:デフォルトの名無しさん mailto:sage [2007/01/25(木) 06:20:32 ]
>>225の続きです
   DO 3000 K=1,3
DO 4000 J=K+1,K+3
A(K,J)=A(K,J)/A(K,K)
DO 5000 I=1,3
IF (I .NE. K) THEN
A(I,J)=A(I,J)-A(K,J)*A(I,K)
ENDIF
5000 CONTINUE
4000 CONTINUE
3000 CONTINUE

PRINT *,'Result'
DO 6000 I=1,3
PRINT *,(A(I,J),J=4,6)
6000 CONTINUE

END

227 名前:デフォルトの名無しさん mailto:sage [2007/01/25(木) 15:09:45 ]
>>223

ない

228 名前:デフォルトの名無しさん mailto:sage [2007/01/25(木) 21:22:12 ]
ん? なにが?

229 名前:デフォルトの名無しさん mailto:sage [2007/01/26(金) 09:44:10 ]
文脈から判断すると、fortran逆コンパイラ。

230 名前:デフォルトの名無しさん mailto:sage [2007/01/30(火) 01:24:15 ]
X(O)=1としたとき、K=1,2,3,...の順に
X(K)=COS(X(K-1))
をくりかえして、
|X(K)-X(K-1)|<0.00001
になったら反復を打ち切るプログラムを作れ。

という問題なんですけど、どうすればいいでしょうか?
DO WHILEを使うのは分かるんですが…
どなたかお知恵をお願いします。
FORTRAN90です。



231 名前:デフォルトの名無しさん [2007/01/30(火) 11:46:43 ]
もう少し歯ごたえのある問題をもってこい!


232 名前:デフォルトの名無しさん mailto:sage [2007/01/30(火) 11:57:43 ]
>>230
program test
real :: x(0:1000)
integer :: i,k
k=0
x(k)=1.
do
k=k+1
x(k)=cos(x(k-1))
if(abs(x(k)-x(k-1))<0.00001) exit
enddo
do i=0,k
print *,i,x(i)
enddo
end program test


233 名前:age [2007/01/31(水) 00:11:58 ]
ご指導ください.
関数副プログラムをF1,F2として,
A=F1*F2
としたとき,
write(*,*) A,F1*F2
の結果が

NaN,[実数値]

となるのはなぜですか?????
謎です・・・

234 名前:デフォルトの名無しさん mailto:sage [2007/01/31(水) 02:15:26 ]
>>233
ソースがないとなんとも言えないが、
変数の型は大丈夫かな?

235 名前:デフォルトの名無しさん [2007/01/31(水) 03:00:46 ]
>>233
NaNとはNot A Numberの略で、実数として違法な表現が入っている場合などに起きる。

コードをもう少し広く見ないと分からない。
>234の言うように型を間違えている可能性が高い。


236 名前:デフォルトの名無しさん mailto:sage [2007/01/31(水) 04:39:27 ]
>234,235
ご回答ありがとうございます.
そうですか・・・
関数も倍精度,代入している変数も倍精度で定義しています.
なぜ代入してから表示するのと,代入する前の状態で表示するのと
で変わるのでしょうか?

関数は内部関数にしているのですが,なにか関係があるのでしょうか?
コードを貼り付けると非常に長くなりますので,
考えうる可能性としてはどのようなものがあるのでしょうか?

237 名前:デフォルトの名無しさん mailto:sage [2007/01/31(水) 04:46:39 ]
A=F1*F2からwrite(*,*) A,F1*F2までの間で何かAに副作用を及ぼすようなことをしていない?

238 名前:230 mailto:sage [2007/01/31(水) 08:04:05 ]
>>232
ありがとうございます。できました。
DO WHILE 使わなくても出来ますね。全然気がつきませんでした。

239 名前:デフォルトの名無しさん mailto:sage [2007/01/31(水) 11:12:23 ]
>>236
出してる情報が少なすぎるから、エスパー以外答えられんよ。
せめてWrite文の結果とエラーメッセージくらい出せば少しはわかる。
コンパイラの種類もわからないし。


まぁ漏れのESPカードによると、F1*F2は巨大数でオーバーフローして倍精度では表せない
数になった。もしくはアンダーフロー。WRITE文が4倍精度に対応しているのでエラーが出なかった。

最近4倍精度をサポートしている処理系が増えているので、Intel・Lahey(Fujitsu)・PGI・Absoft、etc、
十分ありうる。

240 名前:デフォルトの名無しさん [2007/02/01(木) 04:48:46 ]
とあるプログラムのformat文の中に「1pg」と書いてあったのですが,
これは何を意味しているのでしょうか



241 名前:デフォルトの名無しさん [2007/02/01(木) 12:13:32 ]
>>240
1P G のこと。 

それはFとEを自動で切り替えるGフォーマット に 小数点の位置をずらすP フォーマット
が組み合わさったもの。

F90時代にはESあたりを使うがよろしい。
プログラム書法では推奨されていたが、もはや時代遅れ。

詳しくはマニャル嫁。

242 名前:240 [2007/02/02(金) 13:02:07 ]
>>241
はい!せんせい

243 名前:デフォルトの名無しさん mailto:sage [2007/02/02(金) 19:11:37 ]
すいませんちょっとお聞きしたいのですが
ちょっと計算機を変えて計算しはじめたのですが
以下のように今まで読めてたopen文が読めなくなってしまいます
これってコンパイラとか計算機によって依存するんでしょうか
なにかヒントいただければと思うのですが・・・
getRegFromUnwindContext: Can't get Gr0 from UnwindContext, using 0
forrtl: severe (59): list-directed I/O syntax error, unit 515, file /・・・・・

244 名前:デフォルトの名無しさん [2007/02/02(金) 19:14:36 ]
すいませんあげさせてください

245 名前:デフォルトの名無しさん mailto:sage [2007/02/02(金) 19:47:52 ]
ついでにエラー部分は
open(515,file='bc2.dat')
cwrite(*,*)'test'

cwrite(*,*)'test2'
read(515,*)iob  ←ここで止まってる
cwrite(*,*)'test3'
read(515,*)(iobb(i),i=1,iob)
close(515)
です

246 名前:デフォルトの名無しさん mailto:sage [2007/02/02(金) 19:54:46 ]
すいません自己解決しました
読み込むファイルのスペースの数が悪いようでした
書き換えます・・

247 名前:デフォルトの名無しさん mailto:sage [2007/02/02(金) 20:47:42 ]
やっぱりめんどくさいです
どうやら改行もだめのようです
こんなことってあるんですか?

248 名前:デフォルトの名無しさん [2007/02/03(土) 14:17:31 ]
Makefileについて質問があります.

test.f90がメインルーチンで,サブルーチンの入ったsub1.f90に依存しているので
次のようなmakefileを作りました.

第2,3行目を追加したら常にclean:が実行されるようになってしまったのですが
何ででしょうか..
環境はWindows XP SP2 pro,Intel Visual Fortran 9.1で,
MSのNMAKEを使ってます.


FLAGS=%F90FLAGS% %LINK_F90%

.PHONY: all
all: main.exe

main.exe: main.obj sub1.obj
%F90% $(FLAGS) main.obj sub1.obj /o main.exe

main.obj: main.f90
%F90% $(FLAGS) main.f90 /c

sub1.obj: sub1.f90
%F90% $(FLAGS) sub1.f90 /c

.PHONY: clean
clean:
del *.obj

249 名前:デフォルトの名無しさん mailto:sage [2007/02/03(土) 14:19:09 ]
すみません;
× test.f90がメインルーチンで,サブルーチンの入ったsub1.f90に依存しているので
○ main.f90がメインルーチンで,サブルーチンの入ったsub1.f90に依存しているので

あとコマンド行の前にはもちろんタブが入ってます.

250 名前:デフォルトの名無しさん mailto:sage [2007/02/03(土) 16:46:25 ]
>>248
nmakeが .PHONY に対応しておらず、通常のターゲットとみなしてしまうから。

.PHONY: all
を消すか、 all: の後に持って行くかすれば良い。
(nmakeで使う分には残しておいても意味はないが…)

make は結構方言がきついので、油断していると変なところではまってしまうぞ。



251 名前:デフォルトの名無しさん [2007/02/03(土) 17:17:48 ]
>>247
何を言っているのかよく分からんが、一番確実なのは書いたとおりに読み込むことだ。

1行を頭から途中まで読んで、尻のほうを捨てることも出来る。
その場合、次のREAD文では、ファイル内の次の行を頭から読むことになる。

途中まで読んで、その行の残りを別のREAD文で読みたければ、
F90以降で導入されたADVANCE=”NO”を指定する必要がある。

詳しくはマニャル嫁


252 名前:248 mailto:sage [2007/02/04(日) 00:39:15 ]
>>250
ありがとうございます!
NMAKEの仕様を調べなおします.






[ 続きを読む ] / [ 携帯版 ]

前100 次100 最新50 [ このスレをブックマーク! 携帯に送る ] 2chのread.cgiへ
[+板 最近立ったスレ&熱いスレ一覧 : +板 最近立ったスレ/記者別一覧]( ´∀`)<120KB

read.cgi ver5.27 [feat.BBS2 +1.6] / e.0.2 (02/09/03) / eucaly.net products.
担当:undef