mk-mode BLOG

このブログは自作の自宅サーバに構築した Debian GNU/Linux で運用しています。
PC・サーバ構築等の話題を中心に公開しております。(クローンサイト: GitHub Pages

ブログ開設日2009-01-05
サーバ連続稼働時間
Reading...
Page View 合計
Reading...
今日
Reading...
昨日
Reading...

Ruby - 日・月の出・入・南中計算 gem の作成!

[ プログラミング, 暦・カレンダー ] [ Ruby, RubyGems, カレンダー ]

こんばんは。

当方、 「日の出・日の入りの計算―天体の出没時刻の求め方」を参考に日・月の出・入・南中を計算する Ruby スクリプトを作成しておりましたが、あらゆる面で流用したくなったために、今回 RubyGems ライブラリにし公開することとしました。

以下では、今回作成した gem の簡単な利用方法をご紹介します。

0. 前提条件

  • Ruby 2.3.1-p112 での作業を想定。
  • 自作した gem ライブラリの名称は “mk_sunmoon” で、計算対象年月日は 0000-01-01 〜 9999-01-01。
  • 当ライブラリの計算可能項目
    • 日の出(時刻、方位角)
    • 日南中(時刻、高度)
    • 日の入(時刻、方位角)
    • 月の出(時刻、方位角)
    • 月南中(時刻、高度)
    • 月の入(時刻、方位角)

1. インストール

1
$ sudo gem install mk_sunmoon

2. Ruby スクリプトの作成例

sun_moon.rb
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
#! /usr/local/bin/ruby
# coding: utf-8
# 日の出・日の入の時刻・方位、日の南中の時刻・高度、
# 月の出・月の入の時刻・方位、月の南中の時刻・高度  の算出
#
# date          name            version
# 2016.06.13    mk-mode         1.00 新規作成
#
# Copyright(C) 2016 mk-mode.com All Rights Reserved.
#---------------------------------------------------------------------------------
# [引数] 第1: 日付 (Format: 99999999, Default: システム日付)
#              計算対象の日付(グレゴリオ暦)(JST)を半角8桁数字で指定。
#        第2: 緯度 (Format: [+-]999.99999999, Default: 35.47222222)
#              (度で指定。北緯は +, 南緯は -, 小数点以下は省略可)
#        第3: 経度 (Format: [+-]999.99999999, Default: 133.05055556)
#              (度で指定。東経は +, 西経は - ,小数点以下は省略可)
#        第4: 標高 (Format: [+]9999.99999999, Default: 0.0)
#              (メートルで指定。小数点以下は省略可)
#---------------------------------------------------------------------------------
#+
require 'mk_sunmoon'

class SunMoon
  USAGE =<<-EOS
  [USAGE] ./sun_moon.rb [date[, latitude[, longitude[, altitude]]]]
  引数
  第1: 日付 (Format: 99999999, Default: システム日付)
        計算対象の日付(グレゴリオ暦)(JST)を半角8桁数字で指定。
  第2: 緯度 (Format: [+-]999.99999999, Default: 35.47222222)
        (度で指定。北緯は +, 南緯は -, 小数点以下は省略可)
  第3: 経度 (Format: [+-]999.99999999, Default: 133.05055556)
        (度で指定。東経は +, 西経は - ,小数点以下は省略可)
  第4: 標高 (Format: [+]9999.99999999, Default: 0.0)
        (メートルで指定。小数点以下は省略可)
EOS
  def initialize
    check_args(ARGV)
    @obj = MkSunmoon.new(*ARGV)
  end

  def exec
    begin
      sign_lat = @obj.lat < 0 ? "S" : "N"
      sign_lon = @obj.lon < 0 ? "W" : "E"
      sr = @obj.sunrise
      ss = @obj.sunset
      sm = @obj.sun_mp
      mr = @obj.moonrise
      ms = @obj.moonset
      mm = @obj.moon_mp
      str  = sprintf("  %04d-%02d-%02d", @obj.year, @obj.month, @obj.day)
      str << " [#{@obj.lat}#{sign_lat}, #{@obj.lon}#{sign_lon}, #{@obj.alt}m]\n"
      str << "  日の出: #{sr[0]} (方位角: "
      str << (sr[1] == "---" ? "--------°)\n" : sprintf("%8.4f°)\n", sr[1]))
      str << "  日南中: #{sm[0]} (  高度: "
      str << (sm[1] == "---" ? "--------°)\n" : sprintf("%8.4f°)\n", sm[1]))
      str << "  日の入: #{ss[0]} (方位角: "
      str << (ss[1] == "---" ? "--------°)\n" : sprintf("%8.4f°)\n", ss[1]))
      str << "  月の出: #{mr[0]} (方位角: "
      str << (mr[1] == "---" ? "--------°)\n" : sprintf("%8.4f°)\n", mr[1]))
      str << "  月南中: #{mm[0]} (  高度: "
      str << (mm[1] == "---" ? "--------°)\n" : sprintf("%8.4f°)\n", mm[1]))
      str << "  月の入: #{ms[0]} (方位角: "
      str << (ms[1] == "---" ? "--------°)\n" : sprintf("%8.4f°)\n", ms[1]))
      puts str
    rescue => e
      $stderr.puts "[#{e.class}] #{e.message}"
      e.backtrace.each { |tr| $stderr.puts "\t#{tr}" }
      exit 1
    end
  end

  private

  def check_args(args)
    date, lat, lon, alt = args

    begin
      if (date && date !~ /^\d{8}$/) ||
         (lat && lat !~ /^[+-]?\d{,2}(\.\d*)?$/) ||
         (lon && lon !~ /^[+-]?\d{,3}(\.\d*)?$/) ||
         (alt && alt !~ /^+?\d{,4}(\.\d*)?$/)
        puts USAGE
        exit 0
      end
    rescue => e
      raise
    end
  end
end

exit unless __FILE__ == $0
SunMoon.new.exec

3. サンプルスクリプトの実行

1
2
3
4
5
6
7
8
$ ./sun_moon.rb 20160613 35.47222222 133.05055556 0
  2016-06-13 [35.47222222N, 133.05055556E, 0.0m]
  日の出: 04:51:52 (方位角:  60.3626°)
  日南中: 12:07:52 (  高度:  77.7587°)
  日の入: 19:23:59 (方位角: 299.6796°)
  月の出: 12:48:14 (方位角:  89.5617°)
  月南中: 18:58:52 (  高度:  54.1050°)
  月の入: 00:32:24 (方位角: 272.8283°)

4. gem ライブラリ


以前作成した Ruby スクリプトを何かと応用したかったので gem ライブラリ化した次第です。

以上。

Comments