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


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

FORTRAN W



1 名前:デフォルトの名無しさん [2006/11/12(日) 17:13:35 ]
FORTRAN総合スレッドです。
FORTRAN77/90/95/2003, HPF等、FORTRAN全般に関する話題を書き込んで下さい。

・FORTRAN関連情報
お約束だが、まずは自分で調べよう
www.google.co.jp/

x86で動作するFortranコンパイラ
www.nminoru.jp/~nminoru/programming/x86-fortran.html

The Fortran Company
www.fortran.com/
Polyhedron Software
www.polyhedron.co.uk/
Google Directory - Fortran
directory.google.com/Top/Computers/Programming/Languages/Fortran/

・前スレ
FORTRAN III
pc8.2ch.net/test/read.cgi/tech/1104724162/
FORTRAN II
pc5.2ch.net/test/read.cgi/tech/1068351911/
Fortran
pc2.2ch.net/test/read.cgi/tech/1003214738/


29 名前:デフォルトの名無しさん mailto:sage [2006/11/14(火) 20:51:20 ]
>>24
Core Duoでもイゴイタ
32bit ifort版はシングルプロセッサ用に最適化されているみたいだが
SSE/SSE2が使えればIntel CPUでもOKのようだ。

>>25
SYSTEM とかそんな感じの関数なりサブルーチンなりが用意されている(ことが多い)。

>>28
X の値を 1 に変える(X に 1 を代入する)
X = 1.

X の常用対数を計算して Y に代入する
Y = LOG10(X)

X の自然対数を計算して Z に代入する
Z = LOG(X)

X, Y, Z の値を順に表示する
WRITE(*,*) X, Y, Z

30 名前:デフォルトの名無しさん mailto:sage [2006/11/14(火) 23:23:10 ]
倍精度実数と4倍精度実数では実行速度は変わってしまいますか?

31 名前:デフォルトの名無しさん [2006/11/14(火) 23:28:24 ]
>>30
死ぬほど違う。 
倍精度までは数値演算プロセッサの助けでハードウェア演算するが、
4倍精度はソフトウェアで浮動小数点演算をするので遅くなる。

64BitCPUなら若干状況は改善するが本質においては変わらない。
DECのアルファーCPUは4倍精度も微妙に早かったが、特殊な命令セットがあったためらしく、
64bitCPUだからといってよくなるわけでもないようだ。

32 名前:デフォルトの名無しさん [2006/11/14(火) 23:31:25 ]
>>29
DO文で書かないといけないのですが
どうすればいいんでしょうか・・

33 名前:30 mailto:sage [2006/11/15(水) 00:03:03 ]
>>31
詳しいレスサンクス!

34 名前:デフォルトの名無しさん mailto:sage [2006/11/15(水) 00:35:58 ]
>>26
残念ながらあまりいい本は無い。

今、手に入りやすいのはこれ。
www.amazon.co.jp/gp/product/4563014095
しかし、F77の癖を引きずっていて、あまりいい書き方をしていない。
著者は京大のおっさんらしく、WEBで同等の内容のものを見られる。
アドレスはアマゾンのレビューに書いてある。

英語でよければ、この辺とか、
www.lahey.com/elfpage.htm
この辺のEssential Fortranあたりが学習用サブセットになっていて、純粋F90を学べる。
www.fortran.com/F/books.html

しかし、現実世界ではF77ソースがあふれているので微妙ではある。
実際上記のものは教育用としてもはやらなかった。


35 名前:デフォルトの名無しさん mailto:sage [2006/11/15(水) 00:43:57 ]
>>32
   PROGRAM chinpopo
   DO 10 i = 0, 6
    x = 10.0**REAL(i)
y = LOG10(x)
z = LOG(x)
WRITE(6, *) INT(x), y, z
10 CONTINUE
   END
>>35

36 名前:デフォルトの名無しさん [2006/11/15(水) 14:47:06 ]
  complex(8) c

において,

  c=(0.d0, 0.d0)

として初期化するのも,

  c=0.d0

として初期化するのも全く同じことなのですか?

37 名前:デフォルトの名無しさん [2006/11/15(水) 17:59:05 ]
DO文を使用して,xの値を,1,10,100,1000,10000,100000,1000000 の順に変えて
その常用対数および自然対数の値を 計算して表示するプログラムを作れ.
なお,計算結果は書式の指定をして,x, log10(x), log(x) の順に表形式で表示すること.
また,計算結果が整数となるものは整数型(In),実数となるものは実数型(Fn.m)または指数型(En.m)で出力すること.
program report5
implicit none
integer :: x
real :: y,z

write (*,*) 'x='
read (*,*) x,log(x),log10(x)

do 10 i = 0.6

x=10.0**real(i)

y=log(x)

z=log10(x)

write (6,)

end do
stop

end program report5

何処がおかしいんでしょうか?



38 名前:デフォルトの名無しさん mailto:sage [2006/11/15(水) 18:31:55 ]
>>37
read (*,*) x,log(x),log10(x)
どこに入れたいの?
たぶん、その穴じゃないわよ

39 名前:デフォルトの名無しさん mailto:sage [2006/11/15(水) 19:20:43 ]
>>37
>read (*,*) x,log(x),log10(x)
>do 10 i = 0.6
>x=10.0**real(i)
>y=log(x)
>z=log10(x)
>write (6,)
ここら辺が間違ってる。
どこが間違いなのかわからないときは、とりあえずコンパイラ様にソースを渡して
文句を言われたところを上から順に直していくのも1つの手だ。


