org.jfree.chart.demo.PriceVolumeDemo.java Source code

Java tutorial

Introduction

Here is the source code for org.jfree.chart.demo.PriceVolumeDemo.java

Source

/* ===========================================================
 * JFreeChart : a free chart library for the Java(tm) platform
 * ===========================================================
 *
 * (C) Copyright 2000-2004, by Object Refinery Limited and Contributors.
 *
 * Project Info:  http://www.jfree.org/jfreechart/index.html
 *
 * This library is free software; you can redistribute it and/or modify it under the terms
 * of the GNU Lesser General Public License as published by the Free Software Foundation;
 * either version 2.1 of the License, or (at your option) any later version.
 *
 * This library is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY;
 * without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
 * See the GNU Lesser General Public License for more details.
 *
 * You should have received a copy of the GNU Lesser General Public License along with this
 * library; if not, write to the Free Software Foundation, Inc., 59 Temple Place, Suite 330,
 * Boston, MA 02111-1307, USA.
 *
 * [Java is a trademark or registered trademark of Sun Microsystems, Inc. 
 * in the United States and other countries.]
 *
 * --------------------
 * PriceVolumeDemo.java
 * --------------------
 * (C) Copyright 2002-2004, by Object Refinery Limited.
 *
 * Original Author:  David Gilbert (for Object Refinery Limited).
 * Contributor(s):   -;
 *
 * $Id: PriceVolumeDemo.java,v 1.20 2004/05/11 14:56:17 mungady Exp $
 *
 * Changes
 * -------
 * 28-Mar-2002 : Version 1 (DG);
 * 23-Apr-2002 : Modified to use new CombinedXYPlot class (DG);
 * 25-Jun-2002 : Removed unnecessary imports (DG);
 * 11-Oct-2002 : Fixed errors reported by Checkstyle (DG);
 * 21-Nov-2002 : Implemented with dual axes, and used sample data from Chicago Mercantile
 *               Exchange (http://www.cme.com) (DG);
 *
 */

package org.jfree.chart.demo;

import java.text.DecimalFormat;
import java.text.SimpleDateFormat;

import org.jfree.chart.ChartFactory;
import org.jfree.chart.ChartPanel;
import org.jfree.chart.JFreeChart;
import org.jfree.chart.axis.NumberAxis;
import org.jfree.chart.labels.StandardXYToolTipGenerator;
import org.jfree.chart.plot.XYPlot;
import org.jfree.chart.renderer.xy.XYBarRenderer;
import org.jfree.chart.renderer.xy.XYItemRenderer;
import org.jfree.data.time.Day;
import org.jfree.data.time.TimeSeries;
import org.jfree.data.time.TimeSeriesCollection;
import org.jfree.data.xy.IntervalXYDataset;
import org.jfree.data.xy.XYDataset;
import org.jfree.date.MonthConstants;
import org.jfree.ui.ApplicationFrame;
import org.jfree.ui.RefineryUtilities;

/**
 * A demonstration application showing how to create a price-volume chart.
 *
 */
public class PriceVolumeDemo extends ApplicationFrame {

    /**
     * Constructs a new demonstration application.
     *
     * @param title  the frame title.
     */
    public PriceVolumeDemo(final String title) {

        super(title);
        final JFreeChart chart = createChart();
        final ChartPanel panel = new ChartPanel(chart, true, true, true, false, true);
        panel.setPreferredSize(new java.awt.Dimension(500, 270));
        setContentPane(panel);

    }

    /**
     * Creates a chart.
     *
     * @return a chart.
     */
    private JFreeChart createChart() {

        final XYDataset priceData = createPriceDataset();
        final String title = "Eurodollar Futures Contract (MAR03)";
        final JFreeChart chart = ChartFactory.createTimeSeriesChart(title, "Date", "Price", priceData, true, true,
                false);
        final XYPlot plot = chart.getXYPlot();
        final NumberAxis rangeAxis1 = (NumberAxis) plot.getRangeAxis();
        rangeAxis1.setLowerMargin(0.40); // to leave room for volume bars
        final DecimalFormat format = new DecimalFormat("00.00");
        rangeAxis1.setNumberFormatOverride(format);

        final XYItemRenderer renderer1 = plot.getRenderer();
        renderer1.setToolTipGenerator(
                new StandardXYToolTipGenerator(StandardXYToolTipGenerator.DEFAULT_TOOL_TIP_FORMAT,
                        new SimpleDateFormat("d-MMM-yyyy"), new DecimalFormat("0.00")));

        final NumberAxis rangeAxis2 = new NumberAxis("Volume");
        rangeAxis2.setUpperMargin(1.00); // to leave room for price line
        plot.setRangeAxis(1, rangeAxis2);
        plot.setDataset(1, createVolumeDataset());
        plot.setRangeAxis(1, rangeAxis2);
        plot.mapDatasetToRangeAxis(1, 1);
        final XYBarRenderer renderer2 = new XYBarRenderer(0.20);
        renderer2.setToolTipGenerator(
                new StandardXYToolTipGenerator(StandardXYToolTipGenerator.DEFAULT_TOOL_TIP_FORMAT,
                        new SimpleDateFormat("d-MMM-yyyy"), new DecimalFormat("0,000.00")));
        plot.setRenderer(1, renderer2);
        return chart;

    }

