POptimize.h

Go to the documentation of this file.
00001 /*
00002     LoopTK: Protein Loop Kinematic Toolkit
00003     Copyright (C) 2007 Stanford University
00004 
00005     This program is free software; you can redistribute it and/or modify
00006     it under the terms of the GNU General Public License as published by
00007     the Free Software Foundation; either version 2 of the License, or
00008     (at your option) any later version.
00009 
00010     This program is distributed in the hope that it will be useful,
00011     but WITHOUT ANY WARRANTY; without even the implied warranty of
00012     MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
00013     GNU General Public License for more details.
00014 
00015     You should have received a copy of the GNU General Public License along
00016     with this program; if not, write to the Free Software Foundation, Inc.,
00017     51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
00018 */
00019 
00020 #ifndef POPTIMIZE_H
00021 #define POPTIMIZE_H
00022 
00023 #include "PIKAlgorithms.h"
00024 #include "PConstants.h"
00025 #include "PExtension.h"
00026 #include "PBasic.h"
00027 
00028 #define  pi 3.14159265
00029 #define deg2rad pi/180.0e0
00030 #define rad2deg 180.0e0/pi
00031 
00037 struct OptimalSol {
00038   vector<IKSolutions> LoopSol;
00039   vector<double> NonLoopSol;
00040 };
00041 
00042 class POptimize{
00043  public:
00050         POptimize(vector<PProtein*> loops, vector< vector<CDof> > Dofs);
00051    
00057         OptimalSol OptimizeNullSpace(FunctFunctor *FunctToOptimize);
00058 
00064         OptimalSol Optimize(FunctFunctor *FunctToOptimize, DerivFunctor *DerivOfFunct);
00070         OptimalSol OptimizeNullSpace(FunctFunctor *FunctToOptimize, vector<double> InitC);
00071 
00076         OptimalSol Optimize(FunctFunctor *FunctToOptimize, DerivFunctor *DerivOfFunct, vector<double> InitC);
00077 
00078   private:
00079         IKSolution IKCloseChain(PProtein *lp, Vector3 endPriorGoal, Vector3 endGoal, Vector3 endNextGoal);
00080         vector<PProtein*> lps;
00081         vector<int> nRsds, nbb, ndofs;
00082         vector<Vector3> endPG,endG,endNG;
00083         vector<ChainMove> AllMove;
00084         vector< vector<CDof> > DofsToUse;
00085 };
00086 
00087 #endif

Generated on Wed May 16 20:22:08 2007 for LoopTK: Protein Loop Kinematic Toolkit by  doxygen 1.5.1