だれかくだすれの次スレ立ててくれ。

40 名前:デフォルトの名無しさん [2006/11/15(水) 23:55:01 ]
>>37
>>35をもういっぺん見ろ!

>>39
重複スレをクダスレにするか?


41 名前:デフォルトの名無しさん mailto:sage [2006/11/17(金) 00:48:27 ]
>>40
タイトル一緒だから混乱しそうw

42 名前:37 [2006/11/17(金) 10:16:25 ]
>>35
WRITE (6,*) が分かりません
>>37の問題の書式の指定はこれでいいんでしょうか

43 名前:デフォルトの名無しさん [2006/11/17(金) 11:23:12 ]
WRITE(6, '(I10, F15.7, F15.7)') x, y, z

もう少し教科書嫁!!

こんな感じでw

44 名前:デフォルトの名無しさん mailto:sage [2006/11/17(金) 12:00:23 ]
>>37 がんばったけど書式がうまくいかなかった。ゴメン
c DO文を使用して,xの値を,
c 1,10,100,1000,10000,100000,1000000 の順に変えて
c その常用対数および自然対数の値を 計算して表示する
c 計算結果は書式の指定をして,x, log10(x), log(x) の順に
c 計算結果が整数となるものは整数型(In),
c 実数となるものは実数型(Fn.m)または指数型(En.m)で出力.
Program report5
Implicit none
INTEGER i
REAL x

do i = 0, 6
x = 10.0**i
write(*, *) aint(x), log10(x), log(x)
end do

stop
end
c 実行結果
c 1.00000 0.000000E+00 0.000000E+00
c 10.0000 1.00000 2.30259
c 100.000 2.00000 4.60517
c 1000.00 3.00000 6.90776
c 10000.0 4.00000 9.21034
c 100000. 5.00000 11.5129
c 0.100000E+07 6.00000 13.8155

45 名前:デフォルトの名無しさん [2006/11/17(金) 12:28:48 ]
program report5
implicit none
integer :: x
real :: y,z

write (*,*) 'x='
DO 10 i = 0, 6

x = 10.0**REAL(i)
y = LOG10(x)
z = LOG(x)

WRITE(6, '(I10, F15.7, F15.7)') x, y, z
10 CONTINUE

END do
stop

end program report5
こうですか?

46 名前:デフォルトの名無しさん [2006/11/17(金) 17:12:34 ]
Program report5
Implicit none
real :: i,x

do i=0, 6
x=10.0**i

write(*, '(i7, f15.7 f15.7)') x, log10(x), log(x)
end do

stop
end
結果
******* 0.0000000 0.0000000
******* 1.0000000 2.3025851
******* 2.0000000 4.6051702
******* 3.0000000 6.9077554
******* 4.0000000 9.2103405
******* 5.0000000 11.5129251
******* 6.0000000 13.8155107


おかげさまでここまで出来たんですが、どうしても*******が出てしまいます><


47 名前:デフォルトの名無しさん mailto:sage [2006/11/17(金) 19:09:14 ]
>>46
「変数の型」を再勉強してから出直してこい。



48 名前:デフォルトの名無しさん mailto:sage [2006/11/18(土) 00:05:43 ]
>>46
write(*, '(i7, f15.7 f15.7)') x, log10(x), log(x)
   ↓
write(*, '(f15.7, f15.7 f15.7)') x, log10(x), log(x)

にしてみよう・・・
xはrealで宣言されてるからformatを整数表示に指定することはできない.

49 名前:デフォルトの名無しさん [2006/11/18(土) 00:44:07 ]
>>48
>>37の問題を読む感じでは、
write(*, '(i7, f15.7 f15.7)') int(x), log10(x), log(x)
を予期していると思われる。

>>46はもう少し貰った回答例をよく吟味しろw

50 名前:デフォルトの名無しさん [2006/11/18(土) 01:00:15 ]
PukiWiki つくってみた
www.moecity.jp/home/fortran/

wikiよく知らない。自由に使ってみてくれ。


51 名前:デフォルトの名無しさん mailto:sage [2006/11/18(土) 19:42:09 ]
f90スタイルで学べるいい文書はありませんかね。
英語か日本語でお願い

52 名前:デフォルトの名無しさん mailto:sage [2006/11/18(土) 20:03:11 ]
>>51
Fortran 標準コーディングルール
ttp://www.mri-jma.go.jp/Project/mrinpd/coderule.html

European Standards For Writing and Documenting Exchangeable Fortran 90 Code
ttp://www.meto.gov.uk/research/nwp/numerical/fortran90/f90_standards.html

上の和訳
ttp://www.mri-jma.go.jp/Project/mrinpd/eurostand.html

53 名前:デフォルトの名無しさん [2006/11/18(土) 21:18:26 ]
>>52
>推奨する書き方 real:: x(n), y(n)
>x(1:n) = y(1:n)


>×推奨しない書き方 x(:) = y(:) または x = y

これはかなりうそ臭いと思う。
x=y の場合と違って、コロン指定子を使うと、いったん暗にコンパイラが
テンポラリ配列にコピーするのでたいてい余分な時間がかかる。


