Annotation of capa/capa51/pProj/checkunits.c, revision 1.1.1.1

1.1       albertel    1: 
                      2: /* 
                      3:    Units is checked against real or integer answers, 
                      4:    for string and choice answers, units is not checked 
                      5:    
                      6:           UNIT_NOTNEEDED  ==> user entered some units and answer did not need one
                      7:           NO_UNIT         ==> 
                      8:           UNIT_FAIL
                      9:    
                     10:    ans_type must be either ANSWER_IS_INTEGER or ANSWER_IS_FLOAT
                     11:    or else, skip or return UNIT_NOTNEEDED
                     12:    if unit_p is NULL, then UNIT_NOTNEEDED
                     13:    
                     14:    answer must contains at least one digit 
                     15:    
                     16:    
                     17: */
                     18: 
                     19: /*   
                     20: 
                     21: 
                     22: #define    EXACT_ANS           1
                     23: #define    APPROX_ANS          2 
                     24: #define    SIG_FAIL            3
                     25: #define    UNIT_FAIL           4
                     26: #define    NO_UNIT             5
                     27: #define    UNIT_OK             6
                     28: #define    INCORRECT           7
                     29: #define    UNIT_NOTNEEDED      8
                     30: #define    ANS_CNT_NOT_MATCH   9
                     31:   /*  called from capaCommon.c */
                     32: /*                      */
                     33: /*  UNIT_FAIL           */
                     34: /*  NO_UNIT             */
                     35: /*  result: UNIT_OK correct   */
                     36: /*                            */
                     37:  */
                     38: 
                     39: /* capa_check_units() only works under ANSWER_IS_INTEGER or ANSWER_IS_FLOAT */
                     40: int
                     41: capa_check_units( ans, u_p ) char *ans;Unit_t *u_p;
                     42: {
                     43:   input_len = strlen(ans);
                     44:   all_alphabet = 1;
                     45:   for(idx=0;idx<input_len;idx++) {
                     46:     if( isdigit(ans[idx]) ) {
                     47:       all_alphabet = 0;
                     48:     }
                     49:   }
                     50:   
                     51:   if( !all_alphabet ) { /* contains at least a digit char */
                     52:     outcome = split_num_unit(ans,&n_part,num_str,unit_str);
                     53:     /* num_str is used in calc_sig() for sig fig */
                     54:     /* n_part is used together with scale from check_correct_answer() */
                     55:     /* unit_str is used later as input to check_correct_unit() */
                     56:     if( outcome > 1 ) {  /* with both num and unit parts or only unit part */
                     57:     
                     58:       if( u_p != NULL ) {
                     59:           result = check_correct_unit(unit_str,u_p,&scale);
                     60:           /* result could be UNIT_OK, UNIT_FAIL */
                     61:           
                     62:           
                     63:       } else { /* no unit is specified but student entered an units? */
                     64:           
                     65:           result = UNIT_NOTNEEDED;
                     66:           
                     67:       }
                     68: 
                     69:     } else { /* outcome = 0 empty string, 1 a number without units */
                     70:       if( u_p != NULL ) {
                     71:           
                     72:           result = NO_UNIT; /* units required */
                     73:           
                     74:       } else { 
                     75:           result = INCORRECT, /* proceed to check numerical value */
                     76:       }
                     77:     }
                     78:     /* at this point, result could be one of UNIT_OK, UNIT_FAIL, UNIT_NOTNEEDED, and NO_UNIT */
                     79:     
                     80:     sig = calc_sig( num_str );
                     81:     
                     82:   } else {   /* contains all non-digit  char */
                     83:       result = INCORRECT;  /* the students may enter an units but not containing any number */
                     84:       
                     85:   }
                     86:   return (result);
                     87: }
                     88: 
                     89: 
                     90: 
                     91: 
                     92: 
                     93: 
                     94: 
                     95: 
                     96: 
                     97: 
                     98: 
                     99: 
                    100: 
                    101: 
                    102: int
                    103: capa_check_allunits(p,answers,cnt) Problem_t *p; char **answers; int cnt;
                    104: {
                    105:   int     type; 
                    106:   char   *correct;
                    107:   char    input[ANSWER_STRING_LENG], unit_str[UNIT_STRING_LENG];
                    108:   int     tol_type, calc_type;
                    109:   double  tol, n_part; 
                    110:   int     sig_l; 
                    111:   int     sig_u;
                    112:   char   *fmt;
                    113:   int     choice[SIXTY_FOUR], ii, idx, corr_len, input_len;
                    114:   int     result = INCORRECT, sig, outcome, all_alphabet;
                    115:   char    fmted[FORMAT_STRING_LENG];
                    116:   double  given, target, ratio, fmted_target, target_u, target_l, scale=1.0;
                    117:   double  delta;
                    118:   
                    119:   type       = p->ans_type;
                    120:   correct    = p->answer;
                    121:   tol_type   = p->tol_type;
                    122:   tol        = p->tolerance;
                    123:   sig_l      = p->sig_lbound;
                    124:   sig_u      = p->sig_ubound;
                    125:   fmt        = p->ans_fmt;
                    126:   calc_type  = p->calc;
                    127:   unit_str[0]= 0;
                    128:   
                    129:   if( (cnt != p->ans_cnt) ) { return (ANS_CNT_NOT_MATCH); }
                    130:   switch(type) {
                    131:     case ANSWER_IS_INTEGER:
                    132:     case ANSWER_IS_FLOAT:
                    133:           {
                    134:             input_len = strlen(ans);
                    135:             all_alphabet = 1;
                    136:             for(idx=0;idx<input_len;idx++) {
                    137:               if( isdigit(ans[idx]) ) {
                    138:                 all_alphabet = 0;
                    139:               }
                    140:             }
                    141:             if( !all_alphabet ) {  /* answer string is not all alphabets */
                    142:               outcome = split_num_unit(ans,&n_part,num_str,unit_str);
                    143:               if( outcome > 1 ) {  /* with both num and unit parts or only unit part */
                    144:                 if( u_p != NULL ) {
                    145:                   result = check_correct_unit(unit_str,u_p,&scale);
                    146:                 } else { /* what to do when no unit is specified but student entered a
                    147:                 unit? */
                    148:                   result = UNIT_NOTNEEDED;
                    149:                 }
                    150:               } else {
                    151:                 if( u_p != NULL ) {
                    152:                   result = NO_UNIT;
                    153:                 }
                    154:               }
                    155:   
                    156:   idx = 1;  ai = p->ans_list;
                    157:        while( (idx<cnt) && ( (result == EXACT_ANS) || (result == APPROX_ANS) ) ) {
                    158:          result =  capa_check_ans(ai,answers[idx]);
                    159:          ai = ai->ans_next; idx++;
                    160:        }
                    161:   if(num_answer==2)  printf("Answer:->%s [%s,%s] %s, ",p->answer,lower,upper,
                    162: 			    p->unit_str); 
                    163:       else  printf("Answer:->%s, ",lower);
                    164:   switch(p->ans_type) {
                    165:        case ANSWER_IS_INTEGER:   printf(" INTEGER,");
                    166:         break;
                    167:        case ANSWER_IS_FLOAT: 
                    168:         printf(" FLOAT format=%s, SIG=[%d,%d],",
                    169:           p->ans_fmt,p->sig_lbound,p->sig_ubound );
                    170:         break;
                    171:        case ANSWER_IS_STRING_CI: printf(" STRING C.I.,"); break;
                    172:        case ANSWER_IS_STRING_CS: printf(" STRING C.S.,"); break;
                    173:        case ANSWER_IS_CHOICE:    printf(" CHOICE,");      break;
                    174:    }
                    175:    printf(" WEIGHT=%d, TRIES=%d\n", p->weight,p->tries); fflush(stdout);
                    176:    if(p->ans_unit != NULL) {
                    177:         print_unit_t(p->ans_unit);  fflush(stdout);
                    178:    }

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