<?php
/** 
*   @file FilterResSimu.php
*   @brief  Simations Filter Manager 
*
*   
*   @version $Id: 
*/
  class SimuFileMgr 
  {
  	 protected $simXmlName, $simXml, $simRootEl, $simXP;
  	 public $centerID;
  	 
  	 function __construct($basePath,$centerID) 
  	 {
 	    $this->simXmlName = $basePath;
	    $this->simXml     = new DomDocument("1.0");
	    $this->simXml->load($this->simXmlName); 
	    $this->simRootEl  = $this->simXml->documentElement;
	    $this->simXP      = new domxpath($this->simXml);
	    $this->centerID   = $centerID;
  	 }
  
    function queryDatasets()
      {
	      return $this->simXP->query("//dataRoot/dataCenter/simulationModel/simulationRegion/runID/dataset");
      }

    function getDatasetFilterPath($dataset)
      {
	    $datasetID = $dataset->getAttribute('xml:id');
				    
	    $run = $dataset->parentNode;
	    $runID = $run->getAttribute('xml:id');
			      
	    $simReg = $run->parentNode;
	    $simRegID = $simReg->getAttribute('xml:id');

	    $model = $simReg->parentNode;
	    $modelID = $model->getAttribute('xml:id');
		    
	    $center = $model->parentNode;
	    $centerID = $center->getAttribute('xml:id');
	    
	    return $centerID.";".$modelID.";".$simRegID.";".$runID.";".$datasetID;
      }
  	 
    private function getRunFromDataset($dataset)
  	 {
	    $run        = $dataset->parentNode;
	    return $run;
  	 }
   	 
  	 function getReleaseDate($dataset)
  	 {
	    $run = $this->getRunFromDataset($dataset);
	    if (!run || !$run->hasAttribute('ReleaseDate'))

	      return '0';
		  return strtotime($run->getAttribute('ReleaseDate'));
  	 }

	 function getSimulatedRegion($dataset) {
	 
	    if (isset($dataset->parentNode))
	      $run = $dataset->parentNode;  
	    if (isset($run->parentNode)) {
	    if ($run->parentNode->hasAttribute('name'))
	      $simReg = $run->parentNode->getAttribute('name');
	    return $simReg;
	    }
	    else return false;
  	 }

	function getDatasetAttribute($dataset ,$attribute)
  	 {
	    $run = $this->getRunFromDataset($dataset);
	    if (!run || !$run->hasAttribute($attribute))

	      return '';
		  return $run->getAttribute($attribute);
  	 }
  }


  //Get filter result for all simulations bases
  class FilterResSimu extends FilterRes
  {
  	protected $arrayFilesMgr;
  	
  	function __construct() 
  	{
	    $this->arrayFilesMgr = array();
	    array_push($this->arrayFilesMgr,new SimuFileMgr(RemoteData."LATMOS/base.xml",'LATMOS'));
	    array_push($this->arrayFilesMgr,new SimuFileMgr(RemoteData."FMI_GUMICS/base.xml",'FMI_GUMICS'));
	    array_push($this->arrayFilesMgr,new SimuFileMgr(RemoteData."FMI_HYBRID/base.xml",'FMI_HYBRID'));
	    array_push($this->arrayFilesMgr,new SimuFileMgr(RemoteData."SINP/base.xml",'SINP'));
  	}
  	
	function getDataProd($value,$opId)
  	{
  		 $result = array();

  		 foreach ($this->arrayFilesMgr as $fileMgr){
  		 	 
  		   if ((($value == $fileMgr->centerID) && ($opId == 'eq')) || (($value != $fileMgr->centerID) && ($opId == 'ne')))
  		   {
  		     $datasets = $fileMgr->queryDatasets();
  		     foreach ($datasets as $dataset){ 
  		       array_push($result,$fileMgr->getDatasetFilterPath($dataset));
		      }
  		   }
  		  }
  		 return $result;
  	}
  	
  	function getReleaseDate($value,$opId)
  	{
  		 $result = array();
  		  
  		 $val  = strtotime($value);
  		   	 
  	  foreach ($this->arrayFilesMgr as $fileMgr)
  	  {
  		   $datasets = $fileMgr->queryDatasets();
  		   foreach ($datasets as $dataset)
  		   {
  		   	 $date = $fileMgr->getReleaseDate($dataset);
  		   	 if (($date == $val) || (($date < $val) && ($opId == 'le')) || (($date > $val) && ($opId == 'ge')))
  		       array_push($result,$fileMgr->getDatasetFilterPath($dataset));
  		   }
  		 }
  	  
  	  return $result;
  	}


  	function getSimuRegion($value,$opId) {
	  $result = array();
  		
  	  foreach ($this->arrayFilesMgr as $fileMgr) {
	      $datasets = $fileMgr->queryDatasets();
	      foreach ($datasets as $dataset)
	      {
		  if ($fileMgr->getSimulatedRegion($dataset)){
		    $isSimuRegion = ($fileMgr->getSimulatedRegion($dataset) == $value);
		    if (($isSimuRegion && ($opId == 'eq')) || (!$isSimuRegion && ($opId == 'ne')))
			array_push($result,$fileMgr->getDatasetFilterPath($dataset));
		  }
	      }
  	}
  	  
  	  return $result;

  	}

	  	
  	function getInfoFromRunIDEqual($value,$opId, $attribute)
  	{
  		 $result = array();
  		  
  	  foreach ($this->arrayFilesMgr as $fileMgr)
  	  {
  		   $datasets = $fileMgr->queryDatasets();
  		   foreach ($datasets as $dataset)
  		   {
  		   	 $isAttribute = ($fileMgr->getDatasetAttribute($dataset, $attribute) == $value);
  		   	 if (($isAttribute && ($opId == 'eq')) || (!$isAttribute && ($opId == 'ne')))
  		       array_push($result,$fileMgr->getDatasetFilterPath($dataset));
  		   }
  		 }
  	  
  	  return $result;
  	}

	function getInfoFromRunIDComp($value,$opId, $attribute)
  	{
  		 $result = array();
		 $val  = floatval($value); 
  		  
  	  foreach ($this->arrayFilesMgr as $fileMgr)
  	  {
  		   $datasets = $fileMgr->queryDatasets();
  		   foreach ($datasets as $dataset)
  		   {
  		   	 $attrVal = floatval($fileMgr->getDatasetAttribute($dataset, $attribute));
  		   	 if ((($attrVal == $val) || (($attrVal < $val) && ($opId == 'le')) || (($attrVal > $val) && ($opId == 'ge'))) && $attrVal != '')
  		       array_push($result,$fileMgr->getDatasetFilterPath($dataset));
  		   }
  		 }
  	  
  	  return $result;
  	}
  	
  	function getAll()
  	{
  		 
  	}
	
  	function getCondResult($cond)
  	{
  		$condId = $cond['condId'];
  		switch($condId)
  		{
  			case 'dprod' : //data productor
  				return $this->getDataProd($cond['value'],$cond['opId']);
  			case 'simt' : //simulation type
  				return $this->getInfoFromRunIDEqual($cond['value'],$cond['opId'], 'SimulationType');
  			case 'reld' : //release date
  				return $this->getReleaseDate($cond['value'],$cond['opId']);
  			case 'simReg' : //simulated region
  				return $this->getSimuRegion($cond['value'],$cond['opId']);
 			case 'tempDepend' : //Temporal Dependence
  				return $this->getInfoFromRunIDEqual($cond['value'],$cond['opId'], 'TemporalDependence');
 			case 'rating' : //Likelihood Rating
  				return $this->getInfoFromRunIDEqual($cond['value'],$cond['opId'], 'LikelihoodRating');
 			case 'GridCellSize_X' : //Likelihood Rating
  				return $this->getInfoFromRunIDComp($cond['value'],$cond['opId'], 'GridCellSize_X');
 			case 'GridCellSize_Y' : //Likelihood Rating
  				return $this->getInfoFromRunIDComp($cond['value'],$cond['opId'], 'GridCellSize_Y');
 			case 'GridCellSize_Z' : //Likelihood Rating
  				return $this->getInfoFromRunIDComp($cond['value'],$cond['opId'], 'GridCellSize_Z');
 			case 'FieldValue_Bx' : //Likelihood Rating
  				return $this->getInfoFromRunIDComp($cond['value'],$cond['opId'], 'FieldValue_Bx');
			case 'FieldValue_By' : //Likelihood Rating
  				return $this->getInfoFromRunIDComp($cond['value'],$cond['opId'], 'FieldValue_By');
			case 'FieldValue_Bz' : //Likelihood Rating
  				return $this->getInfoFromRunIDComp($cond['value'],$cond['opId'], 'FieldValue_Bz');
			case 'Solar_Wind_electrons-Density' : //Likelihood Rating
  				return $this->getInfoFromRunIDComp($cond['value'],$cond['opId'], 'Solar_Wind_electrons-Density');
			case 'Solar_Wind_electrons-Temperature' : //Likelihood Rating
  				return $this->getInfoFromRunIDComp($cond['value'],$cond['opId'], 'Solar_Wind_electrons-Temperature');
			case 'Solar_Wind_electrons-FlowSpeed' : //Likelihood Rating
  				return $this->getInfoFromRunIDComp($cond['value'],$cond['opId'], 'Solar_Wind_electrons-FlowSpeed');
			case 'Solar_Wind_H-Density' : //Likelihood Rating
  				return $this->getInfoFromRunIDComp($cond['value'],$cond['opId'], 'Solar_Wind_H-Density');
			case 'Solar_Wind_H-Temperature' : //Likelihood Rating
  				return $this->getInfoFromRunIDComp($cond['value'],$cond['opId'], 'Solar_Wind_H-Temperature');
			case 'Solar_Wind_H-FlowSpeed' : //Likelihood Rating
  				return $this->getInfoFromRunIDComp($cond['value'],$cond['opId'], 'Solar_Wind_H-FlowSpeed');
			case 'Solar_Wind_He-Density' : //Likelihood Rating
  				return $this->getInfoFromRunIDComp($cond['value'],$cond['opId'], 'Solar_Wind_He-Density');
			case 'Solar_Wind_He-Temperature' : //Likelihood Rating
  				return $this->getInfoFromRunIDComp($cond['value'],$cond['opId'], 'Solar_Wind_He-Temperature');
			case 'SolarUVFlux' : //Likelihood Rating
  				return $this->getInfoFromRunIDComp($cond['value'],$cond['opId'], 'SolarUVFlux');
		}
	}
	 	function getResult($filter,$isEmptyFilter)
  	{  		
 		 if ($isEmptyFilter)
  			return $this->getAll();
  		$ops = array();
  		for ($i = 0 ; $i < count($filter); $i++)
  		{     
  			$cond = $filter[$i];
  			$cond_res[$i] = $this->getCondResult($cond);
  			$ops[$i] = $cond['logical'];
  		}
  		
  		for ($i = 1; $i < count($cond_res); $i++)
  		{
  			if ($ops[$i] != 'and')
  				continue;
  			$cond_res[$i-1] = $this->andOp($cond_res[$i-1],$cond_res[$i]);
  			array_splice($cond_res, $i, 1);
  			array_splice($ops, $i, 1);
			$i--;		
  		}
  		
  		for ($i = 1; $i < count($cond_res); $i++)
  		{
  			if ($ops[$i] != 'or')
  				continue;
  			$cond_res[$i-1] = $this->orOp($cond_res[$i-1],$cond_res[$i]);
  			array_splice($cond_res, $i, 1);
  			array_splice($ops, $i, 1);
			$i--;			
  		}
  		return $cond_res[0];
  	}
  }
?>