lib/zakuro/version/senmyou/stella/solar/average.rb in zakuro-0.7.2 vs lib/zakuro/version/senmyou/stella/solar/average.rb in zakuro-0.8.0
- old
+ new
@@ -24,11 +24,11 @@
# 初期化
#
# @param [Integer] western_year 西暦年
#
def initialize(western_year:)
- solar_term = Average.first_solar_term(western_year: western_year)
+ solar_term = self.class.first_solar_term(western_year: western_year)
super(solar_term: solar_term)
end
#
# 冬至から数えた1年データの月ごとに二十四節気を割り当てる
@@ -39,58 +39,60 @@
#
def set(annual_range:)
super(annual_range: annual_range)
end
- #
- # 計算開始する二十四節気を求める
- #
- # @param [Integer] western_year 西暦年
- #
- # @return [SolarTerm] 二十四節気
- #
- def self.first_solar_term(western_year:)
- # 天正冬至
- winter_solstice = Origin::WinterSolstice.get(western_year: western_year)
+ class << self
+ #
+ # 計算開始する二十四節気を求める
+ #
+ # @param [Integer] western_year 西暦年
+ #
+ # @return [SolarTerm] 二十四節気
+ #
+ def first_solar_term(western_year:)
+ # 天正冬至
+ winter_solstice = Origin::WinterSolstice.get(western_year: western_year)
- # 二十四節気(冬至)
- solar_term = Cycle::SolarTerm.new(index: 0, remainder: winter_solstice)
+ # 二十四節気(冬至)
+ solar_term = Cycle::SolarTerm.new(index: 0, remainder: winter_solstice)
- first_solar_term_index = Average.calc_first_solar_term_index(western_year: western_year)
+ first_solar_term_index = calc_first_solar_term_index(western_year: western_year)
- # 対象の二十四節気まで戻す
- solar_term.prev_by_index(first_solar_term_index)
+ # 対象の二十四節気まで戻す
+ solar_term.prev_by_index(first_solar_term_index)
- solar_term
- end
+ solar_term
+ end
- # :reek:TooManyStatements { max_statements: 6 }
+ # :reek:TooManyStatements { max_statements: 6 }
- #
- # 計算開始する二十四節気番号を求める
- #
- # * 前提として入定気は冬至の手前にある
- # * 例えば、定気が大雪であれば入定気は大雪の範囲内にある
- # * 入定気は、定気の開始位置に重複しない限り、常に定気より後にある
- # * 基本的に定気の一つ前から起算すれば、当時から求めた11月(閏10/閏11月)に二十四節気を割り当てられる
- #
- # @param [Integer] western_year 西暦年
- #
- # @return [Integer] 二十四節気番号
- #
- def self.calc_first_solar_term_index(western_year:)
- # 天正閏余
- lunar_age = Origin::LunarAge.get(western_year: western_year)
+ #
+ # 計算開始する二十四節気番号を求める
+ #
+ # * 前提として入定気は冬至の手前にある
+ # * 例えば、定気が大雪であれば入定気は大雪の範囲内にある
+ # * 入定気は、定気の開始位置に重複しない限り、常に定気より後にある
+ # * 基本的に定気の一つ前から起算すれば、当時から求めた11月(閏10/閏11月)に二十四節気を割り当てられる
+ #
+ # @param [Integer] western_year 西暦年
+ #
+ # @return [Integer] 二十四節気番号
+ #
+ def calc_first_solar_term_index(western_year:)
+ # 天正閏余
+ lunar_age = Origin::LunarAge.get(western_year: western_year)
- solar_location = Solar::Location.new(lunar_age: lunar_age)
- solar_location.run
+ solar_location = Solar::Location.new(lunar_age: lunar_age)
+ solar_location.run
- solar_term_index = solar_location.index
+ solar_term_index = solar_location.index
- # 入定気の一つ後の二十四節気まで戻す(ただし11月経朔が二十四節気上にある場合は戻さない)
- solar_term_index += 1 unless solar_location.remainder.day.zero?
+ # 入定気の一つ後の二十四節気まで戻す(ただし11月経朔が二十四節気上にある場合は戻さない)
+ solar_term_index += 1 unless solar_location.remainder.day.zero?
- solar_term_index
+ solar_term_index
+ end
end
end
end
end
end