File:  [LON-CAPA] / capa / capa51 / GUITools / analyzeScorer.tcl
Revision 1.3: download - view: text, annotated - select for diffs
Mon Aug 7 20:47:29 2000 UTC (24 years, 3 months ago) by albertel
Branches: MAIN
CVS tags: version_2_9_X, version_2_9_99_0, version_2_9_1, version_2_9_0, version_2_8_X, version_2_8_99_1, version_2_8_99_0, version_2_8_2, version_2_8_1, version_2_8_0, version_2_7_X, version_2_7_99_1, version_2_7_99_0, version_2_7_1, version_2_7_0, version_2_6_X, version_2_6_99_1, version_2_6_99_0, version_2_6_3, version_2_6_2, version_2_6_1, version_2_6_0, version_2_5_X, version_2_5_99_1, version_2_5_99_0, version_2_5_2, version_2_5_1, version_2_5_0, version_2_4_X, version_2_4_99_0, version_2_4_2, version_2_4_1, version_2_4_0, version_2_3_X, version_2_3_99_0, version_2_3_2, version_2_3_1, version_2_3_0, version_2_2_X, version_2_2_99_1, version_2_2_99_0, version_2_2_2, version_2_2_1, version_2_2_0, version_2_1_X, version_2_1_99_3, version_2_1_99_2, version_2_1_99_1, version_2_1_99_0, version_2_1_3, version_2_1_2, version_2_1_1, version_2_1_0, version_2_12_X, version_2_11_X, version_2_11_5_msu, version_2_11_5, version_2_11_4_uiuc, version_2_11_4_msu, version_2_11_4, version_2_11_3_uiuc, version_2_11_3_msu, version_2_11_3, version_2_11_2_uiuc, version_2_11_2_msu, version_2_11_2_educog, version_2_11_2, version_2_11_1, version_2_11_0_RC3, version_2_11_0_RC2, version_2_11_0_RC1, version_2_11_0, version_2_10_X, version_2_10_1, version_2_10_0_RC2, version_2_10_0_RC1, version_2_10_0, version_2_0_X, version_2_0_99_1, version_2_0_2, version_2_0_1, version_2_0_0, version_1_99_3, version_1_99_2, version_1_99_1_tmcc, version_1_99_1, version_1_99_0_tmcc, version_1_99_0, version_1_3_X, version_1_3_3, version_1_3_2, version_1_3_1, version_1_3_0, version_1_2_X, version_1_2_99_1, version_1_2_99_0, version_1_2_1, version_1_2_0, version_1_1_X, version_1_1_99_5, version_1_1_99_4, version_1_1_99_3, version_1_1_99_2, version_1_1_99_1, version_1_1_99_0, version_1_1_3, version_1_1_2, version_1_1_1, version_1_1_0, version_1_0_99_3, version_1_0_99_2, version_1_0_99_1, version_1_0_99, version_1_0_3, version_1_0_2, version_1_0_1, version_1_0_0, version_0_99_5, version_0_99_4, version_0_99_3, version_0_99_2, version_0_99_1, version_0_99_0, version_0_6_2, version_0_6, version_0_5_1, version_0_5, version_0_4, stable_2002_spring, stable_2002_july, stable_2002_april, stable_2001_fall, release_5-1-3, loncapaMITrelate_1, language_hyphenation_merge, language_hyphenation, conference_2003, bz6209-base, bz6209, STABLE, HEAD, GCI_3, GCI_2, GCI_1, CAPA_5-1-6, CAPA_5-1-5, CAPA_5-1-4_RC1, BZ4492-merge, BZ4492-feature_horizontal_radioresponse, BZ4492-feature_Support_horizontal_radioresponse, BZ4492-Support_horizontal_radioresponse
- fixed license notices the reference the GNU GPL rather than the GNU LGPL

