"_", ":" => "_", "?" => "_", '+' => "_");
public $alongOrbit = true;
/*
* @brief init
*/
protected function getRemoteTree()
{
$this->tree = simplexml_load_file($this->url."/".$this->treeXML);
}
protected function setDataCenterAttributes()
{
$this->dataCenter->setAttribute('desc', $this->tree->Repository->ResourceHeader->Description.'
ReleaseDate: '.$this->tree->Repository->ResourceHeader->ReleaseDate);
$this->dataCenter->setAttribute('isSimulation', "true");
}
public function init() {}
// 1-st level : "Mission" : SimulationModel
protected function createMissionNodes()
{
$missionNodes = array();
foreach ($this->tree->SimulationModel as $sm)
{
$ResourceID = trim($sm->ResourceID);
$simulationModel = $this->domAmda->createElement('simulationModel');
$simulationModel->setAttribute('xml:id', $sm->ResourceID);
$simulationModel->setAttribute('name', $sm->ResourceHeader->ResourceName);
$simulationModel->setAttribute('desc', $sm->ResourceHeader->Description.'
ReleaseDate: '.$sm->ResourceHeader->ReleaseDate);
$this->setModelHelp($simulationModel,"");
if ($this->tree->SimulationRun->count() > 0)
{
$simulationRegionNodes = $this->createSimulationRegionNodes(trim($simulationModel->getAttribute('xml:id')));
foreach ( $simulationRegionNodes as $node )
$simulationModel->appendChild($node);
}
$missionNodes[] = $simulationModel;
}
return $missionNodes;
}
protected function setModelHelp($node, $helpFile){}
protected function setHelpAttribute($node, $helpFile)
{
$node->setAttribute('att', $helpFile);
}
// 2-nd level : SimulatedRegion of SimulationRun
protected function createSimulationRegionNodes($modelId)
{
if (file_exists(DATAPATH.'rank.json'))
$cmpArr = json_decode(file_get_contents(DATAPATH.'rank.json'), true);
else
$cmpArr = null;
$simRegions = array();
$simulationRegionNodes = array();
foreach($this->tree->SimulationRun as $sr)
{
if (trim($sr->Model->ModelID) == $modelId)
{
$simReg = trim($sr->SimulatedRegion);
if (! in_array($simReg, $simRegions))
{
$simRegions[] = $simReg;
// add SimReg to TargetsSimu.xml
$this->addSimulatedRegionToTargetsFile($simReg,
$sr->SimulationDomain->CoordinateSystem->CoordinateSystemName);
echo '$simRegions =>'.$sr->SimulatedRegion.PHP_EOL;
$simuRegion=$this->domAmda->createElement('simulationRegion');
$simuRegion->setAttribute('xml:id', $this->baseID.'_'.$simReg);
$simuRegion->setAttribute('name', $simReg);
if (is_array($cmpArr))
{
$target = explode('.',$simReg);
$index = $cmpArr[$target[0]];
if ($index)
$simuRegion->setAttribute('rank',$index);
else
$simuRegion->setAttribute('rank', 999);
}
$this->setHelpAttribute($simuRegion, "simu/simu$simReg");
$simulationRegionNodes[] = $simuRegion;
}
$runNode = $this->createSimulationRunNode($sr);
$this->setSimulationRunNodeDescription($runNode,$sr);
foreach ($simulationRegionNodes as $node)
{
if ($node->getAttribute('xml:id') == $this->baseID.'_'.$simReg)
{
$node->appendChild($runNode);
}
}
}
}
return $simulationRegionNodes;
}
// 3-rd level : SimulationRun
protected function createSimulationRunNode($sr)
{
//$idSimulationRun = $sr->ResourceID;
$runNode = $this->domAmda->createElement('runID');
$runNode->setAttribute('xml:id', $sr->ResourceID);
$runNode->setAttribute('name', $sr->ResourceHeader->ResourceName);
foreach ($this->tree->NumericalOutput as $no)
{
if (((trim($no->InputResourceID) == $sr->ResourceID) || (trim($no->SimulationRunID) == $sr->ResourceID))
&& ((trim($no->SimulationProduct) == "3DCubes") || (trim($no->SimulationProduct) == "Spectra")))
{
if (trim($no->SimulationProduct) == "Spectra")
$isSpectra = true;
else
$isSpectra = false;
$datasetNode = $this->createDatasetNode($no, $isSpectra);
$runNode->appendChild($datasetNode);
}
}
return $runNode;
}
// 4-th level : NumericalOutput (dataset)
protected function createDatasetNode($no, $isSpectra = false)
{
$dsNode = $this->domAmda->createElement('dataset');
$dsNode->setAttribute('xml:id', trim($no->ResourceID));
$dsName = $this->getDatasetName($no);
$dsNode->setAttribute('name', $dsName);
$paramNodes = $this->createParameterNodes($no->Parameter, trim($no->ResourceID), $isSpectra);
foreach ($paramNodes as $node)
{
$dsNode->appendChild($node);
}
// Special case of IPIM
if ($this->hasAccessUrl)
{
$dsNode->setAttribute('accessUrl', $this->getAccessUrl($no));
$dsNode->setAttribute('globalStart', $this->getStartTime($no));
$dsNode->setAttribute('globalStop', $this->getStopTime($no));
$dsNode->setAttribute('desc', 'TimeRange : '.$this->getStartTime($no)."-".$this->getStopTime($no));
}
else
{
$dsNode->setAttribute('globalStart', 'depending on mission');
}
return $dsNode;
}
protected function getDatasetName($no)
{
if (trim($no->ResourceHeader->ResourceName) != '')
return trim($no->ResourceHeader->ResourceName);
else
return trim($no->ResourceID);
}
protected function hasComponents($param)
{
if ($param->Particle->Qualifier)
{
return $param->Particle->Qualifier != "Scalar" && $param->Particle->Qualifier != "Total";
}
if ($param->Field->Qualifier)
{
return $param->Field->Qualifier != "Scalar" && $param->Field->Qualifier != "Total";
}
if (strpos(trim($param->ParameterKey), ',') === false)
$comps = explode(' ',trim($param->ParameterKey));
else
$comps = explode(',',trim($param->ParameterKey));
return count($comps) > 1;
}
// 5-th level : Parameters & Components
protected function createParameterNodes($params, $dsid, $isSpectra = false)
{
$paramNodes = array();
foreach ($params as $param)
{
$paramNode = $this->domAmda->createElement('parameter');
//$p = trim($sm->ResourceID).'/'.$argumentsParameterKey;
$id = $this->param2dd($dsid."/".$param->ParameterKey);
$paramNode->setAttribute('xml:id',$id);
$paramNode->setAttribute('name', $param->Name);
$paramNode->setAttribute('desc', 'Units: '.$param->Units);
$paramNode->setAttribute('needsArgs', $this->needsArgs);
$paramNode->setAttribute('units', $param->Units);
if (!$isSpectra)
{
if ($this->hasComponents($param))
{
if (strpos(trim($param->ParameterKey), ',') === false)
$comps = explode(' ',trim($param->ParameterKey));
else
$comps = explode(',',trim($param->ParameterKey));
$paramNode->setAttribute('size', count($comps));
foreach ($comps as $comp)
{
$compNode = $this->domAmda->createElement('component');
// $compNode->setAttribute('xml:id', $id."_".$comp);
$compNode->setAttribute('xml:id', $this->param2dd($dsid."_".$comp));
$compNode->setAttribute('name', $comp);
$compNode->setAttribute('shortName',$comp);
$compNode->setAttribute('needsArgs', $this->needsArgs);
$paramNode->appendChild($compNode);
}
}
$paramNode->setAttribute('shortName',$param->ParameterKey);
}
else
{
$paramNode->setAttribute('size', $this->getEnergyBinsNumber($param));
$paramNode->setAttribute('display_type', 'spectrogram');
$paramNode->setAttribute('isSpectra', true);
$paramNode->setAttribute('energyRange', 'EnergyRange'); // check if it allways so - should be ! SPASE
$paramNode->setAttribute('shortName','ParticleFlux');
$paramNode->setAttribute('energyUnits',$param->Particle->EnergyRange->Units);
}
$paramNodes[] = $paramNode;
}
return $paramNodes;
}
// EnergyBinsNumber
protected function getEnergyBinsNumber($param)
{
return count($param->Particle->EnergyRange->Bin);
}
// Run Description
protected function getCoordinateSystem($coordSystem)
{
return "Reference Frame :
".$coordSystem->CoordinateSystemName.",".$coordSystem->CoordinateRepresentation;
}
//
protected function getRegionBoundaries($domain, $region)
{
$simReg = explode(".", $region->SimulatedRegion);
$desc = "
Domain: Units: radius of ".$simReg[0]."
";
// Recalcul domain from km or m to rad
$unitsDomain = $domain->Units;
$spatialDimension = $domain->SpatialDimension;
$radius = $region->Radius;
$regionParameterRadius = trim($region->Radius['Units']);
$radiusUnits = trim($domain->Units);
$ValidMinsDom = preg_split ("/\s+/", $domain->ValidMin);
$ValidMaxsDom = preg_split ("/\s+/", $domain->ValidMax);
$coordLabel = preg_split ("/\s+/",$domain->CoordinatesLabel);
// Transform Simulation Domain to Martian radius from km & m
for($j=0; $j< $spatialDimension; $j++)
{
if ((strtolower($radiusUnits) == 'km') || (strtolower($radiusUnits)== 'm'))
{
if ($regionParameterRadius != $radiusUnits)
{
if (strtolower($radiusUnits) == 'km') $radius = ($region->Radius)/1000;
else $radius = ($region->Radius) * 1000;
}
$ValidMinsDom[$j] = number_format($ValidMinsDom[$j]/$radius,2);
$ValidMaxsDom[$j] = number_format($ValidMaxsDom[$j]/$radius,2);
}
$desc .= $coordLabel[$j]."=[".$ValidMinsDom[$j].', '.$ValidMaxsDom[$j]."]
";
}
return $desc;
}
protected function setSimulationRunNodeDescription($runNode,$sr)
{
}
protected function getProperties($sr)
{
}
protected function addSimulatedRegionToTargetsFile($simReg, $coordName)
{
$TargetsXml = new DomDocument("1.0");
$TargetsXml->formatOutput = TRUE;
$TargetsXml->preserveWhiteSpace = FALSE;
if (file_exists(SimuTargetsXml))
{
$TargetsXml->load(SimuTargetsXml);
$rootElement = $TargetsXml->documentElement;
}
else
{
$rootElement = $TargetsXml->createElement('Targets');
$TargetsXml->appendChild($rootElement);
}
$targetNode = $TargetsXml->getElementById($simReg);
if ($targetNode == null)
{
$simRegMain = explode(".",$simReg);
$targetNode = $TargetsXml->createElement("Target", $simReg);
$targetNode->setAttribute('CoordName',$coordName);
$targetNode->setAttribute('TargetMain',$simRegMain[0]);
$targetNode->setAttribute('xml:id',$simReg);
$targetNode->setAttribute($this->baseID,true);
$rootElement->appendChild($targetNode);
}
// add Simulation Data Center to existing target
else
{
$targetNode = $targetNode->setAttribute($this->baseID,true);
}
$TargetsXml->save(SimuTargetsXml);
}
public function getFileName($resourceID, $templateArgs, $start)
{
$fileName = strtr($resourceID, $this->impex_pairs);
foreach ($templateArgs as $key => $value)
$fileName .= "_".$value;
$fileName .= "_".$start.'.xml';
return $fileName;
}
public function getMask($resourceID, $templateArgs)
{
$fileMask = strtr($resourceID, $this->impex_pairs);
foreach ($templateArgs as $key => $value)
$fileMask .= "_".$value;
$fileMask .= '*.xml';
return $fileMask;
}
public function makeArgumentsList()
{
if (!file_exists(SimuTargetsXml))
exit('NOT YET!'.PHP_EOL);
if (file_exists($this->templateFile))
unlink($this->templateFile);
$TemplatesXml = new DomDocument("1.0");
$TemplatesXml->formatOutput = TRUE;
$TemplatesXml->preserveWhiteSpace = FALSE;
$rootNode = $TemplatesXml->createElement('paramTemplateList');
$TemplatesXml->appendChild($rootNode);
$TargetsXml = new DomDocument("1.0");
$TargetsXml->load(SimuTargetsXml);
$targets = $TargetsXml->getElementsByTagName('Target');
foreach ($targets as $target)
{
if ($target->hasAttribute($this->baseID))
{
echo $target->getAttribute('xml:id').PHP_EOL;
$paramNode = $TemplatesXml->createElement('paramTemplate');
$paramNode->setAttribute('paramId',$this->baseID."_".$this->param2dd($target->getAttribute('xml:id')));
$paramNode->setAttribute('fileName','##orbit##');
$argsNode = $TemplatesXml->createElement('arguments');
$paramNode->appendChild($argsNode);
$specialNodes = $this->createSpecialArgs($TemplatesXml);
foreach ($specialNodes as $specialNode)
$argsNode->appendChild($specialNode);
$missionGrps = json_decode(file_get_contents(RemoteData.$target->nodeValue.".json"), true);
$node = $TemplatesXml->createElement('argument');
$node->setAttribute('key', 'url_XYZ');
$node->setAttribute('name', 'Mission Name');
$node->setAttribute('type', 'list');
foreach ($missionGrps as $grp => $missions)
{
foreach ( $missions as $mission => $datasets)
{
echo 'MISSION: '.$mission.PHP_EOL;
foreach ($datasets as $dataset => $parameters)
{
echo " ".$dataset.PHP_EOL;
foreach ($parameters as $param => $value)
{
$item = $TemplatesXml->createElement('item');
$item->setAttribute('name', $mission);
$item->setAttribute('key', $value);
$node->appendChild($item);
}
}
}
}
//TODO select default s/c for each target
$node->setAttribute('default', $value);
$argsNode->appendChild($node);
$rootNode->appendChild($paramNode);
}
}
$TemplatesXml->save(RemoteData.$this->baseID.'/'.$this->templateFile);
}
protected function createSpecialArgs($dom)
{
return array();
}
public function getTableDefinition()
{
$res = array();
$res["tableDefType"] = "SELECT";
$res["channelsDefType"] = "BOUND";
$res["data"] = array();
$res["data"]["bound"] = $this->energyTableName;
return $res;
}
public function getData($params, $isSpectra = false)
{
// $r = print_r($params,true);
// error_log($r,3,'/home/budnik/LOG');
try
{
$client = new SoapClient($this->url."/".$this->WSDL,
array(
'wsdl_cache' => 0,
'trace' => 1,
'soap_version'=>SOAP_1_2
));
}
catch (SoapFault $exception)
{
throw new Exception($exception->getMessage()." ".$exception->getTraceAsString());
}
if ($isSpectra)
$soapMethod = $this->soapMethodSpectra;
else
$soapMethod = $this->soapMethod;
try
{
$file = $client->__soapCall($soapMethod, array($params));
}
catch (SoapFault $exception)
{
throw new Exception($exception->getMessage()." ".$exception->getTraceAsString());
}
return $file;
}
public function validateStartStop($fileName, $startTime, $stopTime)
{
return array("success" => true, "start" => $startTime, "stop" => $stopTime);
}
}
?>