    /**
     * Creates a sample dataset.
     *
     * @return A sample dataset.
     */
    private XYDataset createPriceDataset() {

        // create dataset 1...
        final TimeSeries series1 = new TimeSeries("Price", Day.class);

        series1.add(new Day(2, MonthConstants.JANUARY, 2002), 95.565);
        series1.add(new Day(3, MonthConstants.JANUARY, 2002), 95.640);
        series1.add(new Day(4, MonthConstants.JANUARY, 2002), 95.710);

        series1.add(new Day(7, MonthConstants.JANUARY, 2002), 95.930);
        series1.add(new Day(8, MonthConstants.JANUARY, 2002), 95.930);
        series1.add(new Day(9, MonthConstants.JANUARY, 2002), 95.960);
        series1.add(new Day(10, MonthConstants.JANUARY, 2002), 96.055);
        series1.add(new Day(11, MonthConstants.JANUARY, 2002), 96.335);

        series1.add(new Day(14, MonthConstants.JANUARY, 2002), 96.290);
        series1.add(new Day(15, MonthConstants.JANUARY, 2002), 96.275);
        series1.add(new Day(16, MonthConstants.JANUARY, 2002), 96.240);
        series1.add(new Day(17, MonthConstants.JANUARY, 2002), 96.080);
        series1.add(new Day(18, MonthConstants.JANUARY, 2002), 96.145);

        series1.add(new Day(22, MonthConstants.JANUARY, 2002), 96.120);
        series1.add(new Day(23, MonthConstants.JANUARY, 2002), 96.015);
        series1.add(new Day(24, MonthConstants.JANUARY, 2002), 95.890);
        series1.add(new Day(25, MonthConstants.JANUARY, 2002), 95.8650);

        series1.add(new Day(28, MonthConstants.JANUARY, 2002), 95.880);
        series1.add(new Day(29, MonthConstants.JANUARY, 2002), 96.050);
        series1.add(new Day(30, MonthConstants.JANUARY, 2002), 96.065);
        series1.add(new Day(31, MonthConstants.JANUARY, 2002), 95.910);
        series1.add(new Day(1, MonthConstants.FEBRUARY, 2002), 96.015);

        series1.add(new Day(4, MonthConstants.FEBRUARY, 2002), 96.140);
        series1.add(new Day(5, MonthConstants.FEBRUARY, 2002), 96.195);
        series1.add(new Day(6, MonthConstants.FEBRUARY, 2002), 96.245);
        series1.add(new Day(7, MonthConstants.FEBRUARY, 2002), 96.220);
        series1.add(new Day(8, MonthConstants.FEBRUARY, 2002), 96.280);

        series1.add(new Day(11, MonthConstants.FEBRUARY, 2002), 96.265);
        series1.add(new Day(12, MonthConstants.FEBRUARY, 2002), 96.160);
        series1.add(new Day(13, MonthConstants.FEBRUARY, 2002), 96.120);
        series1.add(new Day(14, MonthConstants.FEBRUARY, 2002), 96.125);
        series1.add(new Day(15, MonthConstants.FEBRUARY, 2002), 96.265);

        series1.add(new Day(19, MonthConstants.FEBRUARY, 2002), 96.290);
        series1.add(new Day(20, MonthConstants.FEBRUARY, 2002), 96.275);
        series1.add(new Day(21, MonthConstants.FEBRUARY, 2002), 96.280);
        series1.add(new Day(22, MonthConstants.FEBRUARY, 2002), 96.305);

        series1.add(new Day(25, MonthConstants.FEBRUARY, 2002), 96.265);
        series1.add(new Day(26, MonthConstants.FEBRUARY, 2002), 96.185);
        series1.add(new Day(27, MonthConstants.FEBRUARY, 2002), 96.305);
        series1.add(new Day(28, MonthConstants.FEBRUARY, 2002), 96.215);
        series1.add(new Day(1, MonthConstants.MARCH, 2002), 96.015);

        series1.add(new Day(4, MonthConstants.MARCH, 2002), 95.970);
        series1.add(new Day(5, MonthConstants.MARCH, 2002), 95.935);
        series1.add(new Day(6, MonthConstants.MARCH, 2002), 95.935);
        series1.add(new Day(7, MonthConstants.MARCH, 2002), 95.705);
        series1.add(new Day(8, MonthConstants.MARCH, 2002), 95.4850);

        series1.add(new Day(11, MonthConstants.MARCH, 2002), 95.505);
        series1.add(new Day(12, MonthConstants.MARCH, 2002), 95.540);
        series1.add(new Day(13, MonthConstants.MARCH, 2002), 95.675);
        series1.add(new Day(14, MonthConstants.MARCH, 2002), 95.510);
        series1.add(new Day(15, MonthConstants.MARCH, 2002), 95.500);

        series1.add(new Day(18, MonthConstants.MARCH, 2002), 95.500);
        series1.add(new Day(19, MonthConstants.MARCH, 2002), 95.535);
        series1.add(new Day(20, MonthConstants.MARCH, 2002), 95.420);
        series1.add(new Day(21, MonthConstants.MARCH, 2002), 95.400);
        series1.add(new Day(22, MonthConstants.MARCH, 2002), 95.375);

        series1.add(new Day(25, MonthConstants.MARCH, 2002), 95.350);
        series1.add(new Day(26, MonthConstants.MARCH, 2002), 95.505);
        series1.add(new Day(27, MonthConstants.MARCH, 2002), 95.550);
        series1.add(new Day(28, MonthConstants.MARCH, 2002), 95.485);

        series1.add(new Day(1, MonthConstants.APRIL, 2002), 95.485);
        series1.add(new Day(2, MonthConstants.APRIL, 2002), 95.630);
        series1.add(new Day(3, MonthConstants.APRIL, 2002), 95.735);
        series1.add(new Day(4, MonthConstants.APRIL, 2002), 95.695);
        series1.add(new Day(5, MonthConstants.APRIL, 2002), 95.810);

        series1.add(new Day(8, MonthConstants.APRIL, 2002), 95.810);
        series1.add(new Day(9, MonthConstants.APRIL, 2002), 95.865);
        series1.add(new Day(10, MonthConstants.APRIL, 2002), 95.885);
        series1.add(new Day(11, MonthConstants.APRIL, 2002), 95.900);
        series1.add(new Day(12, MonthConstants.APRIL, 2002), 95.980);

        series1.add(new Day(15, MonthConstants.APRIL, 2002), 96.035);
        series1.add(new Day(16, MonthConstants.APRIL, 2002), 96.000);
        series1.add(new Day(17, MonthConstants.APRIL, 2002), 96.035);
        series1.add(new Day(18, MonthConstants.APRIL, 2002), 96.085);
        series1.add(new Day(19, MonthConstants.APRIL, 2002), 96.0750);

        series1.add(new Day(22, MonthConstants.APRIL, 2002), 96.105);
        series1.add(new Day(23, MonthConstants.APRIL, 2002), 96.075);
        series1.add(new Day(24, MonthConstants.APRIL, 2002), 96.210);
        series1.add(new Day(25, MonthConstants.APRIL, 2002), 96.255);
        series1.add(new Day(26, MonthConstants.APRIL, 2002), 96.310);

        series1.add(new Day(29, MonthConstants.APRIL, 2002), 96.310);
        series1.add(new Day(30, MonthConstants.APRIL, 2002), 96.325);
        series1.add(new Day(1, MonthConstants.MAY, 2002), 96.345);
        series1.add(new Day(2, MonthConstants.MAY, 2002), 96.285);
        series1.add(new Day(3, MonthConstants.MAY, 2002), 96.385);

        series1.add(new Day(6, MonthConstants.MAY, 2002), 96.380);
        series1.add(new Day(7, MonthConstants.MAY, 2002), 96.485);
        series1.add(new Day(8, MonthConstants.MAY, 2002), 96.230);
        series1.add(new Day(9, MonthConstants.MAY, 2002), 96.310);
        series1.add(new Day(10, MonthConstants.MAY, 2002), 96.445);

        series1.add(new Day(13, MonthConstants.MAY, 2002), 96.355);
        series1.add(new Day(14, MonthConstants.MAY, 2002), 96.180);
        series1.add(new Day(15, MonthConstants.MAY, 2002), 96.240);
        series1.add(new Day(16, MonthConstants.MAY, 2002), 96.325);
        series1.add(new Day(17, MonthConstants.MAY, 2002), 96.200);

        series1.add(new Day(20, MonthConstants.MAY, 2002), 96.305);
        series1.add(new Day(21, MonthConstants.MAY, 2002), 96.385);
        series1.add(new Day(22, MonthConstants.MAY, 2002), 96.445);
        series1.add(new Day(23, MonthConstants.MAY, 2002), 96.385);
        series1.add(new Day(24, MonthConstants.MAY, 2002), 96.390);

        series1.add(new Day(28, MonthConstants.MAY, 2002), 96.390);
        series1.add(new Day(29, MonthConstants.MAY, 2002), 96.475);
        series1.add(new Day(30, MonthConstants.MAY, 2002), 96.555);
        series1.add(new Day(31, MonthConstants.MAY, 2002), 96.500);

        series1.add(new Day(3, MonthConstants.JUNE, 2002), 96.540);
        series1.add(new Day(4, MonthConstants.JUNE, 2002), 96.605);
        series1.add(new Day(5, MonthConstants.JUNE, 2002), 96.580);
        series1.add(new Day(6, MonthConstants.JUNE, 2002), 96.610);
        series1.add(new Day(7, MonthConstants.JUNE, 2002), 96.600);

        series1.add(new Day(10, MonthConstants.JUNE, 2002), 96.615);
        series1.add(new Day(11, MonthConstants.JUNE, 2002), 96.705);
        series1.add(new Day(12, MonthConstants.JUNE, 2002), 96.750);
        series1.add(new Day(13, MonthConstants.JUNE, 2002), 96.830);
        series1.add(new Day(14, MonthConstants.JUNE, 2002), 96.965);

        series1.add(new Day(17, MonthConstants.JUNE, 2002), 96.945);
        series1.add(new Day(18, MonthConstants.JUNE, 2002), 96.990);
        series1.add(new Day(19, MonthConstants.JUNE, 2002), 97.165);
        series1.add(new Day(20, MonthConstants.JUNE, 2002), 97.030);
        series1.add(new Day(21, MonthConstants.JUNE, 2002), 97.145);

        series1.add(new Day(24, MonthConstants.JUNE, 2002), 97.120);
        series1.add(new Day(25, MonthConstants.JUNE, 2002), 97.175);
        series1.add(new Day(26, MonthConstants.JUNE, 2002), 97.365);
        series1.add(new Day(27, MonthConstants.JUNE, 2002), 97.245);
        series1.add(new Day(28, MonthConstants.JUNE, 2002), 97.245);

        series1.add(new Day(1, MonthConstants.JULY, 2002), 97.290);
        series1.add(new Day(2, MonthConstants.JULY, 2002), 97.380);
        series1.add(new Day(3, MonthConstants.JULY, 2002), 97.380);

        series1.add(new Day(5, MonthConstants.JULY, 2002), 97.220);

        series1.add(new Day(8, MonthConstants.JULY, 2002), 97.325);
        series1.add(new Day(9, MonthConstants.JULY, 2002), 97.455);
        series1.add(new Day(10, MonthConstants.JULY, 2002), 97.580);
        series1.add(new Day(11, MonthConstants.JULY, 2002), 97.605);
        series1.add(new Day(12, MonthConstants.JULY, 2002), 97.690);

        series1.add(new Day(15, MonthConstants.JULY, 2002), 97.730);
        series1.add(new Day(16, MonthConstants.JULY, 2002), 97.580);
        series1.add(new Day(17, MonthConstants.JULY, 2002), 97.640);
        series1.add(new Day(18, MonthConstants.JULY, 2002), 97.680);
        series1.add(new Day(19, MonthConstants.JULY, 2002), 97.715);

        series1.add(new Day(22, MonthConstants.JULY, 2002), 97.815);
        series1.add(new Day(23, MonthConstants.JULY, 2002), 97.875);
        series1.add(new Day(24, MonthConstants.JULY, 2002), 97.835);
        series1.add(new Day(25, MonthConstants.JULY, 2002), 97.925);
        series1.add(new Day(26, MonthConstants.JULY, 2002), 97.960);

        series1.add(new Day(29, MonthConstants.JULY, 2002), 97.745);
        series1.add(new Day(30, MonthConstants.JULY, 2002), 97.710);
        series1.add(new Day(31, MonthConstants.JULY, 2002), 97.930);
        series1.add(new Day(1, MonthConstants.AUGUST, 2002), 98.000);
        series1.add(new Day(2, MonthConstants.AUGUST, 2002), 98.170);

        series1.add(new Day(5, MonthConstants.AUGUST, 2002), 98.225);
        series1.add(new Day(6, MonthConstants.AUGUST, 2002), 98.115);
        series1.add(new Day(7, MonthConstants.AUGUST, 2002), 98.265);
        series1.add(new Day(8, MonthConstants.AUGUST, 2002), 98.180);
        series1.add(new Day(9, MonthConstants.AUGUST, 2002), 98.185);

        series1.add(new Day(12, MonthConstants.AUGUST, 2002), 98.150);
        series1.add(new Day(13, MonthConstants.AUGUST, 2002), 98.290);
        series1.add(new Day(14, MonthConstants.AUGUST, 2002), 98.155);
        series1.add(new Day(15, MonthConstants.AUGUST, 2002), 98.075);
        series1.add(new Day(16, MonthConstants.AUGUST, 2002), 98.000);

        series1.add(new Day(19, MonthConstants.AUGUST, 2002), 98.040);
        series1.add(new Day(20, MonthConstants.AUGUST, 2002), 98.135);
        series1.add(new Day(21, MonthConstants.AUGUST, 2002), 98.110);
        series1.add(new Day(22, MonthConstants.AUGUST, 2002), 98.005);
        series1.add(new Day(23, MonthConstants.AUGUST, 2002), 98.055);

        series1.add(new Day(26, MonthConstants.AUGUST, 2002), 98.065);
        series1.add(new Day(27, MonthConstants.AUGUST, 2002), 97.980);
        series1.add(new Day(28, MonthConstants.AUGUST, 2002), 98.035);
        series1.add(new Day(29, MonthConstants.AUGUST, 2002), 98.095);
        series1.add(new Day(30, MonthConstants.AUGUST, 2002), 98.060);

        series1.add(new Day(3, MonthConstants.SEPTEMBER, 2002), 98.250);
        series1.add(new Day(4, MonthConstants.SEPTEMBER, 2002), 98.245);
        series1.add(new Day(5, MonthConstants.SEPTEMBER, 2002), 98.315);
        series1.add(new Day(6, MonthConstants.SEPTEMBER, 2002), 98.170);

        series1.add(new Day(9, MonthConstants.SEPTEMBER, 2002), 98.080);
        series1.add(new Day(10, MonthConstants.SEPTEMBER, 2002), 98.090);
        series1.add(new Day(11, MonthConstants.SEPTEMBER, 2002), 98.030);
        series1.add(new Day(12, MonthConstants.SEPTEMBER, 2002), 98.105);
        series1.add(new Day(13, MonthConstants.SEPTEMBER, 2002), 98.135);

        series1.add(new Day(16, MonthConstants.SEPTEMBER, 2002), 98.115);
        series1.add(new Day(17, MonthConstants.SEPTEMBER, 2002), 98.125);
        series1.add(new Day(18, MonthConstants.SEPTEMBER, 2002), 98.130);
        series1.add(new Day(19, MonthConstants.SEPTEMBER, 2002), 98.255);
        series1.add(new Day(20, MonthConstants.SEPTEMBER, 2002), 98.255);

        series1.add(new Day(23, MonthConstants.SEPTEMBER, 2002), 98.280);
        series1.add(new Day(24, MonthConstants.SEPTEMBER, 2002), 98.310);
        series1.add(new Day(25, MonthConstants.SEPTEMBER, 2002), 98.250);
        series1.add(new Day(26, MonthConstants.SEPTEMBER, 2002), 98.300);
        series1.add(new Day(27, MonthConstants.SEPTEMBER, 2002), 98.410);

        series1.add(new Day(30, MonthConstants.SEPTEMBER, 2002), 98.495);
        series1.add(new Day(1, MonthConstants.OCTOBER, 2002), 98.440);
        series1.add(new Day(2, MonthConstants.OCTOBER, 2002), 98.440);
        series1.add(new Day(3, MonthConstants.OCTOBER, 2002), 98.440);
        series1.add(new Day(4, MonthConstants.OCTOBER, 2002), 98.380);

        series1.add(new Day(7, MonthConstants.OCTOBER, 2002), 98.385);
        series1.add(new Day(8, MonthConstants.OCTOBER, 2002), 98.340);
        series1.add(new Day(9, MonthConstants.OCTOBER, 2002), 98.420);
        series1.add(new Day(10, MonthConstants.OCTOBER, 2002), 98.375);
        series1.add(new Day(11, MonthConstants.OCTOBER, 2002), 98.275);

        series1.add(new Day(14, MonthConstants.OCTOBER, 2002), 98.275);
        series1.add(new Day(15, MonthConstants.OCTOBER, 2002), 98.135);
        series1.add(new Day(16, MonthConstants.OCTOBER, 2002), 98.165);
        series1.add(new Day(17, MonthConstants.OCTOBER, 2002), 98.170);
        series1.add(new Day(18, MonthConstants.OCTOBER, 2002), 98.165);

        series1.add(new Day(21, MonthConstants.OCTOBER, 2002), 98.105);
        series1.add(new Day(22, MonthConstants.OCTOBER, 2002), 98.125);
        series1.add(new Day(23, MonthConstants.OCTOBER, 2002), 98.185);
        series1.add(new Day(24, MonthConstants.OCTOBER, 2002), 98.245);
        series1.add(new Day(25, MonthConstants.OCTOBER, 2002), 98.320);

        series1.add(new Day(28, MonthConstants.OCTOBER, 2002), 98.420);
        series1.add(new Day(29, MonthConstants.OCTOBER, 2002), 98.540);
        series1.add(new Day(30, MonthConstants.OCTOBER, 2002), 98.545);
        series1.add(new Day(31, MonthConstants.OCTOBER, 2002), 98.560);

        return new TimeSeriesCollection(series1);

    }