しかし漏れが疑問に思うのは、F77では変数と配列に同じ名前をAとA(10)を指定できて
別物に扱われる様に規格で決まっていたと思うのだが、F90で矛盾が起きないのか・・・

それとも、これはJIS規格だけでANSIやMILでは違っていたのか?


54 名前:デフォルトの名無しさん mailto:sage [2006/11/18(土) 22:09:41 ]
>>53
REAL A
DIMENSION A(10)
DO 10 I=1,10
A(I) = REAL(I)
10 CONTINUE
A = 1.23
WRITE(*,*) A
WRITE(*,*) (A(I), I=1,10)
END

規格上どうなってたかは知らないが g77だと
A = 1.23
の部分でコンパイルエラーになった。

g95では(当然)

55 名前:54 mailto:sage [2006/11/18(土) 22:12:21 ]
× g95では(当然)
○ g95では(当然) A は配列全体と解釈された。

56 名前:デフォルトの名無しさん [2006/11/18(土) 23:02:07 ]
>>54
そうじゃなくて
REAL A, A(10)
が可能だったと思う。


57 名前:デフォルトの名無しさん mailto:sage [2006/11/19(日) 00:16:02 ]
hoge.f: In program `MAIN__':
hoge.f:1:
     REAL A,A(10)
         1 2
Invalid declaration of or reference to symbol `a' at (2) [initially seen at (1)]




58 名前:デフォルトの名無しさん [2006/11/19(日) 01:39:12 ]
たしか変数名と配列名は規格上の定義では別物だった記憶がある。

実際のコンパイラでどうなっていたかは知らん。





59 名前:デフォルトの名無しさん mailto:sage [2006/11/20(月) 08:30:40 ]
Fortran90なんですが,

integer a(1:100)=0

みたな初期化の仕方はよくやるんですか?

60 名前:デフォルトの名無しさん mailto:sage [2006/11/20(月) 08:32:30 ]
×みたな
○みたいな

orz

61 名前:デフォルトの名無しさん [2006/11/20(月) 09:01:16 ]
>>60
よくやる。
しかしその初期化はリンク・ロード時に行われるものなので、
実行行でa(1:100)=0と書くのとは微妙に違う。



62 名前:59 mailto:sage [2006/11/20(月) 15:25:10 ]
>>61
レスありがとう

63 名前:デフォルトの名無しさん mailto:sage [2006/11/20(月) 17:30:12 ]
integer a(1:100)=0
↑これって通る?

integer:: じゃないと通らなかった気が。


64 名前:質問1/3 [2006/11/20(月) 18:45:56 ]
拡散方程式の境界値問題をオイラー陽解法で解くための
参考プログラムというものが教科書にあり、まわしたのですが
errorは出ないものの上手くまわりませんでした。
アドバイスを願います。
ちなみにMX=41,KM=30,DT=0.01としています。
PARAMETER(NX=51)
DIMENSION U(NX),UU(NX)
C**** INPUT & CALCULATE PARAMETERS
WRITE(*,*) 'MX (<52: MESH POINTS) ? KM (NUMBER OF TIME STEP) ?'
READ(*,*) MX,KM
WRITE(*,*) 'DELTA T: DT ? '
READ(*,*) DT
DX=1./FLOAT(MX-1)
R=DT/DX**2
IH=(MX+1)/2
I5=.05/DT
IF(I5.EQ.0) I5=1
CALL OUTPUT(U,NX,MX,1)
C**** INITIAL CONDITION
DO 10 I=1,MX
X=FLOAT(I-1)/FLOAT(MX-1)
IF(I.LE.IH) THEN
U(I)=X
ELSE
U(I)=1.-X
END IF
10 CONTINUE

65 名前:質問2/3 [2006/11/20(月) 18:46:56 ]
C**** MAIN LOOP
DO 20 K=1,KM
U(1)=0.
U(MX)=0.
IF(MOD(K,I5).EQ.1) CALL OUTPUT(U,NX,MX,2)
C
DO 30 I=2,MX-1
UU(I)=R*U(I-1)+(1.-2*R)*U(I)+R*U(I+1)
30 CONTINUE
DO 40 I=2,MX-1
U(I)=UU(I)
40 CONTINUE
C
IF(ABS(U(IH)).GE.10000.) THEN
WRITE(*,*) 'DIVERGE!'
STOP
END IF
C
20 CONTINUE
C
CALL OUTPUT(U,NX,MX,3)
STOP
END
C
SUBROUTINE OUTPUT(U,NX,MX,MM)
CHARACTER Z(60,23)
DIMENSION U(NX)

66 名前:質問3/3 [2006/11/20(月) 18:48:34 ]
IF(MM.EQ.1) THEN
DO 10 J=1,23
DO 10 I=2,MX-1
Z(I,J)=' '
10 CONTINUE
DO 20 J=1,23
Z(1,J)=':'
Z(MX,J)=':'
20 CONTINUE
DO 30 I=1,MX
Z(I,1)='-'
Z(I,23)='-'
30 CONTINUE
END IF
IF(MM.EQ.2) THEN
DO 40 I=1,MX
J=U(I)*40+.001
IF(J.GT.23) GO TO 40
Z(I,J)='*'
40 CONTINUE
END IF
IF(MM.EQ.3) THEN
DO 50 J=23,1,-1
WRITE(*,600) (Z(I,J),I=1,60)
50 CONTINUE
600 FORMAT(1H ,60A1)
END IF
RETURN
END



