Thursday, November 1, 2012

So how's research?

I realized that I hadn't made a specific post about this awesome thing, so it is time! (It is also Friday, and I struggle to get much done on Fridays)

I was lucky enough to join a research group where a group of us graduates (about 6 of us who had completed our under-grad together) began our MScs at the same time. For those of you who dont know, MScs are rarely course based these days in South Africa. Instead, they are MScs by thesis and the thesis tends to be on the scale of a Phd (at least in our research group). 

At some stage, my good friend Christien and I were chatting about Masters and she concluded it would be a cool idea to meet once a week, to discuss our thesis then work on it for a few hours afterwards in the library. We discussed it with the gang, and we all concluded that although we probably wouldn't all be able to work on our thesis's at the same time, but it would certainly be beneficial to meet once a week to discuss problems, complain about supervisors and such. 

And that was the birth of M club. Every Monday night, us graduates meet at a different restaurant - fun and informal, order some good food and ask each person the question-that-must-not-be-asked "How is research?" and listen to and discuss each person's answer. In this way, we motivate each other to plow on through, share productivity tricks, how to communicate with one's supervisor and (because we are all a group of Computer Scientists) give advice solving the obstacles we have reached with our thesis. Just sometimes explaining your issues to other people makes things clearer as well as minimizes that feeling of not making any progress even though you work on it all the time. 

Everyone gets there chance to speak and everyone listens. 

Recently, we started with a primitive reward system - if you achieved something on your thesis (no matter how small) in the past week, you get a sweetie :) Silly, but effective. 

M Club has been one of the most enjoyable and beneficial part of the first year of my MSc (ours are traditionally 2 - 3 years long). And I advise any group of researchers to start their own M club ^_^ 

Thursday, October 18, 2012

SCRUMing my Thesis... Lets go!

My brain melted about 20 minutes ago, so I figured it was time for a post.

I had been contemplating it for a while, but I finally decided that this is what I needed to do:
SCRUM my thesis.

For those of you who dont know SCRUM, Scrum is a process used for agile software development. A project makes progress via a series of iterations known as Sprints, which are generally 2-4 weeks long. The planning of a spring is essential. SCRUM lends itself well to projects with rapidly changing or highly emergent requirements.

SCRUM is generally used in software development. Considering that I am a Computer Scientist, I figured this might even apply to a Scientific Thesis - particularly one in computer science where I have to code as well.

The main activities of SCRUM are as follows:

  1. A Sprint Product Meeting - list of tasks are created to be performed during the sprint.
  2. Daily Scrum Meeting: Every day, a daily SCRUM meeting is attended by all team members, for maximum 15 minutes - everybody stands. Members share what was worked on the prior day, what will be worked on today and any  obstacles that are decreasing progress. 
  3. Sprint review - performed at the end of a Scrum sprint. Functionality is demonstrated. The goal is to get feedback from the product owner. 
Those are the basics. Obviously there are some GLARING problems with this model in terms of thesis writing. In most (all) cases, we do not get to see our supervisor every day for 15 minutes in the morning.
In fact, often we don't get to see them every 2-4 weeks (although I try make a point of doing so, if at all possible). 

However, the main idea is quite useful. The sprint product meeting where one sits with oneself, and sets up a list of thesis related tasks to be performed during the sprint. If one can sit with one's supervisor at the beginning of each SCRUM, then how beneficial would that be?

Before I thought about using SCRUM, I would create lists too... all the time. But I found I either end up creating lists for too small an amount of time (multiple detailed things I needed to do in an hour) or a list for too large an amount of time ( like for the entire period of my thesis, where I end up wandering lost between items in the list). The SCRUM amount is for 2 - 4 weeks. Just the perfect amount of time. 

The daily scrum meeting is more like a sanity check for the thesis writer: "Yes, I did manage to do something constructive today - this is what it was. Today I will make more progress on this and these were the issues hindering me". I don't know about you, but I generally really really need a daily sanity check. 

As for the Sprint review - this is the little "reward" session where you can demonstrate to yourself what you have achieved during the sprint. And if possible, running what you have done by your supervisor at this point, WOULD be a useful feedback session. 

SCRUM has 2 important artifacts that are both relevant to thesis writing: 
- scrum product backlog - the complete list of functionality that remains to be added to the product (thesis)
- sprint backlog - a to do list for the sprint. 
- the burndown chart - shows the amount of work remaining