    /**
     * Creates a sample dataset.
     *
     * @return A sample dataset.
     */
    private IntervalXYDataset createVolumeDataset() {

        // create dataset 2...
        final TimeSeries series1 = new TimeSeries("Volume", Day.class);

        series1.add(new Day(2, MonthConstants.JANUARY, 2002), 41020);
        series1.add(new Day(3, MonthConstants.JANUARY, 2002), 45586);
        series1.add(new Day(4, MonthConstants.JANUARY, 2002), 81672);

        series1.add(new Day(7, MonthConstants.JANUARY, 2002), 81975);
        series1.add(new Day(8, MonthConstants.JANUARY, 2002), 79692);
        series1.add(new Day(9, MonthConstants.JANUARY, 2002), 53187);
        series1.add(new Day(10, MonthConstants.JANUARY, 2002), 87929);
        series1.add(new Day(11, MonthConstants.JANUARY, 2002), 107047);

        series1.add(new Day(14, MonthConstants.JANUARY, 2002), 86276);
        series1.add(new Day(15, MonthConstants.JANUARY, 2002), 79005);
        series1.add(new Day(16, MonthConstants.JANUARY, 2002), 80632);
        series1.add(new Day(17, MonthConstants.JANUARY, 2002), 88797);
        series1.add(new Day(18, MonthConstants.JANUARY, 2002), 57179);

        series1.add(new Day(22, MonthConstants.JANUARY, 2002), 36611);
        series1.add(new Day(23, MonthConstants.JANUARY, 2002), 57063);
        series1.add(new Day(24, MonthConstants.JANUARY, 2002), 101938);
        series1.add(new Day(25, MonthConstants.JANUARY, 2002), 87177);

        series1.add(new Day(28, MonthConstants.JANUARY, 2002), 39831);
        series1.add(new Day(29, MonthConstants.JANUARY, 2002), 67654);
        series1.add(new Day(30, MonthConstants.JANUARY, 2002), 81162);
        series1.add(new Day(31, MonthConstants.JANUARY, 2002), 64923);
        series1.add(new Day(1, MonthConstants.FEBRUARY, 2002), 73481);

        series1.add(new Day(4, MonthConstants.FEBRUARY, 2002), 54723);
        series1.add(new Day(5, MonthConstants.FEBRUARY, 2002), 76708);
        series1.add(new Day(6, MonthConstants.FEBRUARY, 2002), 81281);
        series1.add(new Day(7, MonthConstants.FEBRUARY, 2002), 66553);
        series1.add(new Day(8, MonthConstants.FEBRUARY, 2002), 53592);

        series1.add(new Day(11, MonthConstants.FEBRUARY, 2002), 29410);
        series1.add(new Day(12, MonthConstants.FEBRUARY, 2002), 60345);
        series1.add(new Day(13, MonthConstants.FEBRUARY, 2002), 67339);
        series1.add(new Day(14, MonthConstants.FEBRUARY, 2002), 40057);
        series1.add(new Day(15, MonthConstants.FEBRUARY, 2002), 67865);

        series1.add(new Day(19, MonthConstants.FEBRUARY, 2002), 58628);
        series1.add(new Day(20, MonthConstants.FEBRUARY, 2002), 52109);
        series1.add(new Day(21, MonthConstants.FEBRUARY, 2002), 50195);
        series1.add(new Day(22, MonthConstants.FEBRUARY, 2002), 47806);

        series1.add(new Day(25, MonthConstants.FEBRUARY, 2002), 31711);
        series1.add(new Day(26, MonthConstants.FEBRUARY, 2002), 88328);
        series1.add(new Day(27, MonthConstants.FEBRUARY, 2002), 95805);
        series1.add(new Day(28, MonthConstants.FEBRUARY, 2002), 84035);
        series1.add(new Day(1, MonthConstants.MARCH, 2002), 113584);

        series1.add(new Day(4, MonthConstants.MARCH, 2002), 71872);
        series1.add(new Day(5, MonthConstants.MARCH, 2002), 83016);
        series1.add(new Day(6, MonthConstants.MARCH, 2002), 62273);
        series1.add(new Day(7, MonthConstants.MARCH, 2002), 138508);
        series1.add(new Day(8, MonthConstants.MARCH, 2002), 139428);

        series1.add(new Day(11, MonthConstants.MARCH, 2002), 80232);
        series1.add(new Day(12, MonthConstants.MARCH, 2002), 75693);
        series1.add(new Day(13, MonthConstants.MARCH, 2002), 104068);
        series1.add(new Day(14, MonthConstants.MARCH, 2002), 72171);
        series1.add(new Day(15, MonthConstants.MARCH, 2002), 117262);

        series1.add(new Day(18, MonthConstants.MARCH, 2002), 66048);
        series1.add(new Day(19, MonthConstants.MARCH, 2002), 87079);
        series1.add(new Day(20, MonthConstants.MARCH, 2002), 116084);
        series1.add(new Day(21, MonthConstants.MARCH, 2002), 113206);
        series1.add(new Day(22, MonthConstants.MARCH, 2002), 68326);

        series1.add(new Day(25, MonthConstants.MARCH, 2002), 34340);
        series1.add(new Day(26, MonthConstants.MARCH, 2002), 104413);
        series1.add(new Day(27, MonthConstants.MARCH, 2002), 57277);
        series1.add(new Day(28, MonthConstants.MARCH, 2002), 69936);

        series1.add(new Day(1, MonthConstants.APRIL, 2002), 57282);
        series1.add(new Day(2, MonthConstants.APRIL, 2002), 74686);
        series1.add(new Day(3, MonthConstants.APRIL, 2002), 108601);
        series1.add(new Day(4, MonthConstants.APRIL, 2002), 123381);
        series1.add(new Day(5, MonthConstants.APRIL, 2002), 106691);

        series1.add(new Day(8, MonthConstants.APRIL, 2002), 118535);
        series1.add(new Day(9, MonthConstants.APRIL, 2002), 85577);
        series1.add(new Day(10, MonthConstants.APRIL, 2002), 75441);
        series1.add(new Day(11, MonthConstants.APRIL, 2002), 88845);
        series1.add(new Day(12, MonthConstants.APRIL, 2002), 137141);

        series1.add(new Day(15, MonthConstants.APRIL, 2002), 72518);
        series1.add(new Day(16, MonthConstants.APRIL, 2002), 122100);
        series1.add(new Day(17, MonthConstants.APRIL, 2002), 136419);
        series1.add(new Day(18, MonthConstants.APRIL, 2002), 141338);
        series1.add(new Day(19, MonthConstants.APRIL, 2002), 80274);

        series1.add(new Day(22, MonthConstants.APRIL, 2002), 40449);
        series1.add(new Day(23, MonthConstants.APRIL, 2002), 72292);
        series1.add(new Day(24, MonthConstants.APRIL, 2002), 110644);
        series1.add(new Day(25, MonthConstants.APRIL, 2002), 145142);
        series1.add(new Day(26, MonthConstants.APRIL, 2002), 139573);

        series1.add(new Day(29, MonthConstants.APRIL, 2002), 51509);
        series1.add(new Day(30, MonthConstants.APRIL, 2002), 105782);
        series1.add(new Day(1, MonthConstants.MAY, 2002), 170680);
        series1.add(new Day(2, MonthConstants.MAY, 2002), 140800);
        series1.add(new Day(3, MonthConstants.MAY, 2002), 170411);

        series1.add(new Day(6, MonthConstants.MAY, 2002), 46172);
        series1.add(new Day(7, MonthConstants.MAY, 2002), 137251);
        series1.add(new Day(8, MonthConstants.MAY, 2002), 220626);
        series1.add(new Day(9, MonthConstants.MAY, 2002), 175902);
        series1.add(new Day(10, MonthConstants.MAY, 2002), 128807);

        series1.add(new Day(13, MonthConstants.MAY, 2002), 78208);
        series1.add(new Day(14, MonthConstants.MAY, 2002), 212048);
        series1.add(new Day(15, MonthConstants.MAY, 2002), 145643);
        series1.add(new Day(16, MonthConstants.MAY, 2002), 121520);
        series1.add(new Day(17, MonthConstants.MAY, 2002), 147820);

        series1.add(new Day(20, MonthConstants.MAY, 2002), 75969);
        series1.add(new Day(21, MonthConstants.MAY, 2002), 118970);
        series1.add(new Day(22, MonthConstants.MAY, 2002), 131013);
        series1.add(new Day(23, MonthConstants.MAY, 2002), 141100);
        series1.add(new Day(24, MonthConstants.MAY, 2002), 63606);

        series1.add(new Day(28, MonthConstants.MAY, 2002), 78687);
        series1.add(new Day(29, MonthConstants.MAY, 2002), 86743);
        series1.add(new Day(30, MonthConstants.MAY, 2002), 164376);
        series1.add(new Day(31, MonthConstants.MAY, 2002), 150108);

        series1.add(new Day(3, MonthConstants.JUNE, 2002), 132363);
        series1.add(new Day(4, MonthConstants.JUNE, 2002), 144902);
        series1.add(new Day(5, MonthConstants.JUNE, 2002), 123834);
        series1.add(new Day(6, MonthConstants.JUNE, 2002), 125004);
        series1.add(new Day(7, MonthConstants.JUNE, 2002), 165049);

        series1.add(new Day(10, MonthConstants.JUNE, 2002), 88069);
        series1.add(new Day(11, MonthConstants.JUNE, 2002), 114146);
        series1.add(new Day(12, MonthConstants.JUNE, 2002), 149992);
        series1.add(new Day(13, MonthConstants.JUNE, 2002), 191261);
        series1.add(new Day(14, MonthConstants.JUNE, 2002), 207444);

        series1.add(new Day(17, MonthConstants.JUNE, 2002), 117081);
        series1.add(new Day(18, MonthConstants.JUNE, 2002), 135924);
        series1.add(new Day(19, MonthConstants.JUNE, 2002), 179654);
        series1.add(new Day(20, MonthConstants.JUNE, 2002), 260936);
        series1.add(new Day(21, MonthConstants.JUNE, 2002), 140283);

        series1.add(new Day(24, MonthConstants.JUNE, 2002), 199052);
        series1.add(new Day(25, MonthConstants.JUNE, 2002), 191804);
        series1.add(new Day(26, MonthConstants.JUNE, 2002), 384936);
        series1.add(new Day(27, MonthConstants.JUNE, 2002), 313065);
        series1.add(new Day(28, MonthConstants.JUNE, 2002), 169963);

        series1.add(new Day(1, MonthConstants.JULY, 2002), 109906);
        series1.add(new Day(2, MonthConstants.JULY, 2002), 140644);
        series1.add(new Day(3, MonthConstants.JULY, 2002), 150898);

        series1.add(new Day(5, MonthConstants.JULY, 2002), 181355);

        series1.add(new Day(8, MonthConstants.JULY, 2002), 155042);
        series1.add(new Day(9, MonthConstants.JULY, 2002), 204305);
        series1.add(new Day(10, MonthConstants.JULY, 2002), 300113);
        series1.add(new Day(11, MonthConstants.JULY, 2002), 338948);
        series1.add(new Day(12, MonthConstants.JULY, 2002), 281325);

        series1.add(new Day(15, MonthConstants.JULY, 2002), 256101);
        series1.add(new Day(16, MonthConstants.JULY, 2002), 348164);
        series1.add(new Day(17, MonthConstants.JULY, 2002), 242995);
        series1.add(new Day(18, MonthConstants.JULY, 2002), 200744);
        series1.add(new Day(19, MonthConstants.JULY, 2002), 181071);

        series1.add(new Day(22, MonthConstants.JULY, 2002), 163266);
        series1.add(new Day(23, MonthConstants.JULY, 2002), 188508);
        series1.add(new Day(24, MonthConstants.JULY, 2002), 308070);
        series1.add(new Day(25, MonthConstants.JULY, 2002), 230901);
        series1.add(new Day(26, MonthConstants.JULY, 2002), 162577);

        series1.add(new Day(29, MonthConstants.JULY, 2002), 216318);
        series1.add(new Day(30, MonthConstants.JULY, 2002), 280677);
        series1.add(new Day(31, MonthConstants.JULY, 2002), 260236);
        series1.add(new Day(1, MonthConstants.AUGUST, 2002), 242803);
        series1.add(new Day(2, MonthConstants.AUGUST, 2002), 298490);

        series1.add(new Day(5, MonthConstants.AUGUST, 2002), 182890);
        series1.add(new Day(6, MonthConstants.AUGUST, 2002), 232273);
        series1.add(new Day(7, MonthConstants.AUGUST, 2002), 253552);
        series1.add(new Day(8, MonthConstants.AUGUST, 2002), 165365);
        series1.add(new Day(9, MonthConstants.AUGUST, 2002), 160382);

        series1.add(new Day(12, MonthConstants.AUGUST, 2002), 118030);
        series1.add(new Day(13, MonthConstants.AUGUST, 2002), 208807);
        series1.add(new Day(14, MonthConstants.AUGUST, 2002), 231599);
        series1.add(new Day(15, MonthConstants.AUGUST, 2002), 343482);
        series1.add(new Day(16, MonthConstants.AUGUST, 2002), 186116);

        series1.add(new Day(19, MonthConstants.AUGUST, 2002), 96437);
        series1.add(new Day(20, MonthConstants.AUGUST, 2002), 151735);
        series1.add(new Day(21, MonthConstants.AUGUST, 2002), 167390);
        series1.add(new Day(22, MonthConstants.AUGUST, 2002), 127184);
        series1.add(new Day(23, MonthConstants.AUGUST, 2002), 80205);

        series1.add(new Day(26, MonthConstants.AUGUST, 2002), 79893);
        series1.add(new Day(27, MonthConstants.AUGUST, 2002), 201723);
        series1.add(new Day(28, MonthConstants.AUGUST, 2002), 114001);
        series1.add(new Day(29, MonthConstants.AUGUST, 2002), 188389);
        series1.add(new Day(30, MonthConstants.AUGUST, 2002), 162801);

        series1.add(new Day(3, MonthConstants.SEPTEMBER, 2002), 200951);
        series1.add(new Day(4, MonthConstants.SEPTEMBER, 2002), 129229);
        series1.add(new Day(5, MonthConstants.SEPTEMBER, 2002), 183348);
        series1.add(new Day(6, MonthConstants.SEPTEMBER, 2002), 216722);

        series1.add(new Day(9, MonthConstants.SEPTEMBER, 2002), 128575);
        series1.add(new Day(10, MonthConstants.SEPTEMBER, 2002), 224714);
        series1.add(new Day(11, MonthConstants.SEPTEMBER, 2002), 144224);
        series1.add(new Day(12, MonthConstants.SEPTEMBER, 2002), 195721);
        series1.add(new Day(13, MonthConstants.SEPTEMBER, 2002), 160724);

        series1.add(new Day(16, MonthConstants.SEPTEMBER, 2002), 65473);
        series1.add(new Day(17, MonthConstants.SEPTEMBER, 2002), 141274);
        series1.add(new Day(18, MonthConstants.SEPTEMBER, 2002), 115084);
        series1.add(new Day(19, MonthConstants.SEPTEMBER, 2002), 242106);
        series1.add(new Day(20, MonthConstants.SEPTEMBER, 2002), 130034);

        series1.add(new Day(23, MonthConstants.SEPTEMBER, 2002), 95215);
        series1.add(new Day(24, MonthConstants.SEPTEMBER, 2002), 229288);
        series1.add(new Day(25, MonthConstants.SEPTEMBER, 2002), 163672);
        series1.add(new Day(26, MonthConstants.SEPTEMBER, 2002), 193573);
        series1.add(new Day(27, MonthConstants.SEPTEMBER, 2002), 170741);

        series1.add(new Day(30, MonthConstants.SEPTEMBER, 2002), 199615);
        series1.add(new Day(1, MonthConstants.OCTOBER, 2002), 170771);
        series1.add(new Day(2, MonthConstants.OCTOBER, 2002), 138498);
        series1.add(new Day(3, MonthConstants.OCTOBER, 2002), 154774);
        series1.add(new Day(4, MonthConstants.OCTOBER, 2002), 287154);

        series1.add(new Day(7, MonthConstants.OCTOBER, 2002), 111762);
        series1.add(new Day(8, MonthConstants.OCTOBER, 2002), 172535);
        series1.add(new Day(9, MonthConstants.OCTOBER, 2002), 148339);
        series1.add(new Day(10, MonthConstants.OCTOBER, 2002), 178796);
        series1.add(new Day(11, MonthConstants.OCTOBER, 2002), 153499);

        series1.add(new Day(14, MonthConstants.OCTOBER, 2002), 4589);
        series1.add(new Day(15, MonthConstants.OCTOBER, 2002), 172088);
        series1.add(new Day(16, MonthConstants.OCTOBER, 2002), 151267);
        series1.add(new Day(17, MonthConstants.OCTOBER, 2002), 222680);
        series1.add(new Day(18, MonthConstants.OCTOBER, 2002), 127019);

        series1.add(new Day(21, MonthConstants.OCTOBER, 2002), 118226);
        series1.add(new Day(22, MonthConstants.OCTOBER, 2002), 183031);
        series1.add(new Day(23, MonthConstants.OCTOBER, 2002), 221005);
        series1.add(new Day(24, MonthConstants.OCTOBER, 2002), 121333);
        series1.add(new Day(25, MonthConstants.OCTOBER, 2002), 138179);

        series1.add(new Day(28, MonthConstants.OCTOBER, 2002), 162012);
        series1.add(new Day(29, MonthConstants.OCTOBER, 2002), 237355);
        series1.add(new Day(30, MonthConstants.OCTOBER, 2002), 161650);
        series1.add(new Day(31, MonthConstants.OCTOBER, 2002), 207569);

        return new TimeSeriesCollection(series1);

    }

    // ****************************************************************************
    // * JFREECHART DEVELOPER GUIDE                                               *
    // * The JFreeChart Developer Guide, written by David Gilbert, is available   *
    // * to purchase from Object Refinery Limited:                                *
    // *                                                                          *
    // * http://www.object-refinery.com/jfreechart/guide.html                     *
    // *                                                                          *
    // * Sales are used to provide funding for the JFreeChart project - please    * 
    // * support us so that we can continue developing free software.             *
    // ****************************************************************************

    /**
     * Starting point for the price/volume chart demo application.
     *
     * @param args  ignored.
     */
    public static void main(final String[] args) {

        final PriceVolumeDemo demo = new PriceVolumeDemo("Price Volume Chart Demo");
        demo.pack();
        RefineryUtilities.centerFrameOnScreen(demo);
        demo.setVisible(true);

    }

}