67 名前:59 mailto:sage [2006/11/20(月) 21:40:21 ]
>>63
そうでした

integer :: a(1:100)=0

じゃないと通らんです.



68 名前:デフォルトの名無しさん [2006/11/22(水) 00:03:15 ]

くだすれFORTRAN(超初心者用)その2
pc8.2ch.net/test/read.cgi/tech/1164121236/

69 名前:デフォルトの名無しさん mailto:sage [2006/11/22(水) 01:57:44 ]
今度、計算機を3台ばかし構築せねばならないんだが、
CPUはcore2duoとXeonのどちらが良いのだろうか
コンパイラはインテルの非商用フリーのやつを使おうと思っている

70 名前:デフォルトの名無しさん [2006/11/22(水) 03:56:04 ]
Xeon5000番台と比較するならXeon、
Xeon3000番台と比較するならCore2Duoかな

71 名前:デフォルトの名無しさん [2006/11/22(水) 11:20:02 ]
キャッシュに載るならそれでもいいが、メモリーアクセス多いならItanium2で池





72 名前:デフォルトの名無しさん mailto:sage [2006/11/22(水) 14:12:45 ]
お前らが使っている計算機のスペックきぼんぬ

うちは
CPU:Pentium4 3.2GHz
メモリ:1GB
コンパイラ:Intel Fortran コンパイラ

メモリを2GBにしろと進言したが無理だった。

73 名前:デフォルトの名無しさん mailto:sage [2006/11/22(水) 14:54:28 ]
便乗しようじゃあないか.

CPU: Pentium4 3.4GHz
RAM: 1.5GB (DDRPC3200デュアル)
コンパイラ: Intel Fortran Compiler 9.1

OS: Windows XP pro SP2

友人のC2D (T7200) 搭載機使って計算したらノートPCのくせに俺の
デスクより2倍以上速くて鬱ry

74 名前:デフォルトの名無しさん [2006/11/22(水) 15:35:21 ]
これはなんですか???教えてください!!
NO ERRORS,4 WARNINGS [<TDOFS>FTN77 Ver 4.03]
NO ERRORS [<FORVIB>FTN77 Ver 4.03]
NO ERRORS [<COEF0>FTN77 Ver 4.03]
NO ERRORS [<COEF1>FTN77 Ver 4.03]
NO ERRORS [<SOLU>FTN77 Ver 4.03]
NO ERRORS [<F_TAN>FTN77 Ver 4.03]
NO ERRORS [<Z_GK>FTN77 Ver 4.03]
NO ERRORS [<INTARG>FTN77 Ver 4.03]
NO ERRORS [<INTARG3>FTN77 Ver 4.03]
NO ERRORS [<INTARG4>FTN77 Ver 4.03]
NO ERRORS [<INTARG5>FTN77 Ver 4.03]
WARNING the following symbols are missing:
DLAX D:\MyDo\Fortran\1122test.obj
(D:\MYDO\FORTRAN\1122TEST.FOR)
DLAXR D:\MyDo\Fortran\1122test.obj
(D:\MYDO\FORTRAN\1122TEST.FOR)

75 名前:デフォルトの名無しさん mailto:sage [2006/11/22(水) 15:50:10 ]
>>74
エラーはない(おめでと♪)けど、変なのが4つあったよ。
なんか、1122testっていうファイルのDLAX, DLAXRっていう名前が変な感じ。
ちょっと見た方がいいかも・・・(byふぉとらんこんばいら4.03号)。

76 名前:デフォルトの名無しさん [2006/11/22(水) 16:07:08 ]
ありがとうございます☆
今昔の先輩のプログラミングを解析中なだけで、FORTRAN自体を理解してませんが、恥を忍んでお伺いします。
DLAXRというのはたぶんこの部分ですが、どこか変でしょうか?

c **** DLAXR ***************************************
call DLAXR(XX,A,k,hmn,ALU,b,IPP,VWW,icond)
do 110 j=1,mn+1,1
jj=j-1
X(jj)=XX(j)
110 continue
do 111 j=mn+2,hmn,1
jj=j-mn-1
Y(jj)=XX(j)
111 continue
c ***********************************************************
return
end


77 名前:デフォルトの名無しさん mailto:sage [2006/11/22(水) 16:51:21 ]
>>76
わたしもよくわかんないけど、
DLAXRを呼んでるけど、このファイルではまだ定義されてないから
型・(引数の数とかの)形式があってるか不安・・・
よければファイルに書いといてね

たぶん他のファイルで定義されてるんだろうから
とりあえず適当にくっつけるけど、間違っても怒らないでね(byふぉとらんこんぱいら)



78 名前:デフォルトの名無しさん mailto:sage [2006/11/22(水) 17:24:56 ]
>>74
DLAX, DLAXR って名前から察すると、富士通の数値計算ライブラリSSL II を使ってるっぽい。

79 名前:デフォルトの名無しさん mailto:sage [2006/11/22(水) 17:45:18 ]
すれ違いかも知れないが、CoreDuo、Core2DuoでLinuxで動くの?

80 名前:デフォルトの名無しさん mailto:sage [2006/11/22(水) 18:00:54 ]
>Core2DuoでLinuxで
シンタックス・エラー: 解決されない助詞「で」

