Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
C
crowdsourcehinter
Overview
Overview
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
OpenEdx
crowdsourcehinter
Commits
b77229fb
Commit
b77229fb
authored
Aug 21, 2014
by
Sola
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
added all to new branch, with .gitignore
parent
a2269b41
Hide whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
46 additions
and
18 deletions
+46
-18
.gitignore
+6
-0
.gitignore~
+0
-0
crowdxblock/crowdxblock.py~
+40
-18
No files found.
.gitignore
0 → 100644
View file @
b77229fb
*.py~
*.md~
*.pyc
*.js~
*.html~
*.css~
.gitignore~
0 → 100644
View file @
b77229fb
crowdxblock/crowdxblock.py~
View file @
b77229fb
# pylint: disable=line-too-long
# pylint: disable=unused-argument
import pkg_resources
import ast
import logging
import operator
import pkg_resources
import random
import ast
from xblock.core import XBlock
from xblock.fields import Scope, Dict, List
...
...
@@ -18,7 +19,7 @@ class CrowdXBlock(XBlock):
that specifically address their mistake. Additionally, the hints that this Xblock shows
are created by the students themselves. This doc string will probably be edited later.
"""
hint_database = Dict(default={
"guess": {"hint": 1
}}, scope=Scope.user_state_summary)
hint_database = Dict(default={
: {
}}, scope=Scope.user_state_summary)
# database of hints. hints are stored as such: {"incorrect_answer": {"hint": rating}}. each key (incorrect answer)
# has a corresponding dictionary (in which hints are keys and the hints' ratings are the values).
HintsToUse = Dict({}, scope=Scope.user_state)
...
...
@@ -27,7 +28,7 @@ class CrowdXBlock(XBlock):
WrongAnswers = List([], scope=Scope.user_state)
# this is a list of incorrect answer submissions made by the student. this list is mostly used for
# feedback, to find which incorrect answer's hint a student voted on.
DefaultHints = Dict(default={
"default hint 1": 2, "default hint 2": 1, "default hint 3": 1
}, scope=Scope.content)
DefaultHints = Dict(default={}, scope=Scope.content)
# a dictionary of default hints. default hints will be shown to students when there are no matches with the
# student's incorrect answer within the hint_database dictionary (i.e. no students have made hints for the
# particular incorrect answer)
...
...
@@ -39,14 +40,14 @@ class CrowdXBlock(XBlock):
# this list is used to prevent students from voting multiple times on the same hint during the feedback stage.
# i believe this will also prevent students from voting again on a particular hint if they were to return to
# a particular problem later
Flagged = Dict(default={
"bad_hint": 1, "other_bad_hint": 4, "another_bad_hint": 3
}, scope=Scope.user_state_summary)
Flagged = Dict(default={}, scope=Scope.user_state_summary)
# this is a dictionary of hints that have been flagged. the keys represent the incorrect answer submission, and the
# values are the hints the corresponding hints. even if a hint is flagged, if the hint shows up for a different
# incorrect answer, i believe that the hint will still be able to show for a student
def student_view(self, context=None):
"""
Student_view docstring. May be edited later. This is a placeholder for now.
This function defines which files to access when a student views this xblock.
"""
html = self.resource_string("static/html/crowdxblock.html")
frag = Fragment(html.format(self=self))
...
...
@@ -57,7 +58,8 @@ class CrowdXBlock(XBlock):
def studio_view(self, context=None):
"""
Studio_view docstring. This is also a place holder.
This function defines which files to access when an instructor views this xblock through the
studio view (and click "edit"). The only difference from student_view is the html script.
"""
html = self.resource_string("static/html/crowdxblockstudio.html")
frag = Fragment(html.format(self=self))
...
...
@@ -68,7 +70,7 @@ class CrowdXBlock(XBlock):
def resource_string(self, path):
"""
This
is also a place holder docstring.
This
function is used to get the path of static resources.
"""
data = pkg_resources.resource_string(__name__, path)
return data.decode("utf8")
...
...
@@ -81,11 +83,14 @@ class CrowdXBlock(XBlock):
a section
"""
remove_list = []
# a list is used to systematically remove all key/values from a dictionary.
# there may be a much cleaner way to do this but I could not find one very easily.
# This whole function will probably be removed if scopes are corrected later.
for used_hints in self.Used:
remove_list.append(used_hints)
for items in remove_list:
self.Used.remove(items)
remove_list
.
= []
remove_list = []
for wrong_answers in self.WrongAnswers:
remove_list.append(wrong_answers)
for items in remove_list:
...
...
@@ -108,33 +113,44 @@ class CrowdXBlock(XBlock):
or 'Sorry, there are no more hints for this answer.' if no more hints exist
"""
answer = str(data["submittedanswer"])
answer = answer.lower()
found
eq
= 0
answer = answer.lower()
# for analyzing the student input string I make it lower case.
found
_equal_sign
= 0
hints_used = 0
# the string returned by the event problem_graded is very messy and is different
# for each problem, but after all of the numbers/letters there is an equal sign, after which the
# student's input is shown. I use the function below to remove everything before the first equal
# sign and only take the student's actual input.
if "=" in answer:
if found
eq
== 0:
found
eq
= 1
if found
_equal_sign
== 0:
found
_equal_sign
= 1
eqplace = answer.index("=") + 1
answer = answer[eqplace:]
self.find_hints(answer)
# add hints to the self.HintsToUse dictionary. Will likely be replaced
# soon by simply looking within the self.hint_database for hints.
if str(answer) not in self.hint_database:
# add incorrect answer to hint_database if no precedent exists
self.hint_database[str(answer)] = {}
self.HintsToUse.clear()
self.HintsToUse.update(self.DefaultHints)
if max(self.HintsToUse.iteritems(), key=operator.itemgetter(1))[0] not in self.Used:
# choose highest rated hint for the incorrect answer
if max(self.HintsToUse.iteritems(), key=operator.itemgetter(1))[0] not in self.Flagged.keys():
self.Used.append(max(self.HintsToUse.iteritems(), key=operator.itemgetter(1))[0])
return {'HintsToUse': max(self.HintsToUse.iteritems(), key=operator.itemgetter(1))[0]}
else:
# choose another random hint for the answer.
not_used = random.choice(self.HintsToUse.keys())
for used_hints in self.Used:
if used_hints in self.HintsToUse.keys():
hints_used += 1
if str(len(self.HintsToUse)) > str(hints_used):
while not_used in self.Used:
# loop through hints to ensure no hint is shown twice
while not_used in self.Flagged.keys():
not_used = random.choice(self.HintsToUse.keys())
else:
# if there are no more hints left in either the database or defaults
self.Used.append(str("There are no hints for" + " " + answer))
return {'HintsToUse': "Sorry, there are no more hints for this answer."}
self.Used.append(not_used)
...
...
@@ -150,17 +166,20 @@ class CrowdXBlock(XBlock):
"""
hints_exist = 0
isflagged = []
self.WrongAnswers.append(str(answer))
self.WrongAnswers.append(str(answer))
# add the student's input to the temporary list, for later use
for answer_keys in self.hint_database:
temphints = str(self.hint_database[str(answer_keys)])
# look through answer keys to find a match with the student's answer, and add
# the hints that exist for said answer into the HintsToUse dict.
hints = str(self.hint_database[str(answer_keys)])
if str(answer_keys) == str(answer):
self.HintsToUse.clear()
self.HintsToUse.update(ast.literal_eval(
temp
hints))
self.HintsToUse.update(ast.literal_eval(hints))
for hint_keys in self.HintsToUse:
for flagged_keys in self.Flagged:
if str(hint_keys) == str(flagged_keys):
isflagged.append(hint_keys)
for flagged_keys in isflagged:
# remove flagged keys from the HintsToUse
del self.HintsToUse[flagged_keys]
for answer_keys in self.HintsToUse:
if answer_keys not in self.Used:
...
...
@@ -180,16 +199,19 @@ class CrowdXBlock(XBlock):
more random hints that exist for an incorrect answer in the hint_database
"""
feedback_data = {}
feedbacklist = []
# feedback_data is a dictionary of hints (or lack thereof) used for a
# specific answer, as well as 2 other random hints that exist for each answer
# that were not used. The keys are the used hints, the values are the
# corresponding incorrect answer
number_of_hints = 0
if len(self.WrongAnswers) == 0:
return
else:
for index in range(0, len(self.Used)):
# each index is a hint that was used, in order of usage
for answer_keys in self.hint_database:
if str(self.Used[index]) in self.hint_database[str(answer_keys)]:
feedback_data[str(self.Used[index])] = str(self.WrongAnswers[index])
feedbacklist.append(str(self.Used[index]))
for answer_keys in self.hint_database:
if str(answer_keys) == str(self.WrongAnswers[index]):
if str(len(self.hint_database[str(answer_keys)])) != str(0):
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment