I got loads of work done, as you can see. I love technology, but sometimes you have to get the stationery out and do it the old-fashioned way. Besides, who doesn’t love stationery, amiright?
I got loads of work done, as you can see. I love technology, but sometimes you have to get the stationery out and do it the old-fashioned way. Besides, who doesn’t love stationery, amiright?
I thought I’d have a quick look at the difference using a lemmatiser instead of a snowball stemmer makes to clustering using k-means and just my group of labelled blogs. Here’s the silhouette plot based on groups:
Remember, the closer the score is to 0, the more statistically likely it is that the blog could be in a different category.
Here’s the same data, this time with the number of categories set to 6, but grouped according to the category the algorithm has calculated as being the most appropriate.
There appear to be blogs that, at least according the k-means, are in a category with a variety of different labels. The algorithm isn’t learning anything, though, it’s just making decisions based on the scores of tokens in the blog, nothing else. I simply wanted to see if lemmatising the blogs instead of stemming made much of a difference.
Here’s the same parameters as above, but using the snowball stemmer as before:
And side-by-side (Snowballing / Lemmatising):
The answer is: overall, not that I can see.
I’ve already said that I wasn’t sure if ‘behaviour’ and ‘feedback, assessment & marking’ (FAM) should be separate categories, and some further analysis has convinced me that I need to drop them both.
One of the many useful features of Orange is the ‘concordance’ app, shown on the left in my workflow. It allows for a sub-set of documents to be extracted based on a key word. I chose to have a closer look at ‘marking’. As you can see from the screenshot below, the app will show you your chosen word as it appears with a selected number of words either side. The default is 5, which I stuck with.
The white and blue bands represent individual documents, which can then be selected and viewed using the ‘corpus viewer’ app. I browsed through several, deciding that they should best be classed as ‘professional concern’, ‘positioning’, ‘soapboxing’ or ‘reflective practice’. I selected ‘assessment’ and ‘feedback’ as alternatives to ‘marking’, but a closer look at a few of them suggested the same. I went back to the posts I’d originally classified as ‘FAM’ and reviewed them, and decided I could easily re-categorise them too.
Here’s an example of a post containing the key word ‘marking’:
Lesson 3 (previous post) had seen my Head of Department sit in with a year 7 group to look at ideas he could apply. His key observation- the need for a grounding in the terminology and symbols see first lesson which has been shared as a flipchart with the department. We move on apace to lesson 4 where pupils start to be involved in setting their own marking criteria linked to SOLO. Still no hexagons, a key aspect in the sequence of lessons now being blogged about by Paul Berry (see previous post). Linking activities between lessons has become very overt in this sequence of lessons. Our starter was a return to annotate the pics from last lesson. Most recall was at a uni-structural stage and some discussion ensued see Year 7 example below. The focus today was to be on marking information onto maps accurately. We have decided as a department to return to more traditional mapping skills as many of our pupils have a lack of sense of place. So we returned to the textbook (Foundations) and a copy of the main map was shared with the class. It limits the amount of information, and hopefully this will develop a stronger use of maps in future work. Before starting though we needed to determine a SOLO based marking criteria which allowed peer marking. The pupils in year 7 in particular had clear ideas already about this. We identified how they would mark and initial and day the marking as Sirdoes so it was clear who the peer marker was. The map task was time limited. I use a variety of flash based timers which I found online- the novelty value of how the timer will end can be a distraction at the end of a task but does promote pupil interest. I circulated the room giving prompts on how seas could include other terms e.g. Channel and ocean. The work rate was very encouraging. The peer marking was successful and invoked quite a lot of table based discussions. We started to identify the idea of feed forward feedback to allow improvement of future pieces of work. Lesson 4 with years 8 and 9 included a return to the SOLO symbols image sheet and sharing recall. Also a key facts based table quiz was used to promote teamwork and remind how we already know a range of facts. These quizzes provided a good opportunity to use the interactive nature of the board to match answers to locations. Writing to compare features in different locations became the focus for Years 8 and 9. We recapped the use of directions in Relational answers. Headings were provided and I circulated to support and/ or prompt as required. Now I need to identify opportunities to use HOT maps as recommended by others including Lucie Golton, John Sayers et al. from Twitters growing #SOLO community. Also the mighty hexagons and linking facts need to enter the arena. Please if commenting, which image size works better as lesson 3 or lesson 4?
This is clearly ‘reflective practice’, as the practitioner is clearly commenting on the successes of using the SOLO taxonomy model with a variety of year groups.
If I have time, it may well be more appropriate to interrogate a particular category to visualise what sub-categories may emerge e.g. I would expect ‘professional concern’ to encompass workload, marking, growth mindset, flipped learning etc. , areas of concern that are ‘product’ as opposed to ‘process’.
Here’s a little thing I wrote for the Web Science Institute over at the University of Southampton….. http://blog.soton.ac.uk/wsi/ben-williamson-seminar-educational-research-web-science/
One of the most important things to do when working with a lot of data is to reduce the dimensionality of that data as far as possible. When the data you are working with is text, this is done by reducing the number of words used in the corpus without compromising the meaning of the text.
One of the most fascinating things about language was discovered by G K Zipf in 1935¹: that the most frequently used words in (the English) language are actually few in number, and obey a ‘power law’. The most frequently used word occurs twice as often as the next most frequently word, three times as often as the third, and so on. Zipf’s law forms a curve like this:
The distribution seems to apply to languages other than English, and it’s been tested many times, including using the text of, for example, novels. It seems we humans are very happy to come up with a rich and varied lexography, but then rely on just a few to communicate with each other. This makes perfect sense as far as I can see: I say I live on a boat, gets the essentials across (a thing that floats, a bit of an alternative lifestyle, how cool am I? etc.) because were I to say I live on a lifeboat, I then have to explain that it’s like one of the fully-enclosed ones you see hanging from the side of cruise ships, not the open Titanic-style ones most people would imagine.
“For language in particular, any such account of the Zipf’s law provides a psychological theory about what must be occurring in the minds of language users. Is there a multiplicative stochastic process at play? Communicative optimization? Preferential reuse of certain forms?” (Piantadosi, 2014)
A recent paper by Piantadosi² reviewed some of the research on word frequency distributions, and concluded that, although Zipf’s law holds broadly true, there are other models that provide a more reliable picture of word frequency which depend on the corpus selected. Referring to a paper by another researcher, he writes “Baayen finds, with a quantitative model comparison, that which model is best depends on which corpus is examined. For instance, the log-normal model is best for the text The Hound of the Baskervilles, but the Yule–Simon model is best for Alice in Wonderland.”
I’m not a mathematician, but that broadly translates as ‘there are different ways of calculating word frequency, you pays your money you takes your choice”. Piantadosi then goes on to explain the problem with Zipf’s law: it doesn’t take account of the fact that some words may occur more frequently that others purely by chance, giving the illusion of an underlying structure where none may exist. He then goes on to suggests a way to overcome this problem, which is to use two independent corpora, or split a corpora in half and then test word frequency distribution in each. He then tests a range of models, and concludes that the “…distribution in language is only near-Zipfian.” and concludes “Therefore, comparisons between simple models will inevitably be between alternatives that are both “wrong.” “.
Semantics also has a strong influence on word frequency. Piantadosi cites a study³ that compared 17 languages across six language families and concluded that simple words are used with greater frequency in all of them, and result in a near-Zipfian model. More importantly for my project, he notes that other studies indicate that word frequencies are domain-dependent. Piantadosi’s paper is long and presents a very thorough review of research relating to Zipf’s law, but the main point is that it does exist, even though why it should be so is still unclear. The next question is should the most frequently used words from a particular domain also be removed?
As I mentioned before, research has already established that it’s worth removing (at least as far as English is concerned) a selection of words. Once that’s done, which are the most frequently used words in my data? I used Orange is to split my data in half and generate three word clouds based on the same parameters, and observe the result. Of course I’m not measuring the distribution of words, I’m just doing a basic word count and then displaying the results, but it’s a start. First, here’s my workflow:
I’ve shuffled (randomised) my corpus, taken a training sample of 25%, and then split this again into two equal samples. Each of these has been pre-processed using the following parameters:
The stop word set is the extended set of ‘standard’ stop words used by Scikit that I referred to in my previous post, plus a few extra things to try and get rid of some of the rubbish that appears.
The word clouds for the full set, and each separate sample, look like this:
The graph below plots the frequency with which the top 500 words occur.
So, I can conclude that based on word counts, each of my samples is similar to each other, and to the total (sampled) corpus. This is good.
So, should I remove the most frequently used words, and if so, how many? Taking the most frequently used words across each set, and calculating the average for each word, gives me a list as follows:
And if I take them out, the word cloud (based on the entire 25% set) looks like this:
Which leads me to think I should take ‘learning’ and ‘teaching’ out as well. It’s also interesting that the word ‘pupil’ has cropped up here – I wonder how many teachers still talk about pupils rather than students? Of course, this data set contains blogs that may be a few years old, and/or be written by bloggers who prefer the term. Who knows? In fact, Orange can tell me. The ‘concordance’ widget, when connected to the bag of words, tells me that ‘pupil’ is used in 64 rows (blogs) and will show me a snippet of the sentence.
It’s actually used a total of 121 times, and looking at the context I’m not convinced it adds value in terms of helping me with my ultimate goal, which is clustering blog posts by topic, so it’s probably worth mentioning here that the words used the least often are going to be the most numerically relevant when it comes to grouping blogs by topic.
Could I take out some more? This is a big question. I don’t want to remove so many words that the data becomes difficult to cluster. Think of this as searching the blog posts using key words, much as you would when you search Google. Where, as a teacher, you might want to search ‘curriculum’, you might be more interesting in results that discuss ‘teaching (the) curriculum’ rather than those that cover ‘designing (the) curriculum’. If ‘teaching’ has already been removed, how will you find what you’re looking for? Alternatively, does it matter so long as search returns everything that contains the word ‘curriculum’? You may be more interested in searching for ‘curriculum’ differentiating by key stage. For my purposes, I think I’d be happy with a cluster labelled ‘curriculum’ that covered all aspects of the topic. I’ll be able to judge when I see some actual clusters emerge, and have the chance to examine them more closely. Which, incidentally, the concordance widget tells me is used in 93 blogs, and appears 147 times. That’s more than ‘pupil’, but because of my specialised domain knowledge I judge to be more important to the corpus.
Which is also a good example of researcher bias.
Today, while my laptop was employed scraping Edu-blog posts from 2011, I decided to play around with Orange. This is one of the suite of tools offered by Anaconda which I use for all my programming needs.
The lovely thing about Orange is that it allows you to build a visual workflow, while all the actual work in the form of the lines and lines of code is done behind the scenes. You have to select some parameters, which can be tricky, but all the heavy lifting is done for you.
This was my workflow today, although this was about halfway through so by the time I’d finished, there were a few more things there. Still, it’s enough to show you how it works.
My corpus is a sample of 9,262 blog posts gathered last year. Originally, there were over 11,000 posts but they’ve been whittled down by virtue of having no content, having content that had been broken up across several rows in the spreadsheet, or being duplicates. I also deleted a few that simply weren’t appropriate, usually because they were written by educational consultants, as means to sell something other tangible such as books or software, or political in some way such as blogs written for one of the teaching unions. What I’ve tried to do is identify blog URLs that contain posts by individuals, preferably but not exclusively teachers, with a professional interest in education and writing from an individual point of view. This hasn’t been easy, and I’m certain that when I have the full set of data (which will contain many tens of thousands of blog posts) some less than ideal ones will have crept in, but that’s one of the many drawbacks of dealing with BIG DATA: it’s simply too big to audit.
You may recall that the point of all this is to classify as much as the Edu-blogosphere as I possibly can – to see what Edu-professionals talk about, and to see if the topics they discuss change over time. Is there any correlation between, for example, Michael Gove being appointed Secretary of State for Education and posts discussing his influence? We’ll see. First of all, I have to try and cluster the posts into groups according to content. I’ve been doing this already, and developed a methodology. However, while I’m still gathering data, and labelling a set of ‘training data’ (of which more in a future blog post) I’ve been experimenting with a different set of tools.
So, here’s my first step using Orange. Open the corpus, shuffle (randomise) the rows, and take a sample of 25% for further analysis, which equates to 2316 documents or rows.
The ‘corpus viewer’ icons along the top of the workflow shown above mean that I can see the corpus at each stage of the process. This is a glimpse of the second one, after shuffling. Double-clicking any of the icons brings up a view of the output, as well as the various options available for selection.
The next few steps are will give me an insight into the data, and already there are a series of decisions to make. I’m only interested in pre-processing the content of each blog post. The text has to be broken up into separate words, or ‘tokens’, punctuation removed, plus any URLs that are embedded in the text. In addition, other characters such as /?&* or whatever are also stripped out. So far, so straightforward as this screen grab shows:
Words can also be stemmed or lemmatised (see above).
“Stemming usually refers to a crude heuristic process that chops off the ends of words in the hope of achieving this goal correctly most of the time, and often includes the removal of derivational affixes. Lemmatization usually refers to doing things properly with the use of a vocabulary and morphological analysis of words, normally aiming to remove inflectional endings only and to return the base or dictionary form of a word, which is known as the lemma . If confronted with the token saw, stemming might return just s, whereas lemmatization would attempt to return either see or saw depending on whether the use of the token was as a verb or a noun. ” The Stanford Natural Language Processing Group
If I lammatise the text as is, I get this lovely word cloud. BTW, it’s just a coincidence that ‘example’ is in red.
As you would expect from blogs written by teachers, words like ‘student’ and ‘teacher’ feature heavily. If I use the snowball stemmer (which is basically an efficient algorithm for stemming, explained here) then the word cloud looks like this:
Both of these word clouds are also generated from the corpus after a series of words know as ‘stop words’ are removed. These words are the ones we often use most frequently, but add little value to a text; words such as ‘the’, ‘is’, ‘at’ or ‘which’. There is no agreed standard, although most algorithms use the list provided by the Natural Language Toolkit (NLTK). I’ve chosen to use the list provided by Scikit-Learn, a handy module providing lots of useful algorithms. Their list is slightly longer. The use of stop words is well researched and recommended to reduce the number of unique tokens (words) in the data, otherwise referred to by computer scientists as dimensionality reduction. I also added some other nonesense that I noticed when I was preprocessing this data earlier in the year- phrases like ‘twitterfacebooklike’ – so in the end I created my own list combining the ‘standard’ words and the *rap, and copied them into a text file. This is referred to as ‘NY17stopwordsOrange.txt’ in the screenshot below.
My next big question, though, is what happens if I add to the list some of the words that are most frequently used in my data set – words like ‘teach’, ‘student’, ‘pupil’, ‘year’? So I added these words to the list: student, school, teacher, work, year, use, pupil, time, teach, learn, use. This is the result, using the stemmer:
There is research to suggest that creating a bespoke list of stop words that is domain-specific is worth doing as a step before going on to try and classify a set of documents. It’s the least-used words in the corpus that are arguably the most interesting and valuable. I’ll explore this some more in the next post, along with the following steps in the workflow.
A few weeks ago, I was asked if I’d be interested in running a workshop for year 12 students as part of the ESRC* Festival of Social Science. This was organised as part of the University of Southampton’s Learn with US (Outreach) programme which I’d quite like to do more work with in the future. The theme of the workshops was looking at how technology, and mobile phones and devices in particular, are being used in social science research. As part of my research, I’m looking at networks and network (or graph) theory, so I thought I could have a go at teaching that. I find networks fascinating, AND I knew I had some excellent resources that could be adapted for use with students, so why not?
I’m also really keen on promoting the idea that a) computer science is for women too, b) web science is an excellent way of combining the social sciences with computer science, and c) age is no barrier. A teacher who was accompanying a group of students also told me that, as well as being a role model for girls, I was also showing students why being able to write code was so important as it could have a real practical benefit.
I really miss being in the classroom. Why will be the subject of another blog post, but suffice to say that, for me, there’s something exhilarating about putting things together (in this case, a PowerPoint and some handouts to guide students the through some actual hands-on work) so that I can deliver knowledge in a way that I hope is interesting. I like being in charge, in my own space, directing my own personal show. It’s also a really good chance for me to consolidate my own learning, which is one of the benefits of teaching.
The students were, of course, excellent. They were made up of groups from several schools – one or two local, others from further afield. It was really interesting to observe how different as groups they were from one another, which I assume reflects both the socio-economic background they were drawn from (and is almost certainly directly related to the catchment area of the school) and the ethos of the school itself. The interactions between them, them and their teachers, and with me was markedly different from session to session. Having only taught in one school before (and not really being detached enough to just observe), it was a fascinating experience for me. It was, though, overwhelmingly positive and I thoroughly enjoyed it!
I’m sure they left with a positive view of the University of Southampton, and I hope they were inspired by my workshop, and the others they attended.
By the way, the resources I used were borrowed and adapted from the ‘Power of Social Networks’ MOOC** that has just finished on Futurelearn. It’ll be repeated though, if you fancy a dabble into the world of social networks.
*Economic & Social Research Council
**Massive Open Online Course
PhD researcher, writer and traveler.
Sharing all the education blogs by people in (or from) the UK
League of Legends, Video Games, Sociology, and the PhD process
Lively Commentary on Canadian Education
Abby Whitmarsh is studying for a PhD in Web Science at Southampton University DTC
Ramblings in a fixed society :0)
My Irrational Life
Music. Consumption. Algorithmic Personalisation.
"The reasoners are like spiders who make cobwebs out of their own substance" Francis Bacon. This blog is about educational research. The quote is appropriate. Views are my own and do not represent any organisation. Follow @websofsubstance
Teaching in British schools