81 名前:デフォルトの名無しさん mailto:sage [2006/11/22(水) 20:45:13 ]
>>80
nice

82 名前:デフォルトの名無しさん [2006/11/22(水) 23:35:23 ]
>>74
それは>>78にあるように、SSLIIのライブラリを読んでいるので、それが無いと言っている。

SSLIIのライブラリがあるコンパイラ(Fujitsu、Lahey)の奴でやるか、
あるいは他のライブラリで置き換える必要がある。

LU分解っぽいので、LAPACKとか何でもあるべ。



83 名前:デフォルトの名無しさん [2006/11/23(木) 14:05:27 ]
n行m列の行列があり、そこからn行m列のそれぞれの値を一列に直して、それぞれに値について大きい順に並べなおし、元のn行m列に直してみたいのですけどどんなプログラムの方法がありますか?

よければ、教えてください><

ちなみにfortran77を使っています></

84 名前:デフォルトの名無しさん [2006/11/23(木) 16:00:07 ]
>>83
言ってることがよく分からないが、2次元行列を列ごとにソートして、
上から下へ大きい順に並べなおしたいということか?


それなら簡単だ。
1.まず1次元ソートのサブルーチンを用意する。これを SORT(n, x) としよう。

2.列ごとにソートする。
DO 10 i = 1, m
 CALL SORT(N, X(1, i))
10 CONTINUE

これでおk。


85 名前:デフォルトの名無しさん [2006/11/23(木) 18:03:09 ]
>>84さん指摘ありがとうございます

でもちょっと違うのです>< 
たとえば、1 5  9 13
     2 6 10 14
     3 7 11 15
     4 8 12 16

について、
1
2
3

16

といってから順番を変更して

16 12 8 4
15 11 7 3
14 10 6 2
13  9 5 1

という風に並べたいのです

86 名前:デフォルトの名無しさん [2006/11/23(木) 19:56:32 ]
>>85
それならもっと簡単だ。FORTRAN77は配列の先頭アドレスしか渡さない。
次元数とか大きさは気にしない。
また、FORTRANの配列はメモリー上では、列方向に隣り合って1次元に並んでいる。
ゆえに、N*Mの要素数で1次元のソートをすればいい。

1.1次元のソートを用意する。
2.CALL SORT(N*M、X)

これでOK

87 名前:デフォルトの名無しさん mailto:sage [2006/11/24(金) 11:12:38 ]
>>83
元々mixiに書き込んだんだから、解決したらmixiにも書くように。



88 名前:デフォルトの名無しさん [2006/11/24(金) 11:44:03 ]
>>87 
つーか>>83のレベルでは>>86の回答は理解できないんじゃないか。

FORTRANはこういうイカサマ技によって、1次元整数0クリアをつっかって
多次元整数、実数などのクリアーに使えた。一種のPolymorphism wwwww



89 名前:デフォルトの名無しさん [2006/11/24(金) 14:36:03 ]
>86さんありがとうございます

確かに速く知りたいという気がはやりすぎて、いろんな所で質問していますね
ちゃんと自分で理解できたら書いていきたいとは思っているのですけどね
でも、やはりちょっと理解できません^^;
よければ、何か例とかあるとありがたいのですけど><


90 名前:デフォルトの名無しさん [2006/11/24(金) 14:36:17 ]
>>77 
ありがとうございます!

>>78さんの言うとおり、富士通SSLUを使っている様子です。

>>82
LaheyやLAPACKとはどんなものですか??

91 名前:デフォルトの名無しさん mailto:sage [2006/11/24(金) 20:57:18 ]
>>90
ttp://www.google.co.jp/search?q=lahey+fortran
ttp://www.google.co.jp/search?q=lapack+fortran

92 名前:デフォルトの名無しさん [2006/11/24(金) 23:12:56 ]
>>90
Laheyはコンパイラの自社独自開発をやめて、今では富士通のフロントエンドを使っている。
富士通はLinux版しか出していないが、LaheyはWindows版も出している。
富士通が絡んでいるので、プロフェッショナルバージョンを買うとSSLがついてくる。

あとSSLは名古屋大学のNUPACKと密接な関係があるので、netNUMPACが参考に
なるかもしれないし、ならないかもしれないwww
漏れは富士通系はメインには使わなかったのでよく知らんw


LAPACKは固有地問題と線形問題用のサブルーチン集だ。これは国際標準と化してきているので
どこの機械でも動いている。


93 名前:デフォルトの名無しさん mailto:sage [2006/11/24(金) 23:33:34 ]
>>89
PROGRAM unko
REAL a(5, 2)
CALL kintama(5 * 2, a)
DO 10 i = 1, 5
PRINT *, a(i, 1), a(i, 2)
10 CONTINUE
END
C
SUBROUTINE kintama(n, x)
REAL x(n)
DO 10 i = 1, n
x(i) = REAL(i)
10 CONTINUE
RETURN
END

実行結果

1.000000 6.000000
2.000000 7.000000
3.000000 8.000000
4.000000 9.000000
5.000000 10.00000
Press any key to continue

サブルーチン 金玉 で、1次元配列xに1〜nまで順番に数を代入している。
一方、メインルーチンから呼び出すときは、2次元配列を引数(ひきすう)に与えている。
要素数は行×列=10個で渡している。 返ってくる結果を見ると、列方向に連続した値で戻って来ている。

