λ、Zを複素数とし、λ=LR+iLI , Z=X+iYとする。
今、任意の複素関数:F(Z,λ)として、また複素関数:G(Z,λ)=G(F(Z,λ),λ)とする。
ここで、巡回式:Z←G(F(Z,λ),λ)を考える。
Zの初期値をZ0とする。最大巡回回数をNmaxとする。
この巡回式で、X^2+Y^2>T(実定数)のとき、巡回ループを抜け出すとする。
今、λの複素平面領域:LRS<=LR<=LRE,LIS<=LI<=LIE の各点において、
Z←G(Z,λ)を実行する。此のループを貫通した場合、該当点を黄色とする。
ループを抜け出した時の巡回回数をNoとして、其の該当点を以下の色とする。
C=No mod 16,C=7→8,6→5。
***
下図は以下の条件の画像である。また、画像の下にBASIC/98のプログラムを示す。
F(Z,λ)=λ(1-1/Z)
G(Z,λ)=G(F(Z,λ),λ)=λ{F(Z,λ)-1/F(Z,λ)^2}
LRS=LIS=-1, LRE=LIE=1
Zo=0.5 ,Nmax=80 ,T=16
-------------------------
上図の6箇所の部分を拡大する。
-------------------------------------
------------------------------------
-----------------------------------------
一番上の画像の、BASIC/98のプロログラム。
10 REM F(Z)=λ(Z-1/Z) , G(Z)=λ{F(Z)-1/F(Z)^2}
20 REM 横軸(K):640 dots、縦軸(J):480 dots
30 CHAIN MERGE "C:\BASIC1\PRO\SUBR\ER1.BAS",40,ALL
40 ON ERROR GOTO 50000
50 CONSOLE ,,0,1
60 COLOR 0,7,,,2
70 CLS 3
80 OPEN "C:\BASIC1\RUN\DATA.DAT" FOR OUTPUT AS #1
90 OPEN "C:\BASIC1\RUN\親DATA.DAT" FOR OUTPUT AS #2
100 REM 親DATAの設定(随時変更)
110 LRS=-1 :LRE=1 :LIS=-1 :LIE=1
120 DR=(LRE-LRS)/480 :DI=(LIE-LIS)/480
130 WRITE #2,LRS,LRE,LIS,LIE,DR,DI
140 CLOSE #2
150 FOR J=0 TO 480
160 LOCATE 0,0:PRINT J
170 LI=LIS+DI*J
180 FOR K=0 TO 480
190 X=0.5 :Y=0
200 LR=LRS+DR*K
210 FOR N=0 TO 80
211 REM F(Z)=λ(Z-1/Z)=FR+iFI
220 A11=X^2+Y^2
230 IF A11=0 THEN 480
240 A1=1/(X^2+Y^2)
250 FR=LR*X*(1-A1)-LI*Y*(1+A1)
260 FI=LI*X*(1-A1)+LR*Y*(1+A1)
270 REM G(Z)=λ{F(Z)-1/F(Z)^2}=GR+iGI
280 A22=((FR^2-FI^2)^2+(2*FR*FI)^2)
290 IF A22=0 THEN 480
300 A2=1/((FR^2-FI^2)^2+(2*FR*FI)^2)
310 A3=FR-A2*(FR^2-FI^2)
320 A4=FI+2*A2*FI*FR
330 GR=LR*A3-LI*A4
340 GI=LI*A3+LR*A4
350 X=GR
360 Y=GI
370 Q=X^2+Y^2
380 '
390 IF Q>16 THEN 420
400 NEXT N
410 C=6:GOTO 460
420 '発散時のPSET
430 C=N MOD 16
440 IF C=7 THEN C=8
450 IF C=6 THEN C=5
460 PSET (K,J),C
470 WRITE #1,K,J,C,N
480 NEXT K
490 NEXT J
500 END