/// <summary> /// MACD using JMA & DWMA /// </summary> /// <returns></returns> public Jurik_JMA_DWMA_MACD Jurik_JMA_DWMA_MACD(Data.IDataSeries input, int dwma_len, double jma_len, double jma_phase, int trail_len) { if (cacheJurik_JMA_DWMA_MACD != null) { for (int idx = 0; idx < cacheJurik_JMA_DWMA_MACD.Length; idx++) { if (cacheJurik_JMA_DWMA_MACD[idx].Dwma_len == dwma_len && Math.Abs(cacheJurik_JMA_DWMA_MACD[idx].Jma_len - jma_len) <= double.Epsilon && Math.Abs(cacheJurik_JMA_DWMA_MACD[idx].Jma_phase - jma_phase) <= double.Epsilon && cacheJurik_JMA_DWMA_MACD[idx].Trail_len == trail_len && cacheJurik_JMA_DWMA_MACD[idx].EqualsInput(input)) { return(cacheJurik_JMA_DWMA_MACD[idx]); } } } lock (checkJurik_JMA_DWMA_MACD) { checkJurik_JMA_DWMA_MACD.Dwma_len = dwma_len; dwma_len = checkJurik_JMA_DWMA_MACD.Dwma_len; checkJurik_JMA_DWMA_MACD.Jma_len = jma_len; jma_len = checkJurik_JMA_DWMA_MACD.Jma_len; checkJurik_JMA_DWMA_MACD.Jma_phase = jma_phase; jma_phase = checkJurik_JMA_DWMA_MACD.Jma_phase; checkJurik_JMA_DWMA_MACD.Trail_len = trail_len; trail_len = checkJurik_JMA_DWMA_MACD.Trail_len; if (cacheJurik_JMA_DWMA_MACD != null) { for (int idx = 0; idx < cacheJurik_JMA_DWMA_MACD.Length; idx++) { if (cacheJurik_JMA_DWMA_MACD[idx].Dwma_len == dwma_len && Math.Abs(cacheJurik_JMA_DWMA_MACD[idx].Jma_len - jma_len) <= double.Epsilon && Math.Abs(cacheJurik_JMA_DWMA_MACD[idx].Jma_phase - jma_phase) <= double.Epsilon && cacheJurik_JMA_DWMA_MACD[idx].Trail_len == trail_len && cacheJurik_JMA_DWMA_MACD[idx].EqualsInput(input)) { return(cacheJurik_JMA_DWMA_MACD[idx]); } } } Jurik_JMA_DWMA_MACD indicator = new Jurik_JMA_DWMA_MACD(); indicator.BarsRequired = BarsRequired; indicator.CalculateOnBarClose = CalculateOnBarClose; #if NT7 indicator.ForceMaximumBarsLookBack256 = ForceMaximumBarsLookBack256; indicator.MaximumBarsLookBack = MaximumBarsLookBack; #endif indicator.Input = input; indicator.Dwma_len = dwma_len; indicator.Jma_len = jma_len; indicator.Jma_phase = jma_phase; indicator.Trail_len = trail_len; Indicators.Add(indicator); indicator.SetUp(); Jurik_JMA_DWMA_MACD[] tmp = new Jurik_JMA_DWMA_MACD[cacheJurik_JMA_DWMA_MACD == null ? 1 : cacheJurik_JMA_DWMA_MACD.Length + 1]; if (cacheJurik_JMA_DWMA_MACD != null) { cacheJurik_JMA_DWMA_MACD.CopyTo(tmp, 0); } tmp[tmp.Length - 1] = indicator; cacheJurik_JMA_DWMA_MACD = tmp; return(indicator); } }
/// <summary> /// MACD using JMA & DWMA /// </summary> /// <returns></returns> public Jurik_JMA_DWMA_MACD Jurik_JMA_DWMA_MACD(Data.IDataSeries input, int dwma_len, double jma_len, double jma_phase, int trail_len) { if (cacheJurik_JMA_DWMA_MACD != null) for (int idx = 0; idx < cacheJurik_JMA_DWMA_MACD.Length; idx++) if (cacheJurik_JMA_DWMA_MACD[idx].Dwma_len == dwma_len && Math.Abs(cacheJurik_JMA_DWMA_MACD[idx].Jma_len - jma_len) <= double.Epsilon && Math.Abs(cacheJurik_JMA_DWMA_MACD[idx].Jma_phase - jma_phase) <= double.Epsilon && cacheJurik_JMA_DWMA_MACD[idx].Trail_len == trail_len && cacheJurik_JMA_DWMA_MACD[idx].EqualsInput(input)) return cacheJurik_JMA_DWMA_MACD[idx]; lock (checkJurik_JMA_DWMA_MACD) { checkJurik_JMA_DWMA_MACD.Dwma_len = dwma_len; dwma_len = checkJurik_JMA_DWMA_MACD.Dwma_len; checkJurik_JMA_DWMA_MACD.Jma_len = jma_len; jma_len = checkJurik_JMA_DWMA_MACD.Jma_len; checkJurik_JMA_DWMA_MACD.Jma_phase = jma_phase; jma_phase = checkJurik_JMA_DWMA_MACD.Jma_phase; checkJurik_JMA_DWMA_MACD.Trail_len = trail_len; trail_len = checkJurik_JMA_DWMA_MACD.Trail_len; if (cacheJurik_JMA_DWMA_MACD != null) for (int idx = 0; idx < cacheJurik_JMA_DWMA_MACD.Length; idx++) if (cacheJurik_JMA_DWMA_MACD[idx].Dwma_len == dwma_len && Math.Abs(cacheJurik_JMA_DWMA_MACD[idx].Jma_len - jma_len) <= double.Epsilon && Math.Abs(cacheJurik_JMA_DWMA_MACD[idx].Jma_phase - jma_phase) <= double.Epsilon && cacheJurik_JMA_DWMA_MACD[idx].Trail_len == trail_len && cacheJurik_JMA_DWMA_MACD[idx].EqualsInput(input)) return cacheJurik_JMA_DWMA_MACD[idx]; Jurik_JMA_DWMA_MACD indicator = new Jurik_JMA_DWMA_MACD(); indicator.BarsRequired = BarsRequired; indicator.CalculateOnBarClose = CalculateOnBarClose; #if NT7 indicator.ForceMaximumBarsLookBack256 = ForceMaximumBarsLookBack256; indicator.MaximumBarsLookBack = MaximumBarsLookBack; #endif indicator.Input = input; indicator.Dwma_len = dwma_len; indicator.Jma_len = jma_len; indicator.Jma_phase = jma_phase; indicator.Trail_len = trail_len; Indicators.Add(indicator); indicator.SetUp(); Jurik_JMA_DWMA_MACD[] tmp = new Jurik_JMA_DWMA_MACD[cacheJurik_JMA_DWMA_MACD == null ? 1 : cacheJurik_JMA_DWMA_MACD.Length + 1]; if (cacheJurik_JMA_DWMA_MACD != null) cacheJurik_JMA_DWMA_MACD.CopyTo(tmp, 0); tmp[tmp.Length - 1] = indicator; cacheJurik_JMA_DWMA_MACD = tmp; return indicator; } }