同様のことをSORTでやれば、はじめ二次元にランダムだった数が、
列方向にソートされて戻ってくる。

94 名前:デフォルトの名無しさん mailto:sage [2006/11/25(土) 08:07:15 ]
>>89
>確かに速く知りたいという気がはやりすぎて、いろんな所で質問していますね
それはマルチポストと言って、マナー違反だな。
ここをよーく読んどくように。
ja.wikipedia.org/wiki/%E3%83%9E%E3%83%AB%E3%83%81%E3%83%9D%E3%82%B9%E3%83%88

95 名前:デフォルトの名無しさん mailto:sage [2006/11/26(日) 17:18:04 ]
FORTRANのエロゲとかないの?

96 名前:デフォルトの名無しさん [2006/11/27(月) 19:00:46 ]
>>53
>x(1:n) = y(1:n)

この書き方って例えば次のような漸化式に使うと
ちゃんと計算してくれない.

x(1)=0
x(2)=1
x(3:n) = 2*x(2:n-1) - 4*x(1:n-2)

自分に自分を代入するような
式だと駄目っぽい (途中から全部0になる).なんで??


97 名前:デフォルトの名無しさん mailto:sage [2006/11/27(月) 21:01:20 ]
>>96
配列の演算はすべて並列計算として処理されるので x の要素が 0 で初期化されていた場合、
x(3) = 2*x(2) - 4*x(1) = 2*1 - 4*0 = 2
x(4) = 2*x(3) - 4*x(2) = 2*0 - 4*1 = -4
x(5) = 2*x(4) - 4*x(3) = 2*0 - 4*0 = 0
x(6) = 2*x(5) - 4*x(4) = 2*0 - 4*0 = 0
・・・
となる。

do i=2,n
x(i) = x(i-1) + 1
end do

x(2:n) = x(1:n-1) + 1
では意味が違うのだ。



98 名前:96 mailto:sage [2006/11/27(月) 22:18:19 ]
>>97
おお〜よくわかりました!
ありがとう

99 名前:デフォルトの名無しさん [2006/11/28(火) 00:17:59 ]
>>96
REAL::A(N, N), B(N, N)
A = A * B
のような状況を考えれば、今のFORTRANの仕様がもっともだと分かる。
行列操作がらみで、この仕様はとても便利。いちいち自分でテンポラリにコピーしなくていい。

あと一応、並列化されたときのことも考慮されてそういう仕様になっているらしい。

100 名前:デフォルトの名無しさん [2006/11/29(水) 13:24:49 ]
>>74のプログラムにおいて、ファイルの定義とはどの部分にどのように書き込むものなのですか?
全体のプログラムの中のどこかに隠れているのでしょうか?

101 名前:デフォルトの名無しさん [2006/11/29(水) 21:16:59 ]
次の条件のうちから他の位置の緯度(θ2)と経度(λ2)を求めるプログラムを作成せよ。
1.元の場所の緯度(θ1)を北緯35度40分、経度(λ1)を東経139度12分
2.距離(s)を6242.2kmとする s=R×α°×π/180  (R=6370km)
3.方位角(ν)を86.6度とする sinν=cosθ2×sin刄ノ/sinα (刄ノ=λ2-λ1)
(利用できるのであればcosα=sinθ1sinθ2+cosθ1cosθ2cos刄ノを利用してもよい)
また、他の方法があるのであればそのプログラムを作成せよ。

正直言って、ちんぷんかんぷんなのです><
わかる方がいればよければ、教えてくださいませんか><


102 名前:デフォルトの名無しさん [2006/11/29(水) 23:12:10 ]
>>100
基本的にリンカーに対してライブラリを指定するだけである。

最近のコンパイラは、コンパイラ・ドライバというものが、コンパイラやリンカーなどを
自動的に次々呼び出しているので、そのヘルプをよく読んで、リンカーにライブラリを
指定するオプションを探すべし。

コンパイラ・ドライバには、コンパイラへのオプションと、リンカーへのオプションを
個々に与えることができる。

この辺は、便利になった分かえって昔より何やってるのかわからなくなってる。

>>101
球面三角がんばれw


103 名前:デフォルトの名無しさん [2006/11/30(木) 02:28:58 ]
>>101
どうも熱海の島から射程約6000kmのテポドンを発射しているようだが、
方位角(ν)の定義が分からん。もう少し詳しく。
まぁ式が与えられているので情報としてはすでに十分なのだが、
数式から逆算する気力がない。

cosα=sinθ1sinθ2+cosθ1cosθ2cos刄ノ は内積から出た。

104 名前:デフォルトの名無しさん mailto:sage [2006/11/30(木) 21:33:37 ]
>>101
今度は2ちゃんに書いた後mixiですか。

105 名前:デフォルトの名無しさん [2006/11/30(木) 22:25:56 ]
>>101
答えは、ハワイのオアフ島だ。 北緯21度24分 西経157度53分だ。
ついでに発射地点は熱海ではなく、八王子のあたりだな。

