とりとめのないことを書いております。
by tempurature
カテゴリ
全体
プログラミング
scheme
verilog
未分類
以前の記事
2016年 04月
2016年 03月
2016年 02月
2016年 01月
2015年 12月
2015年 11月
2015年 10月
2015年 09月
2015年 08月
2015年 07月
2015年 06月
2015年 03月
お気に入りブログ
PHPで競技プログラミング
メモ帳
最新のトラックバック
ライフログ
検索
タグ
その他のジャンル
ブログパーツ
最新の記事
情報処理技術者試験 お疲れ様..
at 2016-04-17 18:55
基本情報技術者試験 平成27..
at 2016-04-14 04:48
基本情報技術者試験 平成27..
at 2016-04-13 23:03
苦い薬(ハーブ、サプリメント..
at 2016-04-09 14:03
「おバカ度チェックリスト」を..
at 2016-03-24 09:54
外部リンク
ファン
記事ランキング
ブログジャンル
画像一覧
B.メイヤー「オブジェクト指向入門」7.13 演習問題を解く(3)
この問題もビルドチェックしかしてません。しかも8章の生成プロシージャも使っています。

E7.4

note
    description: "2-dimentional polar coordinate system"
class
    POINT2
create
    make_cartesian,
    make_polar
feature
    make_cartesian(x1, y1: REAL)
        local
            m: SINGLE_MATH
        do
            create m
            rho := m.sqrt(sqr(x1)+sqr(y1))
            if y1 = 0.0 then
                if x1 >= 0.0 then
                    theta := 0.0
                else
                    theta := pi
                end
            elseif (y1/x1).is_nan then
                if (y1 < 1.0 and x1 < 1.0) then
                    theta := 0.0
                else
                    theta := y1.nan
                end
            elseif y1.is_positive_infinity then
                theta := 0.0
            elseif y1.is_negative_infinity then
                theta := pi
            else
                theta := m.arc_tangent (y1/x1)
            end
        end
    make_polar(r, th: REAL)
        do
            rho := r
            theta := th
        end
feature
    rho, theta: REAL
    x: REAL
            -- x-coordinate
        local
            m: SINGLE_MATH
        do
            create m
            Result := rho * m.cosine (theta)
        end
    y: REAL
            -- y-coordinate
        local
            m: SINGLE_MATH
        do
            create m
            Result := rho * m.sine (theta)
        end
    distance(p: POINT): REAL
            -- distance to p
        local
            m: SINGLE_MATH
        do
            create m
            Result := m.sqrt(sqr(x-p.x)+sqr(y-p.y))
        end
    translate(a, b: REAL)
            -- move a horizontally, b virtically
        local
            x1, y1: REAL
        do
            x1 := x
            y1 := y
            make_cartesian(x1+a, y1+b)
        end
    rotate(p:POINT; angle: REAL)
            -- rotate around p
        do
            translate(-p.x, -p.y)
            theta := theta + angle
            translate(p.x, p.y)
        end
    scale(factor: REAL)
            -- magnify by factor
        do
            rho := rho * factor
        end
feature{NONE}
    sqr(r: REAL): REAL
            -- square of a number
        do
            Result := r * r
        end
    pi: REAL
        local
            m: SINGLE_MATH
        do
            create m
            Result := m.pi.truncated_to_real
        end
end


[PR]
by tempurature | 2016-01-13 23:42 | プログラミング
<< Learn You a Has... IPAの情報処理技術者試験 申... >>