diff egglib/egglib-2.1.5/include/egglib-cpp/DataMatrix.hpp @ 9:98c37a5d67f4 draft

Uploaded
author dereeper
date Wed, 07 Feb 2018 22:08:47 -0500
parents 420b57c3c185
children
line wrap: on
line diff
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/egglib/egglib-2.1.5/include/egglib-cpp/DataMatrix.hpp	Wed Feb 07 22:08:47 2018 -0500
@@ -0,0 +1,219 @@
+/*
+    Copyright 2009-2010 Stéphane De Mita, Mathieu Siol
+
+    This file is part of the EggLib library.
+
+    EggLib is free software: you can redistribute it and/or modify
+    it under the terms of the GNU General Public License as published by
+    the Free Software Foundation, either version 3 of the License, or
+    (at your option) any later version.
+
+    EggLib is distributed in the hope that it will be useful,
+    but WITHOUT ANY WARRANTY; without even the implied warranty of
+    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
+    GNU General Public License for more details.
+
+    You should have received a copy of the GNU General Public License
+    along with EggLib.  If not, see <http://www.gnu.org/licenses/>.
+*/
+
+#ifndef EGGLIB_DATAMATRIX_HPP
+#define EGGLIB_DATAMATRIX_HPP
+
+
+#include "CharMatrix.hpp"
+
+
+namespace egglib {
+
+    /** \brief Data table
+    *
+    * \ingroup core
+    *
+    * Holds a data matrix representing genotype data from simulations.
+    * Data are stored as integers, to each site is associated a
+    * position, and to each sequence is associated a group index (any
+    * integer labelling, for example, a subpopulation). Supports the
+    * CharMatrix interface with the condition that allele genotype
+    * datum is >=0 and <=9.
+    * 
+    */
+    class DataMatrix : public CharMatrix {
+    
+    public:
+    
+        /** \brief Default constructor
+         *
+         * The data table default dimensions are {0,0}
+         *
+         */
+        DataMatrix();
+
+
+        /** \brief Standard constructor
+         *
+         * The data table dimensions must be given.
+         * Each cell default default is 0, and each site position is 0..
+         *
+         * \param numberOfSequences number of lines of the data table.
+         * \param numberOfSites number of columns of the data table.
+         *
+         */
+        DataMatrix(unsigned int numberOfSequences, unsigned int numberOfSites);
+
+
+        /** \brief Copy constructor
+         * 
+         */
+        DataMatrix(const DataMatrix&);
+
+
+        /** \brief Copy constructor
+         * 
+         */
+        DataMatrix(const CharMatrix&);
+
+        
+        /** \brief Assignment operator
+         * 
+         */
+        virtual DataMatrix& operator=(const DataMatrix&);
+        
+        
+        /** \brief Assignment operator
+         * 
+         */
+        virtual DataMatrix& operator=(const CharMatrix&);
+
+
+        /** \brief Destructor
+         * 
+         */
+        virtual ~DataMatrix();
+        
+        
+        /** \brief Gets number of sites
+         * 
+         */
+        unsigned int numberOfSites() const;
+
+
+        /** \brief Gets number of sequences
+         * 
+         */
+        unsigned int numberOfSequences() const;
+        
+        
+        /** \brief Sets a value of the data table
+         * 
+         */
+        void set(unsigned int sequence, unsigned int site, int value);
+
+
+        /** \brief Gets a value from the data table
+         * 
+         */
+        int get(unsigned int sequence, unsigned int site) const;
+        
+        
+        /** \brief Faster and unsecure version of get
+         * 
+         */
+        inline int fget(unsigned int sequence, unsigned int site) const {
+            return dataMatrix[sequence][site];
+        }
+
+
+        /** \brief Sets the position of a site
+         * 
+         */
+        void sitePosition(unsigned int site, double value);
+
+
+        /** \brief Gets the position of a site
+         * 
+         */
+        double sitePosition(unsigned int site) const;
+
+
+        /** \brief Sets the group label of a sequence
+         * 
+         */
+        void populationLabel(unsigned int sequence, unsigned int value);
+
+
+        /** \brief Gets the group label of a sequence
+         * 
+         */
+        unsigned int populationLabel(unsigned int sequence) const;
+
+
+        /** \brief Removes all information from the object
+         * 
+         */
+        void clear();
+
+
+        /** \brief Resizes the data matrix
+         *
+         * \param newNumberOfSequences number of sequences (rows)
+         * \param newNumberOfSites number of sites (columns)
+         *
+         * If new values are larger, data already set is left unchanged.
+         * New data are set to zero.
+         *
+         */
+        void resize(unsigned int newNumberOfSequences, unsigned int newNumberOfSites);
+
+
+       /** \brief Shifts allele value
+        * 
+        * \param minimum the minimum allele value.
+        * 
+        * Shifts all alleles at all sites to ensure that alleles alleles
+        * are equal to or larger than minimum. The shifting is specific
+        * to each site.
+        * 
+        */
+        void shift(int minimum);
+
+        /** \brief Gets the character at a given position
+         * 
+         * An exception is generated if the allele value at this
+         * position is not >=0 and <=9. Not out-of-bound check is
+         * performed.
+         * 
+         */
+        char character(unsigned int sequence, unsigned int site) const;
+        
+
+
+    private:
+        
+        // Initializes to default values (for empty object)
+        void init();
+        
+        // Copies from a source object
+        virtual void copy(const CharMatrix&);
+
+        // Copies from a source object
+        virtual void copy(const DataMatrix&);
+        
+        // Number of lines of the data matrix
+        unsigned int _numberOfSequences;
+        
+        // Number of columns of the data matrix
+        unsigned int _numberOfSites;
+        
+        // Data matrix
+        int **dataMatrix;
+        
+        // Vector of site positions
+        double *positions;
+        
+        // Vector of group indices
+        unsigned int *groups;
+    };
+}
+
+#endif