PROGRAM vipper
IMPLICIT NONE
REAL :: theta1, theta2, phi1, phi2, alpha, anu, pi
REAL :: rot_z(3, 3), rot_y(3, 3), vec1(3), vec2(3)
CHARACTER :: ns, ew
pi = 4.0 * ATAN(1.0)
alpha = 6242.2 / 6370.0
anu = ( 180.0 - 86.6 ) * pi / 180.0
theta1 = ( 90.0 - ( 35.0 + 40.0 / 60.0 ) ) * pi / 180.0
phi1 = ( 139.0 + 12.0 / 60.0 ) * pi / 180.0
!
rot_z(1, :) = (/ COS(phi1), -SIN(phi1), 0.0 /)
rot_z(2, :) = (/ SIN(phi1), COS(phi1), 0.0 /)
rot_z(3, :) = (/ 0.0, 0.0, 1.0 /)
!
rot_y(1, :) = (/ COS(theta1), 0.0, SIN(theta1) /)
rot_y(2, :) = (/ 0.0, 1.0, 0.0 /)
rot_y(3, :) = (/ -SIN(theta1), 0.0, COS(theta1) /)
!
vec1(1) = SIN(alpha) * COS(anu)
vec1(2) = SIN(alpha) * SIN(anu)
vec1(3) = COS(alpha)
!
vec2 = MATMUL(rot_z, MATMUL(rot_y, vec1))
!


106 名前:デフォルトの名無しさん [2006/11/30(木) 22:27:15 ]
theta2 = ASIN(vec2(3)) * 180.0 / pi
phi2 = ATAN2(vec2(2), vec2(1)) * 180.0 / pi
!
PRINT *, theta2, phi2
ns = 'N'
IF (theta2 < 0.0) ns = 'S'
ew = 'E'
IF ( phi2 < 0.0) ew = 'W'
PRINT '(i4, a, i2, 1x, a)', INT(ABS(theta2)), ' ', NINT(( ABS(theta2) - INT(ABS(theta2)) ) * 60.0), ns
PRINT '(i4, a, i2, 1x, a)', INT(ABS( phi2)), ' ', NINT(( ABS( phi2) - INT(ABS( phi2)) ) * 60.0), ew
STOP
END PROGRAM vipper


107 名前:105 [2006/11/30(木) 22:29:33 ]
ごめん 北緯と南緯の処理が間違ったままの古いのうpしてしまった。
ま、本質は変わらんから適当に処理しておいてくれ。

質問があれば、答えやすく論理的に聞いてくれ。




108 名前:105 mailto:sage [2006/11/30(木) 22:33:40 ]
スレ汚し すまんこw

出力結果だ。

21.39687 -157.8804
21 24 N
157 53 W
Press any key to continue


あと、方位角νは真北から時計回りに測ることとした。
つまり今の問題では、八王子からほぼ真東に、地球の半径とだいたい同じだけ飛ぶと
ハワイのホノルル近辺に着くという事だ。

Google Earthで確かめて味噌。定規を使うと2地点間の距離を測れる。


109 名前:デフォルトの名無しさん mailto:sage [2006/12/01(金) 12:38:00 ]
Mixi より vipper の方が上なのかよw 

110 名前:デフォルトの名無しさん [2006/12/01(金) 15:04:03 ]
>105さんありがとうございます

今日だされた答えを見比べてみたら、合っています!!
でも、私が実際にやってみた所たくさんのエラー出てきてどうしようもない
状態です><
今、私が利用しているのは[fc pad FTR77]というfortran77のものなんですが
どうしてエラーが出てしまうのかがよくわかりません><

もしも今回のものがfortran77でないとしたら、今度から実際にやるとしたら
どのようなプログラムになるのですか?

よければ、教えてください><

111 名前:デフォルトの名無しさん mailto:sage [2006/12/01(金) 19:50:23 ]
浮動小数点の値がでかすぎて整数型に変えられません
ってエラーが出てくるんですが、どうすれば回避できますか?
浮動小数点のままちっちゃくして(10で割るとか)整数型に変えてから10を
掛けるとかすれば回避できると思いますけど(端数は取っといて後で足すとして)
こんな妙なことする必要ないですよね…

くだすれに書き込むべきかと思いましたが落ちてますよね?


112 名前:デフォルトの名無しさん mailto:sage [2006/12/01(金) 20:10:12 ]
くだすれFORTRAN(超初心者用)その2
pc8.2ch.net/test/read.cgi/tech/1164121236/

それから質問内容は「具体的に」な

113 名前:デフォルトの名無しさん mailto:sage [2006/12/01(金) 20:28:00 ]
>>112
あれ?たってましたか…すみません。
そちらで聞いてきます、ありがとう。

114 名前:デフォルトの名無しさん mailto:sage [2006/12/01(金) 23:08:57 ]
>>110
つ ttp://ace.phys.h.kyoto-u.ac.jp/~tomita/education/fortran90/sec0.html

これ見て77に直せ。

115 名前:デフォルトの名無しさん mailto:sage [2006/12/01(金) 23:14:37 ]
>>111
今の一般のFORTRANの整数は32ビットの整数だ。
その場合表しうる数の範囲は−2^31〜2^31−1だ。

2^31=2147483648〜2*10^9→2ギガ だから、これより絶対値の大きい
実数を整数に変換しようとすればエラーが出る。

たとえ10で割ってうまく収まっても10倍したらオーバーフローするので無意味だ。
整数のオーバーフローは検知されないので(オプションにもよるが)実行時エラーが
出ないまま無意味な計算が続くことになる。



