From 5e8b7cecd81e40ce23c48cb302fc8fe2df3a5439 Mon Sep 17 00:00:00 2001
From: Gagik Vardanyan <vardanyan@ill.fr>
Date: Wed, 6 Dec 2017 13:23:22 +0100
Subject: [PATCH] Re #19880 progress reporting, use LoadAndMerge

---
 .../plugins/algorithms/LoadAndMerge.py        | 11 +++-
 .../PowderDiffILLReduction.py                 | 51 +++++--------------
 2 files changed, 21 insertions(+), 41 deletions(-)

diff --git a/Framework/PythonInterface/plugins/algorithms/LoadAndMerge.py b/Framework/PythonInterface/plugins/algorithms/LoadAndMerge.py
index 0b92d71dd29..26ccd1fceb7 100644
--- a/Framework/PythonInterface/plugins/algorithms/LoadAndMerge.py
+++ b/Framework/PythonInterface/plugins/algorithms/LoadAndMerge.py
@@ -3,7 +3,7 @@ from __future__ import (absolute_import, division, print_function)
 import os.path
 from mantid.kernel import Direction, StringContainsValidator, PropertyManagerProperty
 from mantid.api import AlgorithmFactory, AlgorithmManager, MultipleFileProperty, \
-    WorkspaceProperty, PythonAlgorithm, FileLoaderRegistry
+    WorkspaceProperty, PythonAlgorithm, FileLoaderRegistry, Progress
 from mantid.simpleapi import MergeRuns, RenameWorkspace, DeleteWorkspace, GroupWorkspaces, mtd
 
 
@@ -13,6 +13,7 @@ class LoadAndMerge(PythonAlgorithm):
     _version = None
     _loader_options = None
     _prefix = ''
+    _progress = None
 
     def name(self):
         return "LoadMergeRuns"