Luckily for me, my supervisor has agreed to have monthly group Thesis sessions (All his MSc and Phd students in one room). This will be the perforect opportunity for my Sprint product meeting and Sprint Review. 

The other awesome part about scrum are the useful tools that exist for the methodology. My favorite being the Kanban board. 


The kan ban board is a board with a few sections and some sticky notes. Each task is written down on a sticky note, including a duration, owner, deadline etc. The colours of the sticky notes can be related to priority of the job or the owner of the job. It has sections for tasks to be done, tasks that are in progress and tasks that are already done. Sounds brainless doesn't it? Turns out, the kanban board has become super popular in a large amount of domains where productivity is required. 

What is really fun, is that there exist free online versions, my favourite being Trello. Try it out. It has been a productivity saver for me. No more annoying lists, that get lost and spilt on. No sticky notes that fall off the screen or wall. And so far, it really seems to be helping my thesis.

This week I had an unofficial run of my first sprint. From next week I will set up a longer sprint and inform my supervisor what I am doing. I will be posting again about my progress. :)

I know this is a rushed post, but I wanted to get the jist of it on paper. I will update and go into more details soon. 
 







Tuesday, August 21, 2012

Make it Visual

My good friend Bobby was just here on holiday. He works in Denmark as a game programmer for IO Interactive but studied at UP and was our graphics lecturer at a stage. You may also know him from here:  http://takinginitiative.net/, if you have ever tried to learn to program in DirectX or attempted to program a Neural Network.

He decided to visit the lab (after a good morning of munching Cinnabon) where he insisted on looking at what I have programmed for the initial phase of my M.

As a re-cap, I am currently working with my swarm robotics algorithms in a 2D grid world, rather than a real-world simulator or actual robots. It has taken AGES to program it. Not because it was difficult to do, but because it is HORRIBLE to debug. I outputted the grid world is the form of a text-based grid. This was fine for the beginning stages of testing. I could check if each robot moved correctly. I thought about programming a nice graphical animation output but I had blocked out all my graphics training quite heavily for some reason and didn't want to go near it.

