| /**************************************************************************** |
| ** |
| ** Copyright (C) 2016 The Qt Company Ltd. |
| ** Contact: https://www.qt.io/licensing/ |
| ** |
| ** This file is part of the Qt Charts module of the Qt Toolkit. |
| ** |
| ** $QT_BEGIN_LICENSE:GPL$ |
| ** Commercial License Usage |
| ** Licensees holding valid commercial Qt licenses may use this file in |
| ** accordance with the commercial license agreement provided with the |
| ** Software or, alternatively, in accordance with the terms contained in |
| ** a written agreement between you and The Qt Company. For licensing terms |
| ** and conditions see https://www.qt.io/terms-conditions. For further |
| ** information use the contact form at https://www.qt.io/contact-us. |
| ** |
| ** GNU General Public License Usage |
| ** Alternatively, this file may be used under the terms of the GNU |
| ** General Public License version 3 or (at your option) any later version |
| ** approved by the KDE Free Qt Foundation. The licenses are as published by |
| ** the Free Software Foundation and appearing in the file LICENSE.GPL3 |
| ** included in the packaging of this file. Please review the following |
| ** information to ensure the GNU General Public License requirements will |
| ** be met: https://www.gnu.org/licenses/gpl-3.0.html. |
| ** |
| ** $QT_END_LICENSE$ |
| ** |
| ****************************************************************************/ |
| |
| #include "boxdatareader.h" |
| |
| #include <algorithm> |
| |
| BoxDataReader::BoxDataReader(QIODevice *device) : |
| QTextStream(device) |
| { |
| } |
| |
| void BoxDataReader::readFile(QIODevice *device) |
| { |
| QTextStream::setDevice(device); |
| } |
| |
| QBoxSet *BoxDataReader::readBox() |
| { |
| //! [1] |
| QString line = readLine(); |
| if (line.startsWith("#")) |
| return 0; |
| //! [1] |
| |
| //! [2] |
| QStringList strList = line.split(" ", QString::SkipEmptyParts); |
| //! [2] |
| |
| //! [3] |
| sortedList.clear(); |
| for (int i = 1; i < strList.count(); i++) |
| sortedList.append(strList.at(i).toDouble()); |
| |
| std::sort(sortedList.begin(), sortedList.end()); |
| //! [3] |
| |
| int count = sortedList.count(); |
| |
| //! [4] |
| QBoxSet *box = new QBoxSet(strList.first()); |
| box->setValue(QBoxSet::LowerExtreme, sortedList.first()); |
| box->setValue(QBoxSet::UpperExtreme, sortedList.last()); |
| box->setValue(QBoxSet::Median, findMedian(0, count)); |
| box->setValue(QBoxSet::LowerQuartile, findMedian(0, count / 2)); |
| box->setValue(QBoxSet::UpperQuartile, findMedian(count / 2 + (count % 2), count)); |
| //! [4] |
| |
| return box; |
| } |
| |
| qreal BoxDataReader::findMedian(int begin, int end) |
| { |
| //! [5] |
| int count = end - begin; |
| if (count % 2) { |
| return sortedList.at(count / 2 + begin); |
| } else { |
| qreal right = sortedList.at(count / 2 + begin); |
| qreal left = sortedList.at(count / 2 - 1 + begin); |
| return (right + left) / 2.0; |
| } |
| //! [5] |
| } |