get_OMNI_1H.cpp 2.62 KB
/////////////////
// CPP HEADERS //
/////////////////
#include <iostream>
#include <fstream>
#include <stdlib.h> 

////////////
/// DDLIB //
////////////
#include "DD.h"

////////////////
// NAMESPACES //
///////////////
using namespace std;

int main(int argc, char const *argv[])
{
	if (argc != 4)
	{
		cout << "[ERROR] Usage : ./get_OMNI_1H (data filename) (ddStart) (ddInterval)" << endl;
		exit(EXIT_FAILURE);
	}

	string dataFilename   = argv[1];
	string ddStart        = argv[2];
	string ddInterval     = argv[3];
	string plasmaVi       = "omni_hour_all";
	string timeParameter  = "Time";
	string DensParameter  = "N";
	string TempParameter  = "T";
	string VNormParameter = "V";
	string VLonParameter  = "Vlon";
	string VLatParameter  = "Vlat";
	string magParameter   = "B";
	
	ofstream plasmaFile(dataFilename.c_str(), ios::out); 

	int id = DD_SetVariable( const_cast<char*>( plasmaVi.c_str() ) );
	
	char *st = const_cast<char*>( ddStart.c_str() );
	
	int error = DD_SetTime(id, st);
	
	if (error < 0)
	{
		std::string ddSetTimeErr = "[ERROR] Bad time pointer init in DD_SetTime -> err value : " +  error;
		throw std::string(ddSetTimeErr);
	}

	// GET DATA
	char *params[7];
	
	params[0] = const_cast<char*>( timeParameter.c_str() );
	params[1] = const_cast<char*>( DensParameter.c_str() );
	params[2] = const_cast<char*>( TempParameter.c_str() );
	params[3] = const_cast<char*>( VNormParameter.c_str() );
	params[4] = const_cast<char*>( VLonParameter.c_str() );
	params[5] = const_cast<char*>( VLatParameter.c_str() );
	params[6] = const_cast<char*>( magParameter.c_str() );
	
	char *timeIntervall = const_cast<char*>( ddInterval.c_str() );
	
	DD_data_t *data;

	int status = 0;

	plasmaFile << "Time,Density,Temperature,V,Vlon,Vlat,Bx,By,Bz" << endl;

	do {

		status = DD_GetMultiData(id, 7, static_cast<char**>(params), timeIntervall, &data, 1);
		
		if (status < 0)
		{
			std::string ddGetDataErr = "[ERROR] Failed to get data -> status : " + status;
			throw std::string(ddGetDataErr);
		}
		

		for (int j = 0; j < data->VarNumber; ++j)
		{
			plasmaFile << static_cast<char*>(data[0].Variables[j]) << ","
			<< *(static_cast<float*>(data[1].Variables[j])) << ","
			<< *(static_cast<float*>(data[2].Variables[j])) << ","
			<< *(static_cast<float*>(data[3].Variables[j])) << ","
			<< *(static_cast<float*>(data[4].Variables[j])) << ","
			<< *(static_cast<float*>(data[5].Variables[j])) << ","
			<< static_cast<float*>(data[6].Variables[j])[0] << ","
			<< static_cast<float*>(data[6].Variables[j])[1] << ","
			<< static_cast<float*>(data[6].Variables[j])[2] << endl; 
		}


	} while (status == MOREDATA);
	
    DD_Close(id);

    plasmaFile.close();

	return 0;
}