Class: TechnicalAnalysis::Indicator
- Inherits:
-
Object
- Object
- TechnicalAnalysis::Indicator
- Defined in:
- lib/technical_analysis/indicators/indicator.rb
Direct Known Subclasses
Adi, Adtv, Adx, Ao, Atr, Bb, Cci, Cmf, Cr, Dc, Dlr, Dpo, Dr, Eom, Fi, Ichimoku, Kc, Kst, Macd, Mfi, Mi, Nvi, Obv, ObvMean, Rsi, Sma, Sr, Trix, Tsi, Uo, Vi, Vpt, Wr
Class Method Summary collapse
-
.calculate(indicator_symbol, data, calculation, options = {}) ⇒ Object
Find the applicable indicator and looks up the value.
-
.find(indicator_symbol) ⇒ Object
Finds the applicable indicator and returns an instance.
-
.indicator_name ⇒ String
Returns the name of the technical indicator.
-
.indicator_symbol ⇒ String
Returns the symbol of the technical indicator.
-
.min_data_size(indicator_symbol, options) ⇒ Integer
Calculates the minimum number of observations needed to calculate the technical indicator.
-
.roster ⇒ Array
Returns an array of TechnicalAnalysis modules.
-
.valid_options ⇒ Array
Returns an array of valid keys for options for this technical indicator.
-
.validate_options(options) ⇒ Boolean
Validates the provided options for this technical indicator.
Class Method Details
.calculate(indicator_symbol, data, calculation, options = {}) ⇒ Object
Find the applicable indicator and looks up the value
77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 |
# File 'lib/technical_analysis/indicators/indicator.rb', line 77 def self.calculate(indicator_symbol, data, calculation, ={}) return nil unless CALCULATIONS.include? calculation indicator = find(indicator_symbol) raise "Indicator not found!" if indicator.nil? case calculation when :indicator_name; indicator.indicator_name when :indicator_symbol; indicator.indicator_symbol when :technicals; indicator.calculate(data, ) when :min_data_size; indicator.min_data_size() when :valid_options; indicator. when :validate_options; indicator.() else nil end end |
.find(indicator_symbol) ⇒ Object
Finds the applicable indicator and returns an instance
61 62 63 64 65 66 67 |
# File 'lib/technical_analysis/indicators/indicator.rb', line 61 def self.find(indicator_symbol) roster.each do |indicator| return indicator if indicator.indicator_symbol == indicator_symbol end nil end |
.indicator_name ⇒ String
Returns the name of the technical indicator
133 134 135 |
# File 'lib/technical_analysis/indicators/indicator.rb', line 133 def self.indicator_name raise "#{self.name} did not implement indicator_name" end |
.indicator_symbol ⇒ String
Returns the symbol of the technical indicator
126 127 128 |
# File 'lib/technical_analysis/indicators/indicator.rb', line 126 def self.indicator_symbol raise "#{self.name} did not implement indicator_symbol" end |
.min_data_size(indicator_symbol, options) ⇒ Integer
Calculates the minimum number of observations needed to calculate the technical indicator
100 101 102 103 |
# File 'lib/technical_analysis/indicators/indicator.rb', line 100 def self.min_data_size(indicator_symbol, ) raise "#{self.name} did not implement min_data_size" nil end |
.roster ⇒ Array
Returns an array of TechnicalAnalysis modules
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 |
# File 'lib/technical_analysis/indicators/indicator.rb', line 18 def self.roster [ TechnicalAnalysis::Adi, TechnicalAnalysis::Adtv, TechnicalAnalysis::Adx, TechnicalAnalysis::Ao, TechnicalAnalysis::Atr, TechnicalAnalysis::Bb, TechnicalAnalysis::Cci, TechnicalAnalysis::Cmf, TechnicalAnalysis::Cr, TechnicalAnalysis::Dc, TechnicalAnalysis::Dlr, TechnicalAnalysis::Dpo, TechnicalAnalysis::Dr, TechnicalAnalysis::Eom, TechnicalAnalysis::Fi, TechnicalAnalysis::Ichimoku, TechnicalAnalysis::Kc, TechnicalAnalysis::Kst, TechnicalAnalysis::Macd, TechnicalAnalysis::Mfi, TechnicalAnalysis::Mi, TechnicalAnalysis::Nvi, TechnicalAnalysis::Obv, TechnicalAnalysis::ObvMean, TechnicalAnalysis::Rsi, TechnicalAnalysis::Sma, TechnicalAnalysis::Sr, TechnicalAnalysis::Trix, TechnicalAnalysis::Tsi, TechnicalAnalysis::Uo, TechnicalAnalysis::Vi, TechnicalAnalysis::Vpt, TechnicalAnalysis::Wr, ] end |
.valid_options ⇒ Array
Returns an array of valid keys for options for this technical indicator
118 119 120 121 |
# File 'lib/technical_analysis/indicators/indicator.rb', line 118 def self. raise "#{self.name} did not implement valid_options" [] end |
.validate_options(options) ⇒ Boolean
Validates the provided options for this technical indicator
110 111 112 113 |
# File 'lib/technical_analysis/indicators/indicator.rb', line 110 def self.() raise "#{self.name} did not implement validate_options" false end |