00001 /************************************************************************* 00002 * 00003 * The Contents of this file are made available subject to 00004 * the terms of GNU Lesser General Public License Version 2.1. 00005 * 00006 * 00007 * GNU Lesser General Public License Version 2.1 00008 * ============================================= 00009 * Copyright 2005 by Kohei Yoshida. 00010 * 1039 Kingsway Dr., Apex, NC 27502, USA 00011 * 00012 * This library is free software; you can redistribute it and/or 00013 * modify it under the terms of the GNU Lesser General Public 00014 * License version 2.1, as published by the Free Software Foundation. 00015 * 00016 * This library is distributed in the hope that it will be useful, 00017 * but WITHOUT ANY WARRANTY; without even the implied warranty of 00018 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU 00019 * Lesser General Public License for more details. 00020 * 00021 * You should have received a copy of the GNU Lesser General Public 00022 * License along with this library; if not, write to the Free Software 00023 * Foundation, Inc., 59 Temple Place, Suite 330, Boston, 00024 * MA 02111-1307 USA 00025 * 00026 ************************************************************************/ 00027 00028 00029 #ifndef _LPSIMPLEX_HXX_ 00030 #define _LPSIMPLEX_HXX_ 00031 00032 #include "lpbase.hxx" 00033 #include <memory> 00034 00035 namespace scsolver { namespace numeric { namespace lp { 00036 00037 class Model; 00038 class RevisedSimplexImpl; 00039 class BoundedRevisedSimplexImpl; 00040 00041 class RevisedSimplex : public BaseAlgorithm 00042 { 00043 public: 00044 RevisedSimplex(); 00045 virtual ~RevisedSimplex() throw(); 00046 00047 virtual void solve(); 00048 00049 void setEnableTwoPhaseSearch( bool ); 00050 00051 private: 00052 std::auto_ptr<RevisedSimplexImpl> m_pImpl; 00053 }; 00054 00055 00056 class BoundedRevisedSimplex : public BaseAlgorithm 00057 { 00058 public: 00059 BoundedRevisedSimplex(); 00060 virtual ~BoundedRevisedSimplex() throw(); 00061 00062 virtual void solve(); 00063 00064 private: 00065 std::auto_ptr<BoundedRevisedSimplexImpl> m_pImpl; 00066 }; 00067 00068 00069 }}} 00070 00071 00072 #endif
1.5.3