當前位置: 首頁>>代碼示例>>Python>>正文


Python LOGGER.warn方法代碼示例

本文整理匯總了Python中fullrmc.Globals.LOGGER.warn方法的典型用法代碼示例。如果您正苦於以下問題:Python LOGGER.warn方法的具體用法?Python LOGGER.warn怎麽用?Python LOGGER.warn使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在fullrmc.Globals.LOGGER的用法示例。


在下文中一共展示了LOGGER.warn方法的3個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。

示例1: get_constraint_original_value

# 需要導入模塊: from fullrmc.Globals import LOGGER [as 別名]
# 或者: from fullrmc.Globals.LOGGER import warn [as 別名]
 def get_constraint_original_value(self):
     """
     Compute all partial Pair Distribution Functions (PDFs). 
     
     :Returns:
         #. PDFs (dictionary): The PDFs dictionnary, where keys are the element wise intra and inter molecular PDFs and values are the computed PDFs.
     """
     if self.originalData is None:
         LOGGER.warn("originalData must be computed first using 'compute_data' method.")
         return {}
     return self._get_constraint_value(self.originalData)
開發者ID:youssefaoun,項目名稱:fullrmc,代碼行數:13,代碼來源:PairDistributionConstraints.py

示例2: create_angles_by_definition

# 需要導入模塊: from fullrmc.Globals import LOGGER [as 別名]
# 或者: from fullrmc.Globals.LOGGER import warn [as 別名]
 def create_angles_by_definition(self, anglesDefinition):
     """ 
     Creates anglesMap using angles definition.
     Calls set_angles(anglesMap) and generates angles attribute.
     
     :Parameters:
         #. anglesDefinition (dict): The angles definition. 
            Every key must be a molecule name (residue name in pdb file). 
            Every key value must be a list of angles definitions. 
            Every angle definition is a list of five items where:
            
            #. First item: The name of the central atom forming the angle.
            #. Second item: The name of the left atom forming the angle (interchangeable with the right atom).
            #. Third item: The name of the right atom forming the angle (interchangeable with the left atom).
            #. Fourth item: The minimum lower limit or the minimum angle allowed in degrees.
            #. Fifth item: The maximum upper limit or the maximum angle allowed in degrees.
     
     ::
     
         e.g. (Carbon tetrachloride):  anglesDefinition={"CCL4": [('C','CL1','CL2' , 105, 115),
                                                                  ('C','CL2','CL3' , 105, 115),
                                                                  ('C','CL3','CL4' , 105, 115),                                      
                                                                  ('C','CL4','CL1' , 105, 115) ] }
                                                              
     """
     if self.engine is None:
         raise Exception(LOGGER.error("Engine is not defined. Can't create angles"))
     assert isinstance(anglesDefinition, dict), LOGGER.error("anglesDefinition must be a dictionary")
     # check map definition
     existingMoleculesNames = sorted(set(self.engine.moleculesNames))
     anglesDef = {}
     for mol, angles in anglesDefinition.items():
         if mol not in existingMoleculesNames:
             LOGGER.warn("Molecule name '%s' in anglesDefinition is not recognized, angles definition for this particular molecule is omitted"%str(mol))
             continue
         assert isinstance(angles, (list, set, tuple)), LOGGER.error("mapDefinition molecule angles must be a list")
         angles = list(angles)
         molAnglesMap = []
         for angle in angles:
             assert isinstance(angle, (list, set, tuple)), LOGGER.error("mapDefinition angles must be a list")
             angle = list(angle)
             assert len(angle)==5
             centralAt, leftAt, rightAt, lower, upper = angle
             assert is_number(lower)
             lower = FLOAT_TYPE(lower)
             assert is_number(upper)
             upper = FLOAT_TYPE(upper)
             assert lower>=0, LOGGER.error("anglesMap items lists fourth item must be positive")
             assert upper>lower, LOGGER.error("anglesMap items lists fourth item must be smaller than the fifth item")
             assert upper<=180, LOGGER.error("anglesMap items lists fifth item must be smaller or equal to 180")
             lower *= FLOAT_TYPE( PI/FLOAT_TYPE(180.) )
             upper *= FLOAT_TYPE( PI/FLOAT_TYPE(180.) )
             # check for redundancy
             append = True
             for b in molAnglesMap:
                 if (b[0]==centralAt) and ( (b[1]==leftAt and b[2]==rightAt) or (b[1]==rightAt and b[2]==leftAt) ):
                     LOGGER.warn("Redundant definition for anglesDefinition found. The later '%s' is ignored"%str(b))
                     append = False
                     break
             if append:
                 molAnglesMap.append((centralAt, leftAt, rightAt, lower, upper))
         # create bondDef for molecule mol 
         anglesDef[mol] = molAnglesMap
     # create mols dictionary
     mols = {}
     for idx in self.engine.pdb.xindexes:
         molName = self.engine.moleculesNames[idx]
         if not molName in anglesDef.keys():    
             continue
         molIdx = self.engine.moleculesIndexes[idx]
         if not mols.has_key(molIdx):
             mols[molIdx] = {"name":molName, "indexes":[], "names":[]}
         mols[molIdx]["indexes"].append(idx)
         mols[molIdx]["names"].append(self.engine.allNames[idx])
     # get anglesMap
     anglesMap = []         
     for val in mols.values():
         indexes = val["indexes"]
         names   = val["names"]
         # get definition for this molecule
         thisDef = anglesDef[val["name"]]
         for angle in thisDef:
             centralIdx = indexes[ names.index(angle[0]) ]
             leftIdx    = indexes[ names.index(angle[1]) ]
             rightIdx   = indexes[ names.index(angle[2]) ]
             lower      = angle[3]
             upper      = angle[4]
             anglesMap.append((centralIdx, leftIdx, rightIdx, lower, upper))
     # create angles
     self.set_angles(anglesMap=anglesMap)
