4.2 異なる大きさの図形

大きい図形の隣に小さな図形を並べる時には, grsvpt を使って陽にビュー ポートを設定することになります. 次のプログラム jump1 を御覧下さ い. まず, ビューポートを (0.15,0.45,0.65,0.95) として, 描画範囲 の左上に正方形の図を描きます. 内容は, 第2.1節のプロ グラム hop と同様のリサジュー図です. 次に, 43行めで grfig ルーチンを呼んで2番めの図を描くために必要な初期化をします. grfrm と違って, 次のフレームには移りません. そして, ビューポートを (0.15,0.95,0.1,0.5) として下の図を描きます. こうすれば, 縦横比が1:2の 長方形の図となります. 内容は, 第3.3節の分布図と同様の ものです.

\resizebox{10cm}{!}{\includegraphics{jump/jump1.eps}}
jump1.rb: frame1

# jump1.rb

require "narray"
require "numru/dcl"

include NumRu
include NMath

nmax = 400
dt = 2*PI/(nmax-1)

x = NArray.sfloat(nmax)
y = NArray.sfloat(nmax)

#-- data 1 ----
dt = 2*PI/(nmax-1)
t = NArray.sfloat(nmax).indgen! * dt
x = 5*sin(4*t)
y = 5*cos(5*t)

#-- graph 1 ----
iws = (ARGV[0] || (puts ' WORKSTATION ID (I)  ? ;'; DCL::sgpwsn; gets)).to_i
DCL::gropn iws
DCL::grfrm

DCL::grswnd(-6.0, 6.0, -6.0, 6.0)
DCL::grsvpt(0.15, 0.45, 0.65, 0.95)
DCL::grstrn( 1 )
DCL::grstrf

DCL::ussttl('X1', '', 'Y1', '')
DCL::usdaxs

DCL::uulin(x, y)

#-- data 2 ----
iseed = 0

x[0] = 2*(rand(iseed)-0.5)
y[nmax-1] = x[0]

for n in 1..nmax-1
  x[n] = 2*(rand(iseed)-0.5)
  y[n-1] = x[n]
end

#-- graph 2 ----
DCL::grfig

DCL::grswnd(-1.1, 1.1, -1.1, 1.1)
DCL::grsvpt(0.15, 0.95, 0.1, 0.5)
DCL::grstrn(1)
DCL::grstrf

DCL::ussttl('X2-TITLE', '', 'Y2-TITLE', '')
DCL::usdaxs

DCL::uumrk(x, y)

DCL::grcls

program jump1