Anyway, so  after exclaiming how totally pointless and academic my thesis topic is (he tends to do things like that) and helping me figure out how to do a 3D histogram in office (not as easy as you'd think), Bobby said "Why are you using a histogram to do this? Make it visual". I told him I'd been avoiding programming some sort of proper visual output. He (having seen the state I managed to get myself in when I had last programmed my Honours graphics project) was nice enough to let me use a part of what he programmed for his thesis. His thesis was on path-finding in games and thus he also needed a little grid-world. Took about half an hour of stripping out the important stuff and merging it to with code and I had a little visualizer.

Immediately, I identified 4 or 5 issues occurring in my grid-world! Hopefully on my way to perfectly functioning abstract mining problem.

So my advice for this month is this: Make it Visual!

Wednesday, June 6, 2012

Stagnating at the familiar

The laboratory I work in is really great. We have top-notch pcs, two shiny screens each, a big white board that is always covered in scribbles (some that are useful, others for fun). Seated next to me and across from me are my two best friends, also working on research or lecturing or development. We have a really good view of Pretoria from the window and the lab is open plan, spacious, light and airy - unlike so many others. 

Outside our particular lab room is a round table, where us and a few members from the lab next door meet everyday for lunch of whatever we decided to buy or bring with. If we are bored, there is inevitably someone interesting and academic making coffee in the kitchen downstairs to chat to. 

This sounds like a fantastic space to work in... and don't get me wrong, most of the time it really is. Unfortunately, it is not conclusive to out-of-the-box research thinking! But why is that? Is it just THIS space? What is wrong with it? It certainly aids to all other types of work: preparing lectures and practicals, developing the research group's open-source AI library, and writing up papers. The lab promotes a calm, familiar, friendly and organised mindset - even if I do have my two best friends to chat to next to me.

The issue, I think, is in the fact that out of the box thinking requires a portion of slightly uncomfortable chaos - putting us in a position where we are forced out of our comfort zone into the realm of the unexplored. To really benefit from reading a paper and analysing its depths or coming up with new ideas or algorithms, I find the lab to be the WORST place to do it. It's as if the familiarity of the laboratory allows one to slip into the comfortable little box too easily and instead of thinking of broader ideas, I scramble around the bottom on the box like a hamster, searching for gourmet food on the corners of the cage. The fact is - the hamster isn't going to find it. Instead the hamster may end up on Facebook looking at funny images and commenting on unrelated posts. :P Despite the charm of the space, if I try to think critically and creatively in the lab, I CANT!

Solution I have discovered to be simple really. Get out the lab. In fact, don't only get out the lab - get out the entire goddamn building!!! Working at a University, one has the benefits of trees and grass with benches and tables. The university is big enough and I could choose a new place every day if I wanted to and it would be weeks before I would have to return to the same spot. 

I have found that once I am outside, my mind feels more open and in some ways more logical - as if I can generalize properly and thus see the bigger picture. I find that I can think more critically and new ideas come more naturally. Planning feels purposeful and progress is inevitable. 

Inside the lab, my stagnating research is a giant pressure, full of looming deadlines (that I have never realyl defined). In the lab, research is everything. Outside the lab, research is just a part of life - something that needs the inspiration from the rest of life to function - and what do you know?  the pressure dissipates, thus resulting in more creative thinking and quality ideas. 

So now everyday, I start out outside, under a tree or on a bench with paper and pen or some journal articles that need to be read and the important parts summarized. Best idea I have had yet




Thursday, May 3, 2012

At least there is progress

After some discussions with my supervisor, we concluded that the best way to approach my robotics thesis was to first of all: Ignore my robots entirely.

Although this is sad, because all I really want to do all day is play with robots, I found a fair amount of relief. I am still on my way of learning about how robots work. The basic movement, tracking, identification stuff is new and fresh and still rather untouched. Before I even get to developing a new algorithm for them, I thought I would have to go through the painstaking process of learning all the basic robotic stuff in detail. My issue with doing it this way, was that I felt that I may be wasting time, learning certain aspects about robotics that I didn't really need to know.

So my supervisor decided I should do it the other way around. Instead of starting with learning the back end of the robotics side, I should start working on the algorithm, in an ultra theoretical space - a 2D grid world. Model everything in the ultra simple 2D grid world, then take it down to robot simulation world, and then down to real robot world.

So I have been working on some ant cemetery algorithms in abstract world and they are kinda working to some degree. They still need some work certainly and although the world may be abstract, progress has become significantly more tangible. All I need to do now, is add the division of labour. Great.

I went to Ballito over the long weekend, which was a nice break. I unfortunately got ill on the way down there and so I am struggling to get back into the flow of things. I stress a little when I think how much time I am loosing. I need to just get on with it and function.

Next week I need to have division of labour. Something, anything - as long as it kinda works. Progress is required.

Thursday, April 5, 2012

Taking back Master's to Undergrad

We spend our entire lives: primary school, high-school and university using similar (if not identical) structures of learning. Although the difficulty increases, with an increase in tasks as you go, in general, the structure remains the same

Here are some of those tasks that we are used to:

Lectures/Classes - approximately 45 minute periods of learning something new.
  • Requires some preparation reading
  • Involves introductions, definitions, overviews of main techniques, and then detailed algorithms or examples of those techniques
  • Break between class or lectures to get to the next venue.
Practicals - approximately 3 to 5 hours (depending on the subject matter) giving one the chance to physically apply what one has learnt.
  • In Physics, it would be run an experiment demonstrating the physical laws, in computer science it is to program a working version of the topics and algorithms covered in class
  • Generally starts with a simple task, then follows with more difficult challenges.
Assignments - Take home things which last a few weeks, usually involving the theory, working out difficult examples, and providing new incite and critical discussion. Sometimes involving practical demonstrations and experiments.

Tests - whether a pop quiz or semester test or exam, tests are the most commonly used evaluation of assessments. These are usually set out with separate questions for each section (not always though) - testing everything from basic definitions, to techniques to actually formulating new models and solving new problems. A large amount of study (if you're doing it correctly ;)) goes into the bigger tests, while a pop quiz just requires listening and understanding basic topics covered in class and practicas.

Project - a large assignment generally at the end of the semester/term which evaluates a large quantity of the topics covered in the course - an accumulation of one's knowledge involving theoretical side as well as practical.

So... We do this our entire lives, until we get to postgrad. Up until this point, we have had our studies divided up into different types of learning and understanding for us. But at a postgrad level it all changes: One focus, One topic, One thesis, One final presentation - in absolute detail and (in general) entirely unguided.

For those of us who managed to fly through highschool and undergrad, following the method of evaluation prescribed to us, without a bother, often find the sudden change to a research master's to be difficult. There is no granularity of how to divide learning. Most of us just start reading, and start writing - totally unguided - jumping from beginning to end to middle, sitting lost among a pile of journal papers, with endless headaches and panic attacks.

Wouldn't it be beneficial to steal some of those things from undergrad, since we are so well accustomed to them and try to use them in our how we approach Masters? I have a few ideas how this could be done and intend to implement some of them.

Lets take lectures: 45 minutes period of learning something new - starting with the basic definition and overview then going into relative detail with a few techniques. I think think can be used to introduce oneself to a topic one has come across during research. Generally a quick search about the topic can often yield conference paper presentations , which will introduce one to the topic. Then a look at existing textbooks and literature reviews for a few more ideas.

Once one has absorbed the knowledge in a lecture, it is probably time to implement a bit of what you have learnt. Take 3 hours, write up a mini-specification of what you are going to try do and apply what you have learnt. If its calculations, then try to redo those calculations, try program that robot or repeat the experiment. If you get stuck, the research to solve those problems may undoubtedly prove useful in your thesis.

Assignments seem to be akin to Chapters in one's thesis. Perhaps posing one's chapter in assignment form may allow for guidance. It also makes it less intimidating thinking of a thesis chapter as merely an assignment. It is also good to remember that even in the literature review, critical discussion and analysis is required - as it would be in an assignment.

What about tests? Where do they fit in? Well, regular meetings with ones supervisor are important. At these meetings one should be able to explain the topics that have been tackled so far. A good supervisor will ask for a presentation and ask you to answer questions about what you understand and what you have done. Is this like the tests we used to receive in undergrad? Not entirely, as often the "marker" has no idea what the topic is about. But it may be useful to formulate your main thesis points as questions and be able to answer them without looking at notes - a technique often used for studying for tests. This way one can solidify some of the more difficult topics in the thesis.

Projects - well... the project is the thesis. The accumulation of one's knowledge learnt during the duration of the course. Luckily one can use all the "assignments" that one has previously done, make changes, add some introductions and extra experiments... and voila - THESIS!! Ok....so its not that simple, but I think it's a nice analogy.

Reading through what I have just written, I realized that in my own way, I was doing this sort of thing anyways... but in an unstructured unknowing fashion. I think, just on a mental level, it is good to sometimes think of a chapter as simply an assignment and as little problems and experiments as practicals. It should mentally bring the entire vast and frightening idea of writing a thesis into something we are acquainted with and have (for all you cum laude/honours students) mastered.

Happy research ;)

Thesis Stand-still

So I've recently become addicted to the following blog: http://thethesiswhisperer.wordpress.com/. It may have just saved my life. Dr Inger Mewburn is a genius. The blog covers everything on getting things done, procrastination and writing techniques to your supervisor relationship to how to handle one's first conference. Most importantly it is far more approachable than large text books on how to write one's thesis.

So one of the things that is suggested in the blog (and just about everywhere else), is to maintain a blog oneself. Well I clearly have a blog, but it has never been maintained and it has rarely been beneficial to me. Before hand I wanted to write things to entertain others. Now I hope my blog takes on a more functional role: To monitor and quantify my progress with my thesis - and hopefully allow me to track where I am and not get lost in the ultimate "bigness" of it.

So... (the ultimate unspoken question of a researcher) how's research?

Well, in the first week of the year I wrote up my master's proposal. It was detailed, took me about 3 days and I felt very good about it. Not only that, but my supervisor was very impressed by it. In my proposal I had a very detailed (and unique) schedule. I chose, rather than schedule deadlines, to estimate the number of days each task would take me - and thus make it more flexible to sick days and such. Each day was only 5 hours (to cater for the fact I also have part-time lecturing duties). From my estimation, the thesis would take me about a year and 3 months to complete if I was diligent.

Unfortunately, although I created this wonderful schedule, I am afraid to look at it. I know for a fact I have lost about 30 days... an important 30 days or so of my thesis - most likely more. This is the result of a conference paper I had to publish, general getting settled into my new lifestyle as a lecturer and master's student and university delays - such as getting the laboratory setup (which is still underway). So now I have a schedule I don't look at.

In my proposal, I had written up my problem statement as far as I knew how it went. It felt valid enough - even though I knew it required a few more consultation with mining experts (and yes, my master's thesis has to do with the use of swarm robotics in a gold mining context) as well as a far amount of reading about swarm robotics and foraging.

So after a month of trying to nail down "What problem am I actually trying to solve?" - I've spoken to mining experts, geologists, looked at diagrams, read loads of papers on swarm robotics and foraging, I'd thought I'd happily written up my problem. Until the next day I read over it again and was full of doubts. I doubt the purpose behind my experiments. I doubt if I am really researching anything new. I feel so insecure and overwhelmed that I have reached a complete stand still (hence the emergency call for action to write a blog and pray for progress ). I'm too afraid to look at the literature. As The Thesis Whisperer so well described, in the blog post Reading like a mongrel, us students end up in a "reading death spiral". I'm at the point where I fear to look at another journal paper again, just to have its facts strewn around my brain in a big tornado.

I had "read" through tons and tons of material. Or so I had thought. I looked back on what I had read and I had simply made my way through about a total of 6 articles and skimmed through about another 6. And in the process I have increased my reading list by about 60 more papers I need to read. And it took me 2 months to get through those 6.

On the plus side, I have written up a fair amount of what I have read, but none of it feels good enough and none of it reads properly (in my opinion).

So, not only do I not look at my schedule because I know I'm so behind, I'm refusing to look at my problem and I fear looking at my overwhelming reading list or everything I have written (and if I do look and what I have written I spend ages panicking over every sentence).

So what was left? My simulation software which I have been slowly learning and my robots. So cute. Bless their cotton socks! However, after running a few existing simulations and running those simulations on the real robots (and trying to understand existing example code) I realized the depth I'm wading through NOT HAVING EVER DONE a course in robotics. I thought I'd be able to catch on with only the bits I need, but now I have come to think that I actually need a full introductory course on normal robotics - messing around with only a single one of my robots. This is of course a very frightening prospect.

So out of fear I am doing nothing. I am currently at home (it's the Easter holidays - which I had scheduled at least 3 double days (5 hours x 2 per day) of work. ) and I am doing bleeding nothing. NAAAATHING. I have instead watched a ton of detective stories with my mother and slept late and read fiction books about sociopaths. I felt ill for most of it, migraines and the such - but I have a feeling it is all in my head. I am behind on lecturing work and I have no car (it broke down - 3 weeks ago and is still not ready). As a result of avoiding my M, I have avoided EVERYTHING. No work, no Master's, no band practice, no following up of car admin. I managed to complete a website for my boyfriend's mum and I have joined a new musical project in the mean-time - ENTIRELY unrelated stuff to the general functioning of my life and progress towards my life goals.

The weird thing is that it probably isn't as bad as I think it is. Although I feel totally lost, I probably have made a fair amount of progress. The reading I have made was most likely the most important literature in the field, my problem is probably too specific - I may be able to lighten the load and make it less specific. I know I have a bit more reading I need to do for my problem (probably only 2 more important papers, rather than 20 papers). And all the things I have already written are probably entirely acceptable, with only a small amount of editing required. I will probably find the basic robotic syllabus entirely doable in a week or two and all the lecturing work and admin I am behind on, will probably be over in an hour or two on Tuesday. And I feel like my supervisor doesn't know what I'm doing, but my co-supervisor should get involved soon and he will know. As for being behind... A month behind, means an extra month - just an extra month. It will result in an extra few years of thesis doing. Stand back and quantify. It just ain't that bad.

So where to from here:
  1. Look at my schedule - determine how behind I am (in exact 5 hour days) - if I determine that I am 2 months behind, I will accept that as okay and move on. Because it is okay. It really is
  2. I will go read a single paper - the one that is pressing on my mind the most. Just one and it will be okay.
  3. I will contact my supervisor and demand he gets my promised co-supervisor officially involved
  4. I will look into a basic robotics syllabus.
I am luckily part of a very awesome group which we have christened: Master's Club (or M. Club for short). It's just a group of Computer Science master's students - a group of friends really. We meet every Monday night, go get some food, and we ask that all time horrible question: How is research? I have found some solace and companionship with my fellow M. club member - whether it is complaining about supervisors or topics - I am not alone.