This project has moved and is read-only. For the latest updates, please go here.

Device to Data in 5 Easy Steps

This guide is intended to aid you in getting data from your device as quickly and easily as possible. The steps are as follows:

  1. Create a project
  2. Add references
  3. Copy in the code snippet
  4. Set up your data source
  5. Run the application

Step 1: Create a project

The first thing you need to do is create a console application in Microsoft Visual Studio 2008. The following are detailed steps to guide you through the process.

  1. Launch Microsoft Visual Studio
  2. In the toolbar, go to "File > New > Project..."
  3. Under "Project Types", click on "Windows".
  4. Under "Templates", click on "Console Application".
  5. In the text box labeled "Name", enter the name of your application (i.e. "DeviceToData").
  6. Click the button labeled "Browse..." and select a directory to store the project.
  7. Click the "OK" button
  8. Right Click on your new project and select "Properties"
  9. In the Application settings, change the Target Framework to ".NET Framework 4"

Step 2: Add references

In order to get the code to run, you will need to add references to the openPDC assemblies. The following are detailed steps to guide you through the process.
Note: In order to complete this step, you will need to build openPDC.

  1. In your project's Solution Explorer on the right, right-click "References", select "Add Reference...", then click the Browse button
  2. Navigate to "SOURCEDIR\Main\Build\Output\Debug\Libraries" (SOURCEDIR is the directory where you extracted and built the openPDC source code files).
  3. Select "TVA.Communication.dll", "TVA.Core.dll", "TVA.PhasorProtocols.dll", and "TimeSeriesFramework.dll" then click the "OK" button

Step 3: Copy in the code snippet

Now you are ready to copy the source code that will interface with your device. Remove everything in Program.cs and replace it with the following code snippet.

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using TVA;
using TVA.PhasorProtocols;

namespace DeviceToData
    class Program
        static MultiProtocolFrameParser parser;
        static long frameCount;

        static void Main(string[] args)
            // Create a new protocol parser
            parser = new MultiProtocolFrameParser();

            // Attach to desired events
            parser.ConnectionAttempt += parser_ConnectionAttempt;
            parser.ConnectionEstablished += parser_ConnectionEstablished;
            parser.ConnectionException += parser_ConnectionException;
            parser.ParsingException += parser_ParsingException;
            parser.ReceivedConfigurationFrame += parser_ReceivedConfigurationFrame;
            parser.ReceivedDataFrame += parser_ReceivedDataFrame;

            // Define the connection string
            parser.ConnectionString =
                "phasorProtocol=Ieee1344; accessID=2; " +
                "transportProtocol=File; file=Sample1344.PmuCapture";
            // When connecting to a file based resource you may want to loop the data
            parser.AutoRepeatCapturedPlayback = true;

            // Start frame parser
            parser.AutoStartDataParsingSequence = true;

            // To keep the console open while receiving live data with AutoRepeatCapturedPlayback = false, uncomment the following line of code:
            // Console.ReadLine();

        static void parser_ReceivedDataFrame(object sender, EventArgs<IDataFrame> e)
            // Increase the frame count each time a frame is received

            // Print information each time we receive 60 frames (every 2 seconds for 30 frames per second)
            // Also check to assure the DataFrame has at least one Cell
            if ((frameCount % 60 == 0) && (e.Argument.Cells.Count > 0))
                IDataCell device = e.Argument.Cells[0];
                Console.WriteLine("Received {0} data frames so far...", frameCount);
                Console.WriteLine("    Last frequency: {0}Hz", device.FrequencyValue.Frequency);

                for (int x = 0; x < device.PhasorValues.Count; x++)
                    Console.WriteLine("PMU {0} Phasor {1} Angle = {2}", device.IDCode, x, device.PhasorValues[x].Angle);
                    Console.WriteLine("PMU {0} Phasor {1} Magnitude = {2}", device.IDCode, x, device.PhasorValues[x].Magnitude);

                Console.WriteLine("    Last Timestamp: {0}", ((DateTime)device.Timestamp).ToString("yyyy-MM-dd HH:mm:ss.fff"));

        static void parser_ReceivedConfigurationFrame(object sender, EventArgs<IConfigurationFrame> e)
            // Notify the user when a configuration frame is received
            Console.WriteLine("Received configuration frame with {0} device(s)", e.Argument.Cells.Count);

        static void parser_ParsingException(object sender, EventArgs<Exception> e)
            // Output the exception to the user
            Console.WriteLine("Parsing exception: {0}", e.Argument);

        static void parser_ConnectionException(object sender, EventArgs<Exception, int> e)
            // Display which connection attempt failed and the exception that occurred
            Console.WriteLine("Connection attempt {0} failed due to exception: {1}",
                e.Argument2, e.Argument1);

        static void parser_ConnectionEstablished(object sender, EventArgs e)
            // Notify the user when the connection is established
            Console.WriteLine("Initiating {0} {1} based connection...",

        static void parser_ConnectionAttempt(object sender, EventArgs e)
            // Let the user know we are attempting to connect
            Console.WriteLine("Attempting connection...");

Step 4: Set up your data source

This step will vary depending on your data source. Information on setting up the connection string can be found on the Getting Started page.

This example uses the sample data file in the PMU Connection Tester project.  Copy the "Sample1344.PmuCapture" file from PMU Connection Tester's "SOURCEDIR\Main\Source\Tools\PMUConnectionTester" to "PROJECTDIR\bin\Debug"

(SOURCEDIR is the directory where you extracted the PMU Connection Tester source code files, and PROJECTDIR is the directory where you stored your project in step 1).

Step 5: Run the application

If you followed all the other steps correctly, you should be able to run the project by pressing "F5" from within Microsoft Visual Studio. The result should look something like the example image below.


Last edited Jun 22, 2012 at 2:17 PM by alexfoglia, version 4


alexandrun Dec 4, 2012 at 2:47 PM 
I did everything exactly as described. As output, I only get the two first lines. I do not get "Received configuration frame with 1 device(s)". I think I am going crazy. Can you please help me with a piece of advice ? I have Microsoft Visual Studio 2010. Same code as in the code snippet. Same "Sample1344.PmuCapture". What could be different is that my references are located in: SOURCEDIR\Synchrophasor\Current Version\Build\Output\Debug\Libraries ... The path description in Step 2 of this tutorial: "SOURCEDIR\Main\Build\Output\Debug\Libraries" makes no sense to me.