Welcome to Evaluations Help
Introduction: An overview of Evaluations plug-in for SFIAB
Installation: How to Install Evaluations plug-in
Process: The typical process used in Evaluations plug-in
Setup: How to set up the evaluations schemes for your event.
Step by Step: Details about the administrative actions (steps) in the Evaluations process.
Examples: Examples of setting up Evaluations for different types of project evaluations and scoring.
Tables: Details about the database tables used in Evaluations.
Apperson Scanner: How to setup SFIAB to use the Apperson Education Products Benchmark 3000 Scanner.
NOTE: The Evaluations plugin should be 'functional' at this time but not
secured. Until security is incorporated, it should not be used on real data.
I will need James to help implement security.
To Do list: (in order of importance - sort of):
Evaluations is a plug-in to SFIAB. That means you can add it to your current version of SFIAB with
minimal changes to your current SFIAB version. No changes will be made to
your current SFIAB data. In other words, no matter where you are in the SFIAB process for your event, you can add and take advantage of Evaluations and not worry about it creating problems. If you decide to not use it in the future you can 'unplug' it without any effect on your current setup or data.
There are two changes in the configuration of SFIAB that must be implemented
during the installing of Evaluations:
SFIAB must be configured for judging as follows:
- the table config must have an entry with var = 'score_entry_enable' and val = 'yes'
- the table judges_teams_timeslots_projects_link must have a field 'score' Float length 5.2 null=yes
Configuring SFIAB in this manner will also enable the necessary links in the admin menu and the judges menu for using Evaluations. This is the SFIAB configuration used my one or more fairs in the past.
Evaluations provides a very configurable method of capturing 'scores' for your projects. You can configure multiple schemes used for scoring! For each scheme you design the evaluation criteria to use, the weighting for each criteria and the levels (choices) judges can select from for each criteria. With multiple schemes you can design a completely different method of evaluation for each different type of projects (i.e. senior divisions versus junior divisions, team projects, etc.) When your organization changes the way they want you to evaluate projects, just change the Evaluations setup.
Evaluations provides several methods of collecting your judge teams (judges) evaluations. Web pages are built for each scheme for entry on the web. CSV files are created for use with scanners or for creating your own forms to be used by the judge teams (judges)
And, all the calculations are done for you. Evaluations uses the information in your setup to calculate scores from the entries made by the judges. The code works for all combinations of possible schemes - it all driven by the tables. So, once you can set up your scheme(s) Evaluations can do the math. A unique averaging method is used when you collect more than one evaluation for each project so all the valid data is used, even if one judge team leaves out a mark or makes multiple marks on their evaluations forms (i.e. when using scanners)..
The process in a nutshell is:
1. Install Evaluations plug-in:
2. Set up your evaluation schemes, criteria and values:
3. After all your projects and judge teams are configured - Link Evaluations to your SFIAB data.
4. If required, Export the necessary data for use by external
programs or scanners to collect the evaluations:
- CSV files are created for download for your use in programming scanners and pre slug of the scanner forms
- CSF files can be use to create your own evaluation forms.
5. The judge teams (judges) do the evaluations and 'mark' the appropriate level for each of the criteria for the scheme that applies to the project.
6. The data is collected into a table in Evaluations.
7. The data is processed (a button push).
8. If a caucus of the judge team requires some adjustments to the evaluations scores, that is accomplished by the team leader (chair person) - resulting in the final score for the project.
9. Reports and or CSV files are available for the final results.
10. A tool is provided to facilitate assigning the winners of some of the category awards (1st, 2nd, 3rd prizes and honorable mentions) where those winners simply rely on the ranking results.
It is imperative you understand how to correctly setup Evaluations for your event. With that in mind we will try our best to explain how the setup works and the various options that are available.
Definitions:
Scheme: A method of evaluating a set of projects - perhaps differently than other projects. For instance you might have a scheme for team projects and another scheme for non-team projects. Or, you might have different schemes for each division in your event. Each scheme has a specific set of criteria, criteria weights and evaluation levels (choices) used to evaluate a project and then to calculate a score for that project. Each project is assigned a scheme. You can have as many schemes as you like. Each scheme has an id, a name and a selection statement. The selection statement is used to select which scheme is used for each project. The selection statement has three parts. the 'item', the 'condition' and the 'value' - like 'div > 1'. Each project that matches the selection statement of one of the schemes is assigned that scheme. Here are a couple of examples of schemes:
scheme id name selection statement result
1 ISEF scoring team = no projects with one student are assigned scheme id 1
2 ISEF (Team) team = yes projects with two or more students are assigned scheme id 2
scheme id name selection statement result assumes we have 2 categories setup - Junior = 1, Senior =2
1 Junior Category cat = 1 projects with category id = 1 (junior) are assigned scheme id
1.
2 Senior Category cat > 1 projects with category id = 2 or higher are assigned scheme id
2. (could use cat = 2 also)
'item': The 'item' part can have and of the following values: (more can be added it your request but it requires a code change.)
team: If the project has one student then the value of team is 'no'. If the project has more than one student then the value of team is 'yes'
cat: This represents the setting of the category_id assigned to the project. You set up categories in SFIAB and each project gets assigned one of those categories.
div: This represents the setting of the division_id assigned to the project. You set up divisions in SFIAB and each project gets assigned one of those divisions.
grade: This represents the grade of the project's student. For teams, grade is the grade of the team member with the highest grade.
cwdiv: This represents the Canada wide science fair division id (cwsfdivisionid field in projects).
'condition': You are allowed to use any one of these
symbols as the 'condition' part of the scheme selection criteria:
= Equal
!= Not Equal
< Less Than
> Greater Than
'value:' The 'value' part represents the value of the Field for each project. For instance team can have a value of 'yes' or 'no'. Cat can have values like 0,1,2... - whatever you used for the Category Ids when you set up Age Categories in SFIAB. cwsfdivisionid has values those in Canada should understand.
So, you can setup criteria like 'team = yes' or 'div = 1' or 'div < 3' or 'team != no' etc. Except for team (value = 'yes' or 'no) it is important to use a value that is set up for that field in SFIAB else the scheme_id will not be set correctly in Evaluations projects data.
Criteria: Each evaluation scheme will have a set of criteria. These are what the judge team considers when comparing a project with other projects and with a standard. Examples of criteria are: 'Scientific Thought', 'Skill', 'Thoroughness', 'Teamwork', 'Research Skill', Etc. You create the criteria for each scheme used for your event. In fact you can have different criteria and a different number of criteria for each scheme For instance, elementary school projects may require only two criteria - 'Scientific Approach' 'Completeness' where as a senior school projects will require criteria of more relevance to the project advancing to the next level.
Levels: Each evaluation scheme will have a set of levels. Levels are like grades. You determine the number of levels your evaluations will have and the value assigned to each level for each scheme. For instance you might have levels of A, B, C, D, F with values of 4,3,2,1,0 for one scheme and levels of Exceptional, Excellent, Very Good , Good, Acceptable with values of 5,4,3,2,1 for another scheme. The values do not have to be a sequence of integers but that works best. There are also optional 'special use' levels you can create that allow you to do error checking on the judges entries and take the appropriate action if the entry has errors. Special use levels are not used in calculating a score. An example is to assign a 'special use' level of 'No Entry' with a value of 0. Then when a scanner or any other process used to collect entries detects that there is no mark for a criteria it can assign the value 0 to the entry and Evaluations knows to 1.) not use that criteria entry in the calculations and 2.) indicate the error in the status for that entry. The short 4 character level_code is then added to the status for that entry. Setting a 'special use' level "MultipleMarks" with a value of 7 would allow the collection process (i.e. a scanner) to set that value when multiple entries are made for a criteria. Evaluations knows to not use that criteria's entry in the calculations and can indicate the error in the status.
Weighting: Each criteria will have a weighing assigned in such a way that the sum of the weights for all the criteria to be used is = 100. Lets do an example: Say one of your evaluations schemes has 4 levels -L1, L2, L3 and L4 with values of 1,2,3,4 and the scheme as 3 criteria C1, C2 and C3. with weights of 20,30, 50. Note the weights add up to 100. Define level_value as the entry made by the judge for a given criteria. It will be 1,2,3 or 4 in this example. Also define max_level_val as the maximum level value used in calculating a score (i.e. not a 'special use' level) In this example max_level_val = 4. Given all that, a score in this example is calculated as follows:
score = ( C1.level_value * C1.weight + C2.level_value * C2.weight + C3.level_value * C3.weight) / ( max_level_val)
If all level_values are = 4 (the perfect project), then:
perfectscore = (4*20 + 4*30 + 4*50) / 4
perfectscore = 80 + 120 + 200) /4
perfectscore = 400 / 4 = 100
the lowest score for this scheme will be:
lowest score = (1*20 + 1* 30 + 1* 50) / 4 = 25
Note: You may enter a criteria with a weight of '0' This allows keeping the number of criteria the same for each scheme. This special case is used to provide compatibility with the Exported CSV files used to pre slug the Apperson Education Products Benchmark 3000 scanners.
Setup: Now that you understand (hopefully) the definitions we can explain how you set up 'Evaluations'
Note: For now all setup is done in the tables. This will be updated as I create the web pages for setup
1.) Decide how many schemes you will need. Most events will use only one scheme, some will want two or more. Enter the schemes in table eval_schemes. enter the item, condition and value in the scheme's selection statement.
2.) For each scheme enter a record in eval_criteria for each criteria to be used for that scheme.
3.) For each scheme enter a record in eval_levels for each level to be used for that scheme.
For an example for ISEF evaluations (2010) see evaluations/db/db.eval.setup.isef.sql. This setup is compatible with the Apperson Education Products Benchmark 3000 scanners.
To install Evaluations plug-in follow these steps:
'root' (the base folder for sfiab)
'admin' the SFIAB admin folder
... other SFIAB folders
'plugins' ( a folder for all plugins)
'evaluations' (the Evaluations plug-in base folder)
'db' folder (the Evaluations data base creation and update files and the various default evaluation setup files)
'docs' folder (files for information or download)
'uploads' folder (uploaded files are placed here while in use - then deleted - folder must be 'writable'.)
files... The various files for Evaluations.
.....
'Rmail' ... or other SFIAB folders.
There will be no link in SFIAB to get to the main page for evaluations so.. do the following:
- Log into SFIAB as a super user.
- In you web browser go to 'SFIAB/plugins/evaluations/eval_index.php'
(Where 'SFIAB' is you main browser root name for your SFIAB installation)
- If Evaluations is not installed you will be quided through the steps to install and set up Evaluations.
What the installation does:
Link Evaluations to Data base: For Evaluations to function it must be linked to the SFIAB data. This step creates (or updates) all the linkages so that Evaluations has the necessary information from SFIAB (read only) to accomplish the tasks designed into Evaluations.
Assign judge teams (or judges) to the projects they are to evaluate. The default here is to use the judge_team_projects assignments of SFIAB so it is important that these are setup in SFIAB and that you run the 'Link Evaluations' after they are setup to update the Evaluations information. Optionally, you can go thru a completely different assignment of judges to projects. This feature is NOT IMPLEMENTED for revision 100 of Evaluations and will be implemented only if enough requests are generated.
Create the evaluations documents or files required to enter the evaluations. This step can do several options.
1.) A web form for each evaluation scheme is created automatically for each judge teams' assigned projects. The form will have the following:
- an entry for the team (or judge) number doing the evaluation. (one of the judge team members must be logged in.)
- an entry (selection) of one of the assigned project numbers.
- a web form table is presented with bubbles to mark for the project as follows
criteria criteria criteria ....
level [ ] [ ] [ ]
level [ ] [ ] [ ]
level [ ] [ ] [ ]
- a button to submit the evaluation entries
2.) CSV download files to be used by your organization to create your own web pages, or score forms or to pre slug standard forms or to import to scanners. The files should have enough data to accomplish your process. If not, request additional data be added. (coding changes)
3.) specific CSV files to be used to:
- Load the 'student' data into the Apperson Education Products Benchmark 3000 scanner (requires a specific scheme setup).
- Pre slug the Apperson Education Products Benchmark 3000 'Science Fair evaluation' forms.
Evaluate the projects: During this time the judge teams (or judges) either mark the forms for your event, enter the evaluations on the web page or some other process to capture the required information. For each project, each evaluation they need the following:
- project number (this is automatic in web page and Apperson scanner)
- Team or judge number (this is required to verify that that team or judge has been assigned to the project.
- a list of criteria_id, level_id pairs representing the evaluation of the project. (automatic with Apperson scanner and web page)
- other optional items not yet designed.
Enter the evaluations: the data from the evaluations is entered into Evaluations tables. This is done by the web page, or an upload from the Apperson Scanner or by an upload of a CSV file(s) created by you with the correct specifications. Details TBD.
Calculate the scores: This is simply a button push. It calculates the individual score for each evaluation and... calculated the project's eval_score which is an average all of the evaluations for that project.
Enter the final scores: After a caucus of the judge team(s) some adjustment will sometimes be required to the projects scores. This can be accomplished using a Evaluations web page
examples: TBD
Table description TBD for now see the db.eval.full.100.sql file or browse the tables with phpmyadmin.
eval_projects: Caution: contains all projects, even those not assigned. (may change this later - or not)
eval_projects-entries. A copy of judges_teams_timeslots_projects_links with additional fields ( a record for each project - judge team assignment with the scheme_id, and an entry for the selected value_id during judging.
Setup SFIAB to use Apperson Scanner
If you want to use the Apperson Scanner to record evaluation the following SFIAB setup rules must apply:
The main requirement is that the scanner
(and forms) require project numbers form 1 to 9999 and Judge numbers from 1 to
9999
To accomplish this the following must be true.
If the Category digit(s) are removed from the SFIAB project number the
resulting numbers must be unique.
Here is one way to accomplish the above requirements:
Configuration variables:
-Allows for the setup of different divisions for each category: = Yes
(not sure, perhaps No will also work???)
-Project Numbering Format = CDN
(Category, Division, Number)
Project Age Categories: The Categories' IDs must be an integer from 1 to 9
(usually 1 = Junior, 2 = Senior)
Divisions: The Divisions' IDs must be integers from 1 to 99
(Usually Junior = 1 to n, Senior = n+1 to ..(99max)
When creating the Divisions, Create a separate Division ID for each
Category even if the Division name is the same.
( do Not assign more than one category to a Division)
Example:
Category
Division
1 - Junior
1 - Animal Science (junior)
1 - Junior
2 - Chemistry (junior)
etc ...
2 - Senior
22- Animal Science (senior)
2 - Senior
23 - Chemistry
etc
Thus, project Numbers are never more than 5 digits - i.e. CDDNN
where NN is the exhibit sub number in the specific Division. And, when the 'C'
is removed the remaining number is still a unique number. However...
VERY IMPORTANT - This means there can be no more than 99 projects in a given
category-division.
If that becomes a problem for your fair, a different SFIAB
numbering method must be invented.
Other methods may also work. If you have a suggestion, let us know.
Evaluation Schemes You must have 2 - Non-Team and Team (One
may work not sure yet)
Evaluation Criteria You must have 6 criteria for each scheme with
Ids from 1 to 6 as follows *you can use ISEF weighting or your own)
id name
weight non team weight team
1 -Creative Ability
30
25
2 -Scientific Thought
30
25
3 -Thoroughness
15
12
4 -Skill
15
12
5 -Clarity
10
10
6 -Teamwork
0
16
Note: Starting in 2011, ISEF no longer uses the Teamwork criteria - all projects
are evaluated using the non-team weights
You must have 7 levels for each criteria with Ids from 0 to 6 as follows: (You
can use your own level_values but for ISEF the value = id
id value name spec_use
Spec_use_code
0 0 No mark yes
NoMk
1 1 Acceptable no
2 2 Good
no
3 3 Very Good no
4 4 Excellent no
5 5 Exceptional no
7 7 MultipleMark yes
MltM
Note level_id of 6 is not used
IMPORT data from Apperson Scanner:
The file created by the scanner has the following format (the import code is
designed to use this format)
"Apperson_proj_num","Judgeteam_num","CreativeAbility.level_id","ScientificThouth.level_id","Thoroughness.level_id","Skill.level_id","Clarity.level_id","Teamwork.level_id","seq#"
where level_id are 0,1,2,3,4,5,7 0 = no mark
7 = double mark and seq# is a 6 digit sequence number created by the
scanner.
Imp