| Behavior | 
                            Exhibits correct behavior in all cases, including edge, corner, and error cases | 
                            Exhibits correct behavior in all common cases | 
                            Exhibits incorrect behavior in some common casesLacks some required functionality | 
                            Behavior does not resemble specificationLacks significant portions of required functionality | 
                
                    | Abstraction and Design | 
                            Classes contain no redundant constructorsAll methods are clear and concise and include no extraneous parametersAll methods include a proper access modifierClasses contain only the most essential fields and all fields are initialized appropriatelyAll constants are declared correctly and used in all appropriate placesMost appropriate type, including interface types, used in all expected places | 
                            No redundancy exists between methodsAll methods are clear and conciseClasses contain no extraneous constructorsClasses contain reasonable fieldsAll constants are declared correctlyReasonable types used in all placesAll public methods are specified public | 
                            Redundancy exists between methodsSome methods are overly long or complexClasses contain redundant or extraneous constructors or public methodsClasses contain extraneous or unnecessary fieldsConstants are declared incorrectlyUnreasonable or inappropriate types used in some places | 
                            Not enough code present to evaluate effectivelyRequired methods or constructors missingNo fields present | 
                
                    | Use of Concepts | 
                            Most appropriate variant of all control flow constructs used and properly factored and simplifiedRecursive methods contain no extraneous cases or callsNo expensive operations are unnecessarily recomputedMost appropriate data structure used in all casesAll assignment-specific requirements met | 
                            Appropriate control flow constructs usedRecursive methods contain extraneous cases or callsDoes not create any unnecessary objectsAppropriate data structure used in all casesKey assignment-specific requirements met | 
                            Inappropriate control flow constructs usedRecursive methods contain redundant cases or callsCreates unnecessary objectsInappropriate data structure used in some casesSome assignment-specific requirements not met | 
                            Not enough code present to evaluate effectivelyRequired language features or concepts not usedBanned or inappropriate language features or concepts used | 
                
                    | Documentation and Readability | 
                            Header comments on all classes and methods are well-written and contain all relevant informationAll identifiers are meaningful and follow prescribed naming conventionsAll code is indented and spaced consistently and cleanlyNo lines longer than 100 charactersCode has no "magic numbers"Exceptions thrown as soon as possiblePersonal style choices are consistent and reasonable | 
                            Header comments present on all classes and methodsSome identifier names are not meaningful or fail to follow prescribed conventionsNo complete blocks are indented or spaced incorrectlySome lines longer than 100 characters | 
                            Header comments missing on some classes and/or methodsEntire code blocks are indented or spaced incorrectly | 
                            Not enough code present to evaluate effectivelyCode shows little or no effort follow code quality guidelinesCode is extremely difficult to read and understand |