@@ -55,6 +56,7 @@ class LoadAndMerge(PythonAlgorithm):
             @param run : the full file path
             @param runnumber : the run number
         """
+        self._progress.report('Loading '+runnumber)
         alg = self._create_fresh_loader()
         alg.setPropertyValue('Filename', run)
         alg.setPropertyValue('OutputWorkspace', runnumber)
@@ -74,7 +76,9 @@ class LoadAndMerge(PythonAlgorithm):
         # having an additional optional output workspace, but without requesting the optional output,
         # it will still be produced with some hidden temporary name (__TMPx...).
         # This is related to replaying the history, or might as well be a bug in Algorithm base class.
-        alg = AlgorithmManager.create(self._loader, self._version)
+        # alg = AlgorithmManager.create(self._loader, self._version)
+        alg = self.createChildAlgorithm(self._loader, self._version)
+        alg.setAlwaysStoreInADS(True)
         alg.initialize()
         for key in self._loader_options.keys():
             alg.setPropertyValue(key, self._loader_options.getPropertyValue(key))
@@ -82,6 +86,9 @@ class LoadAndMerge(PythonAlgorithm):
 
     def PyExec(self):
         runs = self.getProperty('Filename').value
+        runs_as_str = self.getPropertyValue('Filename')
+        number_runs = runs_as_str.count(',') + runs_as_str.count('+') + 1
+        self._progress = Progress(self, start=0.0, end=1.0, nreports=number_runs)
         self._loader = self.getPropertyValue('LoaderName')
         self._version = self.getProperty('LoaderVersion').value
         self._loader_options = self.getProperty('LoaderOptions').value
diff --git a/Framework/PythonInterface/plugins/algorithms/WorkflowAlgorithms/PowderDiffILLReduction.py b/Framework/PythonInterface/plugins/algorithms/WorkflowAlgorithms/PowderDiffILLReduction.py
index 09cb1495e15..34ae3fca03d 100644
--- a/Framework/PythonInterface/plugins/algorithms/WorkflowAlgorithms/PowderDiffILLReduction.py
+++ b/Framework/PythonInterface/plugins/algorithms/WorkflowAlgorithms/PowderDiffILLReduction.py
@@ -103,17 +103,23 @@ class PowderDiffILLReduction(PythonAlgorithm):
 
     def PyExec(self):
 
+        self._progress = Progress(self, start=0.0, end=1.0, nreports=4)
+
         self._configure()
         temp_ws = self._hide('temp')
         joined_ws = self._hide('joined')
         mon_ws = self._hide('mon')
-        to_group = self._load()
-        GroupWorkspaces(InputWorkspaces=to_group, OutputWorkspace=temp_ws)
 
+        self._progress.report('Loading the data')
+        LoadAndMerge(Filename=self.getPropertyValue('Run'),
+                     LoaderName='LoadILLDiffraction',
+                     OutputWorkspace=temp_ws)
+
+        self._progress.report('Normalising and merging')
         if self._normalise_option == 'Time':
-            for ws in to_group:
+            for ws in mtd[temp_ws]:
                 # normalise to time here, before joining, since the duration is in sample logs
-                duration = mtd[ws].getRun().getLogData('duration').value
+                duration = ws.getRun().getLogData('duration').value
                 Scale(InputWorkspace=ws,OutputWorkspace=ws,Factor=1./duration)
 
         try:
@@ -132,6 +138,7 @@ class PowderDiffILLReduction(PythonAlgorithm):
 
         DeleteWorkspace(mon_ws)
 
+        self._progress.report('Applying calibration or ROC if needed')
         if self._calibration_file:
             calib_ws = self._hide('calib')
             LoadNexusProcessed(Filename=self._calibration_file, OutputWorkspace=calib_ws)
@@ -157,6 +164,7 @@ class PowderDiffILLReduction(PythonAlgorithm):
             self.log().information('First positive 2theta at workspace index: ' + str(first_positive_theta))
             CropWorkspace(InputWorkspace=joined_ws, OutputWorkspace=joined_ws, StartWorkspaceIndex=first_positive_theta)
 
+        self._progress.report('Treating the zero counting cells')
         self._find_zero_cells(joined_ws)
 
         if self._zero_counting_option == 'Crop':
@@ -179,41 +187,6 @@ class PowderDiffILLReduction(PythonAlgorithm):
         RenameWorkspace(InputWorkspace=joined_ws, OutputWorkspace=self._out_name)
         self.setProperty('OutputWorkspace', self._out_name)
 
-    def _load(self):
-        """
-            Loads the list of runs
-            If sum is requested, MergeRuns is called
-            @return : the list of the loaded ws names
-        """
-        runs = self.getPropertyValue('Run')
-        to_group = []
-        self._progress = Progress(self, start=0.0, end=1.0, nreports=runs.count(',') + runs.count('+') + 1)
-
-        for runs_list in runs.split(','):
-            runs_sum = runs_list.split('+')
-            if len(runs_sum) == 1:
-                runnumber = os.path.basename(runs_sum[0]).split('.')[0]
-                run = self._hide_run(runnumber)
-                LoadILLDiffraction(Filename=runs_sum[0], OutputWorkspace=run)
-                self._progress.report('Loaded run #' + runnumber)
-                to_group.append(run)
-            else:
-                for i, run in enumerate(runs_sum):
-                    runnumber = os.path.basename(run).split('.')[0]
-                    if i == 0:
-                        first = self._hide_run(runnumber + '_multiple')
-                        LoadILLDiffraction(Filename=run, OutputWorkspace=first)
-                        self._progress.report('Loaded run #' + runnumber)
-                        to_group.append(first)
-                    else:
-                        run = self._hide_run(runnumber)
-                        LoadILLDiffraction(Filename=run, OutputWorkspace=run)
-                        self._progress.report('Loaded run #' + runnumber)
-                        MergeRuns(InputWorkspaces=[first, run], OutputWorkspace=first)
-                        DeleteWorkspace(Workspace=run)
-
-        return to_group
-
     def _configure(self):
         """
             Configures the input properties
-- 
GitLab