Commodity Channel Index (CCI)

Overview

Developed by Donald Lambert and featured in Commodities magazine in 1980, the Commodity Channel Index (CCI) is a versatile indicator that can be used to identify a new trend or warn of extreme conditions. Lambert originally developed CCI to identify cyclical turns in commodities, but the indicator can successfully applied to indices, ETFs, stocks and other securities. In general, CCI measures the current price level relative to an average price level over a given period of time. CCI is relatively high when prices are far above their average. CCI is relatively low when prices are far below their average. In this manner, CCI can be used to identify overbought and oversold levels.

Mathematical description of the indicator please see at: Mathematical Description of Technical Indicators

to top

Adding indicator

To add any indicator to the chart, you need to use Data Provider with the fields required by the indicator. When such Data Provider is ready - you can add indicator to the chart.

Preparing Data Provider

Commodity Channel Index indicator needs Data Provider with High, Low and Close or Value fields.

Sample XML/JSON of Data Provider, which can be used to create Commodity Channel Index indicator:

XML/JSON Syntax
Plain code
03     <data_provider data_set="dataSet1" id="dpMsft">
04       <fields>
05         <field type="High" column="2" approximation_type="High" />
06         <field type="Low" column="3" approximation_type="Low" />
07         <field type="Close" column="4" approximation_type="Close" />
08       </fields>
09     </data_provider>
01{
03    {
04      dataSet: "dataSet1",
05      id: "dpMsft",
06      fields: [
07        {
08          type: "High",
09          column: 2,
10          approximationType: "High"
11        },
12        {
13          type: "Low",
14          column: 3,
15          approximationType: "Low"
16        },
17        {
18          type: "Close",
19          column: 4,
20          approximationType: "Close"
21        }
22      ]
23    }
24  ]
25}

to top

Indicator Declaration

As soon as Data Provider is ready you can add an indicator to a chart.

Commodity Channel Index indicator is usually shown on the chart below the chart with data (stock data). So we should declare it in another chart. Learn more about charts and layout in Chart Layout article.

XML/JSON for Commodity Channel Index declaration, note that there are two charts defined - one is used to show the stock data, and another one contains technical indicator:

XML/JSON Syntax
Plain code
01 <?xml version="1.0" encoding="UTF-8"?>
02 <stock xmlns="http://anychart.com/products/stock/schemas/1.9.0/schema.xsd">
03   <settings>
04     <charts>
05       <chart>
06         <series_list>
07           <series type="Line" data_provider="dpMsft" />
08         </series_list>
09       </chart>
10       <chart>
11         <technical_indicators>
12           <technical_indicator type="CCI" data_provider="dpMsft" />
13         </technical_indicators>
14       </chart>
15     </charts>
16   </settings>
17 </stock>
01{
02  settings: {
03    charts: [
04      {
05        seriesList: [
06          {
07            type: "Line",
08            dataProvider: "dpMsft"
09          }
10        ]
11      },
12      {
13        technicalIndicators: [
14          {
15            type: "CCI",
16            dataProvider: "dpMsft"
17          }
18        ]
19      }
20    ]
21  }
22}

After all things mentioned above are done, you can create a chart with Commodity Channel Index indicator, see basic Live Sample with it below:

Live Sample:  Technical Indicators - Adding Commodity Channel Index Indicator

to top

Indicator parameters

Commodity Channel Index has one type-specific parameter - period. This parameter is set in <cci_indicator> node, where all settings for Commodity Channel Index indicator are set.

XML for setting Commodity Channel Index parameters:

XML/JSON Syntax
Plain code
01{
02  type: "CCI",
03  dataProvider: "dpMsft",
04  cciIndicator: {
05    period: 14
06  }
07}

As you can see you just need to set period attribute in <cci_indicator> node, it accepts any integer greater than 1.

Live sample below shows sharpened CCI(14) indicator:

Live Sample:  Technical Indicators - Commodity Channel Index Parameters

to top

Visualization

To visualize and tune visualization of technical indicators AnyChart Stock Component uses the same methods as for the data series.

By default Commodity Channel Index is shown as series of Line type, but you can use almost any of available series types to show it on the chart - Spline, Area or Stick, for example.

Commodity Channel Index indicator settings are contained in <cci_indicator> node, also in this node you can put <series> subnode - this node defines how exactly indicator is displayed on the chart. This node is identical to <series> node used to describe data series, so you can do with indicator anything you can do with series.

Sample XML for changing indicator visualization:

XML/JSON Syntax
Plain code
01 <chart>
03     <technical_indicator type="CCI" data_provider="dpMsft">
04       <cci_indicator>
05         <series type="Spline" color="#469833">
06           <name><![CDATA[CCI(20)]]></name>
07           <line_series thickness="2" />
08         </series>
09       </cci_indicator>
10     </technical_indicator>
12 </chart>
01{
03    {
04      type: "CCI",
05      dataProvider: "dpMsft",
06      cciIndicator: {
07        series: {
08          type: "Spline",
09          color: "#469833",
10          name: "CCI(20)",
11          lineSeries: {
12            thickness: 2
13          }
14        }
15      }
16    }
17  ]
18}

Live sample below shows settings shown above:

Live Sample:  Technical Indicators - Commodity Channel Index Visualization Settings

to top