SmartQuant Discussion

Automated Quantitative Strategy Development, SmartQuant Product Discussion and Technical Support Forums
It is currently Mon Sep 24, 2018 3:30 am

All times are UTC + 3 hours




Post new topic Reply to topic  [ 1 post ] 
Author Message
 Post subject: Cyklop indicator
PostPosted: Wed Jun 24, 2009 11:32 pm 
Offline

Joined: Thu Sep 20, 2007 6:43 pm
Posts: 122
Location: Poland
Hi :)

This is my "Cyklop" indicator. Maybe for someone it will be usefull :)

Code:
using System;
using System.Drawing;

using OpenQuant.API;
using OpenQuant.API.Indicators;
using OpenQuant.API.Plugins;

namespace Cyklop
{
   public class Cyklop : UserIndicator
   {
      private double response;
      
      public Cyklop(BarSeries input) : base(input)
      {
         Name = "Cyklop";
      }
      
      public override double Calculate(int index)
      {   
         if (index > 100)
         {
            response =
               20.30176462753054880 * Input[index, BarData.Close]
               +19.89517503255600770 * Input[index - 1, BarData.Close]
               +19.09101103080196890 * Input[index - 2, BarData.Close]
               +17.90711953485438460 * Input[index - 3, BarData.Close]
               +16.36963803048180570 * Input[index - 4, BarData.Close]
               +14.51265052594307650 * Input[index - 5, BarData.Close]
               +12.37698774465265930 * Input[index - 6, BarData.Close]
               +10.00935345287616760 * Input[index - 7, BarData.Close]
               +7.46141708838192219 * Input[index -  8, BarData.Close]
               +4.78848889436422631 * Input[index - 9, BarData.Close]
               +2.048047808219 * Input[index - 10, BarData.Close]
               -0.701507283322 * Input[index - 11, BarData.Close]
               -3.40208530299827006 * Input[index - 12, BarData.Close]
               -5.99741003891303670 * Input[index - 13, BarData.Close]
               -8.43445506875376161 * Input[index  - 14, BarData.Close]
               -10.66417836091287260 * Input[index - 15, BarData.Close]
               -12.64286312464568600 * Input[index - 16, BarData.Close]
               -14.33322032070694800 * Input[index - 17, BarData.Close]
               -15.70481631634793550 * Input[index - 18, BarData.Close]
               -16.73501249662616530 * Input[index - 19, BarData.Close]
               -17.40900634023730830 * Input[index - 20, BarData.Close]
               -17.72030972186459510 * Input[index - 21, BarData.Close]
               -17.67044624476172740 * Input[index - 22, BarData.Close]
               -17.26905193931774460 * Input[index - 23, BarData.Close]
               -16.53340609896157790 * Input[index - 24, BarData.Close]
               -15.48764916710436700 * Input[index - 25, BarData.Close]
               -14.16215614765486210 * Input[index - 26, BarData.Close]
               -12.59288125256666820 * Input[index - 27, BarData.Close]
               -10.82026662617382940 * Input[index - 28, BarData.Close]
               -8.88795048740255211 * Input[index - 29, BarData.Close]
               -6.84180357772046222 * Input[index - 30, BarData.Close]
               -4.72909983326097905 * Input[index - 31, BarData.Close]
               -2.596864930251 * Input[index - 32, BarData.Close]
               -0.490902149756 * Input[index - 33, BarData.Close]
               +1.544667468747 * Input[index - 34, BarData.Close]
               +3.46932190284909492 * Input[index - 35, BarData.Close]
               +5.24617696071075290 * Input[index - 36, BarData.Close]
               +6.84333549693778664 * Input[index - 37, BarData.Close]
               +8.23399222479030257 * Input[index - 38, BarData.Close]
               +9.39714063445486758 * Input[index - 39, BarData.Close]
               +10.31764768985001450 * Input[index - 40, BarData.Close]
               +10.98646697025617410 * Input[index - 41, BarData.Close]
               +11.40081174277368170 * Input[index - 42, BarData.Close]
               +11.56383892802017500 * Input[index - 43, BarData.Close]
               +11.48407419877762510 * Input[index - 44, BarData.Close]
               +11.17510785713783150 * Input[index - 45, BarData.Close]
               +10.65535682270992270 * Input[index - 46, BarData.Close]
               +9.94723379746933922 * Input[index - 47, BarData.Close]
               +9.07588430189692552 * Input[index - 48, BarData.Close]
               +8.06909104557127499 * Input[index - 49, BarData.Close]
               +6.95679451976188812 * Input[index - 50, BarData.Close]
               +5.76878347085071752 * Input[index - 51, BarData.Close]
               +4.53592781775697773 * Input[index - 52, BarData.Close]
               +3.28777916161014705 * Input[index - 53, BarData.Close]
               +2.052872663665 * Input[index - 54, BarData.Close]
               +0.857511000871 * Input[index - 55, BarData.Close]
               -0.2744275247557 * Input[index - 56, BarData.Close]
               -1.322008888862 * Input[index - 57, BarData.Close]
               -2.267551911958 * Input[index - 58, BarData.Close]
               -3.096796209009 * Input[index - 59, BarData.Close]
               -3.79924836880220695 * Input[index - 60, BarData.Close]
               -4.36842124701495838 * Input[index - 61, BarData.Close]
               -4.80146803409200462 * Input[index - 62, BarData.Close]
               -5.09857596264640911 * Input[index - 63, BarData.Close]
               -5.26301331855863186 * Input[index - 64, BarData.Close]
               -5.30180183955435513 * Input[index - 65, BarData.Close]
               -5.22447821271621660 * Input[index - 66, BarData.Close]
               -5.04107502298629662 * Input[index - 67, BarData.Close]
               -4.76591843809617988 * Input[index - 68, BarData.Close]
               -4.41239823219124006 * Input[index - 69, BarData.Close]
               -3.99594809199802370 * Input[index - 70, BarData.Close]
               -3.53179731825870924 * Input[index - 71, BarData.Close]
               -3.035286310261 * Input[index - 72, BarData.Close]
               -2.521148703919 * Input[index - 73, BarData.Close]
               -2.003256834925 * Input[index - 74, BarData.Close]
               -1.494415762982 * Input[index - 75, BarData.Close]
               -1.006091940898 * Input[index - 76, BarData.Close]
               -0.548283182796 * Input[index - 77, BarData.Close]
               -0.1293603243533 * Input[index - 78, BarData.Close]
               +0.2444124870260 * Input[index - 79, BarData.Close]
               +0.569199569345 * Input[index - 80, BarData.Close]
               +0.842876377613 * Input[index - 81, BarData.Close]
               +1.063062976919 * Input[index - 82, BarData.Close]
               +1.227949139989 * Input[index - 83, BarData.Close]
               +1.344922347274 * Input[index - 84, BarData.Close]
               +1.412050251308 * Input[index - 85, BarData.Close]
               +1.436049354018 * Input[index - 86, BarData.Close]
               +1.421047832495 * Input[index - 87, BarData.Close]
               +1.372722782937 * Input[index - 88, BarData.Close]
               +1.296909792286 * Input[index - 89, BarData.Close]
               +1.199679276096 * Input[index - 90, BarData.Close]
               +1.087145521959 * Input[index - 91, BarData.Close]
               +0.965292120700 * Input[index - 92, BarData.Close]
               +0.840007141299 * Input[index - 93, BarData.Close]
               +0.717118380939 * Input[index - 94, BarData.Close]
               +0.602450650068 * Input[index - 95, BarData.Close]
               +0.502177424801 * Input[index - 96, BarData.Close]
               +0.423365578698 * Input[index - 97, BarData.Close]
               +0.374787991996 * Input[index - 98, BarData.Close]
               +0.368295243182 * Input[index - 99, BarData.Close]
               -0.812878177182 * Input[index - 100, BarData.Close];
            
            return response;
         }
         else
            return double.NaN;
      }      
   }
   
   public class MyStrategy : Strategy
   {
      public override void OnStrategyStart()
      {
         Cyklop cyklop = new Cyklop(Bars);
         cyklop.Color = Color.White;
         Draw(cyklop, 2);
      }

      public override void OnBar(Bar bar)
      {
      }
   }
}



Regards
MaRCHeW


Attachments:
File comment: Screenshot Cyklop indicator.
Cyklop.png
Cyklop.png [ 10.47 KiB | Viewed 3061 times ]

_________________
"Your worst day with OpenQuant is better than your best day with most of the other stuff."
Top
 Profile  
 
Display posts from previous:  Sort by  
Post new topic Reply to topic  [ 1 post ] 

All times are UTC + 3 hours


Who is online

Users browsing this forum: No registered users and 1 guest


You cannot post new topics in this forum
You cannot reply to topics in this forum
You cannot edit your posts in this forum
You cannot delete your posts in this forum
You cannot post attachments in this forum

Search for:
Jump to:  
cron
Powered by phpBB® Forum Software © phpBB Group