changeset 1452:6e9615bde1f9 streaming-csv-writer

For sparse models, write whole model to CSV in one go
author Chris Cannam <cannam@all-day-breakfast.com>
date Tue, 17 Apr 2018 10:37:50 +0100 (2018-04-17)
parents b40f67578976
children 4b496a258782
files base/Selection.h data/fileio/CSVFileWriter.cpp data/fileio/CSVFileWriter.h data/fileio/CSVStreamWriter.h data/model/Model.h data/model/SparseModel.h
diffstat 6 files changed, 32 insertions(+), 14 deletions(-) [+]
line wrap: on
line diff
--- a/base/Selection.h	Tue Apr 17 10:37:15 2018 +0100
+++ b/base/Selection.h	Tue Apr 17 10:37:50 2018 +0100
@@ -13,8 +13,8 @@
     COPYING included with this distribution for more information.
 */
 
-#ifndef _SELECTION_H_
-#define _SELECTION_H_
+#ifndef SV_SELECTION_H
+#define SV_SELECTION_H
 
 #include <cstddef>
 #include <set>
--- a/data/fileio/CSVFileWriter.cpp	Tue Apr 17 10:37:15 2018 +0100
+++ b/data/fileio/CSVFileWriter.cpp	Tue Apr 17 10:37:50 2018 +0100
@@ -67,11 +67,11 @@
     };
     MultiSelection selections;
     selections.addSelection(all);
-    writeSelection(&selections); 
+    writeSelection(selections); 
 }
 
 void
-CSVFileWriter::writeSelection(MultiSelection *selection)
+CSVFileWriter::writeSelection(MultiSelection selection)
 {
     try {
         TempWriteFile temp(m_path);
@@ -85,13 +85,24 @@
     
         QTextStream out(&file);
 
+        sv_frame_t blockSize = 65536;
+
+        if (m_model->isSparse()) {
+            // Write the whole in one go, as re-seeking for each block
+            // may be very costly otherwise
+            sv_frame_t startFrame, endFrame;
+            selection.getExtents(startFrame, endFrame);
+            blockSize = endFrame - startFrame;
+        }
+        
         bool completed = CSVStreamWriter::writeInChunks(
             out,
             *m_model,
-            *selection,
+            selection,
             m_reporter,
             m_delimiter,
-            m_options
+            m_options,
+            blockSize
         );
 
         file.close();
--- a/data/fileio/CSVFileWriter.h	Tue Apr 17 10:37:15 2018 +0100
+++ b/data/fileio/CSVFileWriter.h	Tue Apr 17 10:37:50 2018 +0100
@@ -13,8 +13,8 @@
     COPYING included with this distribution for more information.
 */
 
-#ifndef _CSV_FILE_WRITER_H_
-#define _CSV_FILE_WRITER_H_
+#ifndef SV_CSV_FILE_WRITER_H
+#define SV_CSV_FILE_WRITER_H
 
 #include <QObject>
 #include <QString>
@@ -50,7 +50,7 @@
     virtual QString getError() const;
 
     virtual void write();
-    virtual void writeSelection(MultiSelection *selection);
+    virtual void writeSelection(MultiSelection selection);
 
 protected:
     QString m_path;
--- a/data/fileio/CSVStreamWriter.h	Tue Apr 17 10:37:15 2018 +0100
+++ b/data/fileio/CSVStreamWriter.h	Tue Apr 17 10:37:50 2018 +0100
@@ -13,8 +13,8 @@
     COPYING included with this distribution for more information.
 */
 
-#ifndef CSV_STREAM_WRITER_H
-#define CSV_STREAM_WRITER_H
+#ifndef SV_CSV_STREAM_WRITER_H
+#define SV_CSV_STREAM_WRITER_H
 
 #include "base/BaseTypes.h"
 #include "base/Selection.h"
@@ -146,4 +146,4 @@
     );
 }
 } // namespace CSVStreamWriter
-#endif
\ No newline at end of file
+#endif
--- a/data/model/Model.h	Tue Apr 17 10:37:15 2018 +0100
+++ b/data/model/Model.h	Tue Apr 17 10:37:50 2018 +0100
@@ -95,6 +95,11 @@
     virtual QString getTypeName() const = 0;
 
     /**
+     * Return true if this is a sparse model.
+     */
+    virtual bool isSparse() const { return false; }
+    
+    /**
      * Mark the model as abandoning. This means that the application
      * no longer needs it, so it can stop doing any background
      * calculations it may be involved in. Note that as far as the
--- a/data/model/SparseModel.h	Tue Apr 17 10:37:15 2018 +0100
+++ b/data/model/SparseModel.h	Tue Apr 17 10:37:50 2018 +0100
@@ -13,8 +13,8 @@
     COPYING included with this distribution for more information.
 */
 
-#ifndef _SPARSE_MODEL_H_
-#define _SPARSE_MODEL_H_
+#ifndef SV_SPARSE_MODEL_H
+#define SV_SPARSE_MODEL_H
 
 #include "Model.h"
 #include "TabularModel.h"
@@ -145,6 +145,8 @@
 
     virtual bool hasTextLabels() const { return m_hasTextLabels; }
 
+    virtual bool isSparse() const { return true; }
+
     QString getTypeName() const { return tr("Sparse"); }
 
     virtual QString getXmlOutputType() const { return "sparse"; }