開發者ID:youssefaoun,項目名稱:fullrmc,代碼行數:92,代碼來源:AngleConstraints.py

示例3: set_angles

# 需要導入模塊: from fullrmc.Globals import LOGGER [as 別名]
# 或者: from fullrmc.Globals.LOGGER import warn [as 別名]
 def set_angles(self, anglesMap):
     """ 
     Sets the angles dictionary by parsing the anglesMap list.
     
     :Parameters:
         #. anglesMap (list): The angles map definition.
            Every item must be a list of five items.
            
            #. First item: The central atom index.
            #. Second item: The index of the left atom forming the angle (interchangeable with the right atom).
            #. Third item: The index of the right atom forming the angle (interchangeable with the left atom).
            #. Fourth item: The minimum lower limit or the minimum angle allowed in rad.
            #. Fifth item: The maximum upper limit or the maximum angle allowed in rad.
     """
     map = []
     if self.engine is not None:
         if anglesMap is not None:
             assert isinstance(anglesMap, (list, set, tuple)), LOGGER.error("anglesMap must be None or a list")
             for angle in anglesMap:
                 assert isinstance(angle, (list, set, tuple)), LOGGER.error("anglesMap items must be lists")
                 angle = list(angle)
                 assert len(angle)==5, LOGGER.error("anglesMap items must be lists of 5 items each")
                 centralIdx, leftIdx, rightIdx, lower, upper = angle
                 assert is_integer(centralIdx), LOGGER.error("anglesMap items lists of first item must be an integer")
                 centralIdx = INT_TYPE(centralIdx)
                 assert is_integer(leftIdx), LOGGER.error("anglesMap items lists of second item must be an integer")
                 leftIdx = INT_TYPE(leftIdx)
                 assert is_integer(rightIdx), LOGGER.error("anglesMap items lists of third item must be an integer")
                 rightIdx = INT_TYPE(rightIdx)
                 assert centralIdx>=0, LOGGER.error("anglesMap items lists first item must be positive")
                 assert leftIdx>=0, LOGGER.error("anglesMap items lists second item must be positive")
                 assert rightIdx>=0, LOGGER.error("anglesMap items lists third item must be positive")
                 assert centralIdx!=leftIdx, LOGGER.error("bondsMap items lists first and second items can't be the same")
                 assert centralIdx!=rightIdx, LOGGER.error("bondsMap items lists first and third items can't be the same")
                 assert leftIdx!=rightIdx, LOGGER.error("bondsMap items lists second and third items can't be the same")
                 assert is_number(lower), LOGGER.error("anglesMap items lists of third item must be a number")
                 lower = FLOAT_TYPE(lower)
                 assert is_number(upper), LOGGER.error("anglesMap items lists of fourth item must be a number")
                 upper = FLOAT_TYPE(upper)
                 assert lower>=0, LOGGER.error("anglesMap items lists fourth item must be positive")
                 assert upper>lower, LOGGER.error("anglesMap items lists fourth item must be smaller than the fifth item")
                 assert upper<=PI, LOGGER.error("anglesMap items lists fifth item must be smaller or equal to %.10f"%PI)
                 map.append((centralIdx, leftIdx, rightIdx, lower, upper))  
     # set anglesMap definition
     self.__anglesMap = map     
     # create bonds list of indexes arrays
     self.__angles = {}
     self.__atomsLUAD = {}
     if self.engine is not None:
         # parse bondsMap
         for angle in self.__anglesMap:
             centralIdx, leftIdx, rightIdx, lower, upper = angle
             assert centralIdx<len(self.engine.pdb), LOGGER.error("angle atom index must be smaller than maximum number of atoms")
             assert leftIdx<len(self.engine.pdb), LOGGER.error("angle atom index must be smaller than maximum number of atoms")
             assert rightIdx<len(self.engine.pdb), LOGGER.error("angle atom index must be smaller than maximum number of atoms")
             # create atoms look up angles dictionary
             if not self.__atomsLUAD.has_key(centralIdx):
                 self.__atomsLUAD[centralIdx] = []
             if not self.__atomsLUAD.has_key(leftIdx):
                 self.__atomsLUAD[leftIdx] = []
             if not self.__atomsLUAD.has_key(rightIdx):
                 self.__atomsLUAD[rightIdx] = []
             # create angles
             if not self.__angles.has_key(centralIdx):
                 self.__angles[centralIdx] = {"leftIndexes":[],"rightIndexes":[],"lower":[],"upper":[]}
             # check for redundancy and append
             elif leftIdx in self.__angles[centralIdx]["leftIndexes"]:
                 index = self.__angles[centralIdx]["leftIndexes"].index(leftIdx)
                 if rightIdx == self.__angles[centralIdx]["rightIndexes"][index]:
                     LOGGER.warn("Angle definition for central atom index '%i' and interchangeable left an right '%i' and '%i' is  already defined. New angle limits [%.3f,%.3f] ignored and old angle limits [%.3f,%.3f] kept."%(centralIdx, leftIdx, rightIdx, lower, upper, self.__angles[centralIdx]["lower"][index], self.__angles[centralIdx]["upper"][index]))
                     continue
             elif leftIdx in self.__angles[centralIdx]["rightIndexes"]:
                 index = self.__angles[centralIdx]["rightIndexes"].index(leftIdx)
                 if rightIdx == self.__angles[centralIdx]["leftIndexes"][index]:
                     LOGGER.warn("Angle definition for central atom index '%i' and interchangeable left an right '%i' and '%i' is  already defined. New angle limits [%.3f,%.3f] ignored and old angle limits [%.3f,%.3f] kept."%(centralIdx, leftIdx, rightIdx, lower, upper, self.__angles[centralIdx]["lower"][index], self.__angles[centralIdx]["upper"][index]))
                     continue
             # add angle definition
             self.__angles[centralIdx]["leftIndexes"].append(leftIdx)
             self.__angles[centralIdx]["rightIndexes"].append(rightIdx)
             self.__angles[centralIdx]["lower"].append(lower)
             self.__angles[centralIdx]["upper"].append(upper)
             self.__atomsLUAD[centralIdx].append(centralIdx)
             self.__atomsLUAD[leftIdx].append(centralIdx)
             self.__atomsLUAD[rightIdx].append(centralIdx)
         # finalize angles
         for idx in self.engine.pdb.xindexes:
             angles = self.__angles.get(idx, {"leftIndexes":[],"rightIndexes":[],"lower":[],"upper":[]} )
             self.__angles[INT_TYPE(idx)] =  {"leftIndexes": np.array(angles["leftIndexes"], dtype = INT_TYPE), 
                                              "rightIndexes": np.array(angles["rightIndexes"], dtype = INT_TYPE),
                                              "lower"  : np.array(angles["lower"]  , dtype = FLOAT_TYPE),
                                              "upper"  : np.array(angles["upper"]  , dtype = FLOAT_TYPE) }
             lut = self.__atomsLUAD.get(idx, [] )
             self.__atomsLUAD[INT_TYPE(idx)] = sorted(set(lut))
     # reset constraint
     self.__initialize_constraint__()
開發者ID:youssefaoun,項目名稱:fullrmc,代碼行數:97,代碼來源:AngleConstraints.py


注:本文中的fullrmc.Globals.LOGGER.warn方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。