# early verision of a reverse mapping of a randomized multiple choice 
# question analyzer
#  Copyright (C) 1992-2000 Michigan State University
#
#  The CAPA system is free software; you can redistribute it and/or
#  modify it under the terms of the GNU General Public License as
#  published by the Free Software Foundation; either version 2 of the
#  License, or (at your option) any later version.
#
#  The CAPA system is distributed in the hope that it will be useful,
#  but WITHOUT ANY WARRANTY; without even the implied warranty of
#  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
#  General Public License for more details.
#
#  You should have received a copy of the GNU General Public
#  License along with the CAPA system; see the file COPYING.  If not,
#  write to the Free Software Foundation, Inc., 59 Temple Place - Suite 330,
#  Boston, MA 02111-1307, USA.
#
#  As a special exception, you have permission to link this program
#  with the TtH/TtM library and distribute executables, as long as you
#  follow the requirements of the GNU GPL in regard to all of the
#  software in the executable aside from TtH/TtM.


proc parseScorerOutputLine { aline studentVar } {
    upvar $studentVar student
    set student(stunum) [lindex $aline 0]
    set aline [string range $aline 40 end]
    set length  [llength [split [lrange $aline 3 end] ,] ]
    set student(response) [lrange [split [lrange $aline 3 end] ,] 0 [expr {$length-2}]]
    set student(question) [lindex [lindex [split $aline ,] end] 0]
#    parray student
}

proc getQuestions { num pid set questnum questionVar } {
    upvar $questionVar question
    global gCapaConfig
    catch {unset question}
    set result [exec $gCapaConfig($num.answers_command) $pid {} 1 $set]
    set capture [set i 0]
    puts "$questnum:$i"
    foreach line [split $result "\n"] {
	switch [lindex [split $line :] 0] {
	    BQES {
		incr i
		if { [lsearch $questnum $i] != -1 } { set capture 1 }
	    }
	    EQES { set capture 0 }
	    ANS {
		if { [lsearch $questnum $i] != -1 } { 
		    set question($i.ans) [split [lindex [split $line :] 1] {} ]
		}
	    }
	    default { if { $capture } { lappend question($i.text) $line } }
	}
    }
    foreach quest $questnum {
	foreach line $question($quest.text) {
	    if { [regexp {^ *([A-Z])\)(.*)} $line temp letter rest] } {
		set question($quest.$letter) $rest
		if { [lsearch $question($quest.ans) $letter] != -1} {
		    set question($quest.correct.$letter) 1
		} else {
		    set question($quest.correct.$letter) 0
		}
	    }
	}
    }
    parray question
}

#FIXME not parsing all student responses?
proc getStudentResponses { responses which questionVar responseArVar } {
    upvar $questionVar question $responseArVar responseAr
    set i 0
    foreach response [split $responses {}] {
	if { $response == "" || $response == " "} { continue } 
	incr i
	if { [catch {incr responseAr($which.$question($which.$response))}] } {
	    if {[catch {set responseAr($which.$question($which.$response)) 1}]} {
                set responseAr($which.Illegal\ Bubble) 1
            }
	}
    }
    puts $i
}

set fileId [open "records/scorer.output.1" r]
set setId 1
set questionNum "1"
source /nfs/capa1/capadvt/CAPA_SRC/5.0/GUITools/common.tcl
set aline [gets $fileId]
set aline [gets $fileId]
parseCapaConfig 1 .
set k 0
while { ! [eof $fileId] } {
    parseScorerOutputLine $aline student
    getQuestions 1 $student(question) $setId $questionNum question
    foreach which $questionNum {
	getStudentResponses [lindex $student(response) [expr $which-1]] $which question \
	    responses
    }
    foreach which $questionNum {
	foreach elem [array names responses "$which.*"] {
	    puts -nonewline "$responses($elem) "
	}
    }
   incr k
    if { $k%20 == 0 } { parray responses }
    puts ""
    set aline [gets $fileId]
}
parray responses

FreeBSD-CVSweb <freebsd-cvsweb@FreeBSD.org>