116 名前:デフォルトの名無しさん mailto:sage [2006/12/01(金) 23:23:55 ]
>>110
それはFortran90のプログラムだから、Fortran77ではエラーが出るのは当然だ。
ちみは今度からは、くだスレの方に書きなさい。

しかしその程度のレベルで、あの座標回転を使って解いたプログラムを出したら
他人にやってもらったことがバレバレだwww

次からは最初にFORTRAN77でお願いしますと書いておきなさい。

117 名前:デフォルトの名無しさん mailto:sage [2006/12/03(日) 01:14:47 ]
もっと初心者にやさしくしてやれよ。

Fortranユーザーを増やすために。



118 名前:デフォルトの名無しさん mailto:sage [2006/12/03(日) 04:16:33 ]
>>117
同意・・・(どうでもいいがw)

119 名前:デフォルトの名無しさん mailto:sage [2006/12/03(日) 05:14:42 ]
初心者っつーより只の宿題教えてクンっぽいが。

120 名前:デフォルトの名無しさん mailto:sage [2006/12/03(日) 18:07:18 ]
FORTRAN77
のGOTO文とラベルの嵐に
いやになり,暫くC++系に浮気してたが
Fortran90当りからまたフォトランナーに戻った

121 名前:デフォルトの名無しさん mailto:sage [2006/12/03(日) 19:04:12 ]
>>120
おかえりなさい。

C言語は、C99,D,C++,ObjectiveC,SecureなCなどに分裂してきているので、
煽ってこの分裂をいっそう深めて、Fortranを有利にしてくれ。



122 名前:デフォルトの名無しさん mailto:sage [2006/12/04(月) 03:38:34 ]
>>121
それを発展ともいうんだがw

123 名前:デフォルトの名無しさん mailto:sage [2006/12/04(月) 17:38:37 ]
計算量が増えてきたので、1台パソコンを増やそうとしているのですが、
(現在Pen4 3.6GHz、IntelVisualFortran9.0)
並列計算しそうにないコードなので、CPUの選択に迷っています。
今までPen4あたりのシングルコアで流していた方はこれから
どうされるつもりですか?
Core2Duoとかどうなんでしょう・・・
上の方ではCore2Duoの方が速いという書き込みがありますが・・・
一応予算は1式20万円位を想定しています.

124 名前:デフォルトの名無しさん mailto:sage [2006/12/04(月) 23:45:38 ]
>>122
いや、ハッテンは結構なんだが、うまく同じくらいに枝分かれしてもらえると、内ゲバが始まって
全部衰退してくれて助かる。

あとC派生言語がSecureな方向に向かってくれると、最適化スピードが落ちてやがて自滅するだろう。
バッファーオーバーランの恐怖とかを煽って常にSUBCHKかけたまま走るように仕向けるべし。

JavaやC#などは結局根本的に方向を間違っていると思う。
UCSD p-code Pascalの昔から、VirtualMachineはとてもいいアイデアのように思えて、
それでいてうまく行ったためしがない。スピードがあればエミュレーションで十分だと、むかしから
言われてきたが、スピードが上がると新しい使い方が出てきて、ギリギリのCPU消費が
求められるからうまく行くはずがない。


もっともFortranも規格がどんどん肥大化していてかつてのPL/I型の破滅の道を
たどっている気がしなくも無いのだがw

125 名前:デフォルトの名無しさん mailto:sage [2006/12/05(火) 10:31:13 ]
>>124
PL/Iかw
VMはわしらのように計算機として使う人には無理だが
普通に遊ぶ程度ならいいんじゃないか?
っていうか大丈夫なくらいPCの性能があがったんじゃないか?

もちろん、FortranでVM使われたら根本的な間違いだが
Javaの方向もアリなんじゃないか?
Fortranと用途が重ならないし・・・

ちょっとPL/Iがなつかしくなって書きコ

126 名前:デフォルトの名無しさん [2006/12/05(火) 14:26:13 ]
C Pad for Salford FTN77 をつかっていますが、プログラムを実行すると
RUN TIME ERROR
00402c50 SOLU [+0174] [recur= 1]
00401000 TDOFS [+09ca]
が出ます。
RUN TIME ERRORとはなんでしょうか??
メッセージ欄には
「 Licensed to: FTN77 Personal Edition
Department: Non-commercial use only
0001) omega1 theta0 theta1 alph beta theta g()/kG
*** Unexpected continuation line (have you got more than 19?)

*** Compilation failed

^C  」
とでますが、よくわからないです(−−;)
どなたか教えてください!!





127 名前:デフォルトの名無しさん mailto:sage [2006/12/05(火) 22:54:37 ]
>>126
>*** Unexpected continuation line (have you got more than 19?)
>*** Compilation failed

せっかくコンパイラがメッセージを出しているのだから、ちゃんと読むように。



128 名前:デフォルトの名無しさん mailto:sage [2006/12/06(水) 00:05:57 ]
>>126
まったく>>127の言うとおりだ。
子供が泣いているのに、かまってやらない育児放棄の母親レベルだ。


漏れの診断では、2chからコピペしたので、6カラム文の字下げをしていない。
そのせいで継続行に勘違いされている。


129 名前:デフォルトの名無しさん [2006/12/06(水) 12:51:58 ]
>>127
じゃあ英訳してあげたら??
子供が泣いているのに、かまってやらない育児放棄の母親レベルだ。







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

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

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