MASA-Core
CPUBlockProcessor.hpp
Go to the documentation of this file.
00001 /*******************************************************************************
00002  *
00003  * Copyright (c) 2010-2015   Edans Sandes
00004  *
00005  * This file is part of MASA-Core.
00006  * 
00007  * MASA-Core is free software: you can redistribute it and/or modify
00008  * it under the terms of the GNU General Public License as published by
00009  * the Free Software Foundation, either version 3 of the License, or
00010  * (at your option) any later version.
00011  * 
00012  * MASA-Core is distributed in the hope that it will be useful,
00013  * but WITHOUT ANY WARRANTY; without even the implied warranty of
00014  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
00015  * GNU General Public License for more details.
00016  * 
00017  * You should have received a copy of the GNU General Public License
00018  * along with MASA-Core.  If not, see <http://www.gnu.org/licenses/>.
00019  *
00020  ******************************************************************************/
00021 
00022 #ifndef CPUBLOCKPROCESSOR_HPP_
00023 #define CPUBLOCKPROCESSOR_HPP_
00024 
00025 #include "AbstractBlockProcessor.hpp"
00026 #include "../libmasa.hpp"
00027 
00028 /*
00029  * The score constants
00030  */
00031 #define DNA_MATCH       (1)
00032 #define DNA_MISMATCH    (-3)
00033 #define DNA_GAP_EXT     (2)
00034 #define DNA_GAP_OPEN    (3)
00035 #define DNA_GAP_FIRST   (DNA_GAP_EXT+DNA_GAP_OPEN)
00036 
00037 
00038 
00039 class CPUBlockProcessor: public AbstractBlockProcessor {
00040 public:
00041 
00042         CPUBlockProcessor();
00043         virtual ~CPUBlockProcessor();
00044 
00045         virtual void setSequences(const char* seq0, const char* seq1, int seq0_len, int seq1_len);
00046         virtual void unsetSequences();
00047         virtual score_t processBlock(cell_t *row, cell_t *col, const int i0, const int j0, const int i1, const int j1, const int recurrenceType);
00048 
00049 private:
00050         const char *seq0;
00051         const char *seq1;
00052 };
00053 
00054 #endif /* CPUBLOCKPROCESSOR_HPP_ */