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の仕様を調べなおします.