MoochoPack : Framework for Large-Scale Optimization Algorithms Version of the Day
MoochoPack_EvalNewPointTailoredApproachOrthogonal_Step.hpp
00001 // @HEADER
00002 // ***********************************************************************
00003 // 
00004 // Moocho: Multi-functional Object-Oriented arCHitecture for Optimization
00005 //                  Copyright (2003) Sandia Corporation
00006 // 
00007 // Under terms of Contract DE-AC04-94AL85000, there is a non-exclusive
00008 // license for use of this work by or on behalf of the U.S. Government.
00009 // 
00010 // This library is free software; you can redistribute it and/or modify
00011 // it under the terms of the GNU Lesser General Public License as
00012 // published by the Free Software Foundation; either version 2.1 of the
00013 // License, or (at your option) any later version.
00014 //  
00015 // This library is distributed in the hope that it will be useful, but
00016 // WITHOUT ANY WARRANTY; without even the implied warranty of
00017 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
00018 // Lesser General Public License for more details.
00019 //  
00020 // You should have received a copy of the GNU Lesser General Public
00021 // License along with this library; if not, write to the Free Software
00022 // Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307
00023 // USA
00024 // Questions? Contact Roscoe A. Bartlett (rabartl@sandia.gov) 
00025 // 
00026 // ***********************************************************************
00027 // @HEADER
00028 
00029 #ifndef EVAL_NEW_POINT_TAILORED_APPROACH_ORTHOGONAL_STEP_H
00030 #define EVAL_NEW_POINT_TAILORED_APPROACH_ORTHOGONAL_STEP_H
00031 
00032 #include "MoochoPack_EvalNewPointTailoredApproach_Step.hpp"
00033 #include "Teuchos_StandardCompositionMacros.hpp"
00034 
00035 namespace MoochoPack {
00036 
00046 class EvalNewPointTailoredApproachOrthogonal_Step
00047   : public EvalNewPointTailoredApproach_Step
00048 {
00049 public:
00050 
00052   EvalNewPointTailoredApproachOrthogonal_Step(
00053     const deriv_tester_ptr_t                &deriv_tester
00054     ,const bounds_tester_ptr_t              &bounds_tester
00055     ,EFDDerivTesting                        fd_deriv_testing = FD_DEFAULT
00056     );
00057 
00058 protected:
00059 
00062 
00064   void uninitialize_Y_Uy(
00065     MatrixOp         *Y
00066     ,MatrixOp        *Uy
00067     );
00069   void calc_py_Y_Uy(
00070     const NLPDirect       &nlp
00071     ,const D_ptr_t        &D
00072     ,VectorMutable        *py
00073     ,MatrixOp             *Y
00074     ,MatrixOp             *Uy
00075     ,EJournalOutputLevel  olevel
00076     ,std::ostream         &out
00077     );
00079   void recalc_py(
00080     const MatrixOp           &D
00081     ,VectorMutable           *py
00082     ,EJournalOutputLevel     olevel
00083     ,std::ostream            &out
00084     );
00086   void print_calc_py_Y_Uy(
00087     std::ostream& out, const std::string& leading_str
00088     ) const;
00089 
00091 
00092 private:
00093 
00094   // ///////////////////////////////
00095   // Private types
00096 
00098   typedef Teuchos::RCP<MatrixSymOpNonsing>  S_ptr_t;
00099 
00100   // ///////////////////////////////
00101   // Private data members
00102 
00103   S_ptr_t   S_ptr_;
00104 
00105   // //////////////////////////////
00106   // Private member functions
00107 
00108   // not defined and not to be called
00109   EvalNewPointTailoredApproachOrthogonal_Step();
00110 
00111 };  // end class EvalNewPointTailoredApproachOrthogonal_Step
00112 
00113 } // end namespace MoochoPack 
00114 
00115 #endif  // EVAL_NEW_POINT_TAILORED_APPROACH_ORTHOGONAL_STEP_H
 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends