ReCompute with Umar Suleman & Sarfraz Raza | How to Teach Programming Fundamentals - Success Stories | Podcast # 6

Both our guests in this podcast are Computer Science (CS) university teachers, and both have their own, unique, unconventional approach to teaching introductory programming courses. We ask them why they felt universities in Pakistan are not producing the quality of graduates they could, and why conventional teaching approach in most Pakistani Universities was probably not fulfilling its purpose. We then explore their teaching methodology in some detail, getting down to the level of specifics about teaching in a CS classroom that we have never been to before in our podcasts. We hope both CS teachers and students benefit from listening to our guests.

Generally, the industry’s standpoint is that computer science programs in Pakistan aren’t producing the kind of graduates that it requires. Is that our fundamental problem?

Umar Suleman (US) The problem is real. There are about 10,000 new jobs in the software industry per annum, and there are about 20,000 graduates being produced, but at max about 1000 of them are employable. This is a deficit, but also simultaneously, a great opportunity for us, the educators.

Are most of these 1000 employable graduates concentrated in a handful of universities or spread around uniformly? If concentrated, then what could be the reason for that?

US They are concentrated, and the reason is that in those universities the traditional education or educationist-first principle is relatively still intact. Ideally, if you want to address the education crisis in Pakistan, one recipe is that the teachers in private universities should be given at least a semblance of respect that the owners of the universities currently have. For instance, when the owner solves a problem by bending or breaking the stated rules, the way he is praised for thinking outside the box, if the same attitude is meted to teachers, then it would be a teacher’s or education-first institute. The over-emphasis on research, at the cost of teaching is also a sign that institutional priority isn’t education-first.

Should there be some universities that should focus more on research and some on teaching?

US For me, this is a premature question to ask at this stage, in terms of our cultural progression. First comes a new body of knowledge always, for instance once upon a time it was the fundamental knowledge around metallurgy, then comes the scale of skillful individuals within the culture that gives birth to genuine money-making industries, and once those genuine industries start facing genuine issues, however small their problems might be, the culture needs to have its best brains ready for this stage’s problem solving. This does not mean that this is a strictly linear model and that there are no exceptions to it. At the more mature stage of growth, the civilization needs to have pure research-based universities, but before that happens, the best brains of a culture ought to be given a respectful, dignified home within the current universities.

Let’s take Sarfraz onboard as well, before we head towards potential solutions, as to what he thinks is the fundamental problem.

Sarfraz Raza (SR) To me, much more than the need to ensure dignity for teachers, is the need to ensure dignity for our students. To make up for their incompetence, some teachers degrade their students and their questions in strange ways. Of course, students are lagging, but since the teachers are in power, that’s why in my view they are a bigger problem, with the smallness of their priorities and university politics.

Since it appears that what Umar Suleman was saying was absolutely true (teachers-first), and yet what you are saying is also absolutely true (teachers ought to put their house in order first), how do you reconcile between the positions?

SR I’m hopeless to a large extent as far as the faculty environment in university goes, but I’m still very hopeful as far as our students are concerned. For instance, during Covid, in my online course offering, when the students started going quiet on me and stopped interacting, after my persistent enquiry from them, they finally opened up with me. I came to know that most of the teachers are not even using the whiteboard technology or even the tabs that the university provided to them. Instead of adapting and learning something new, teachers are pushing everything onto slides. Students are getting depressed while they are rightfully finding it impossible to concentrate on the boring content and pedagogy. Teachers are not checking the assignments on time; hence the students are clueless about their learning progress. This makes the students tune out even in good classes. But perhaps the teachers have also tuned out because their universities have started expecting an unrealistic quantity of research and services from them besides teaching.

Umar, I hope this doesn’t turn into a chicken and egg problem, as to what comes first.

US It isn’t. Principles don’t follow a linear progression stepwise; principles are timeless in that sense. And it is a principle that a teacher ought to be given respect and honor, and the decision-makers in universities need to adhere to this principle. But connecting it to Sarfraz’ point, it seems that the teacher also ought to remain cognizant of the fact that he or she is to have the deepest respect in the whole society, and he or she better act likewise, to ensure that that remains the case. Teaching is a special designation that demands respect, much more than other cadres of the society, and it’s also important to know why there’s respect for this designation – it is not because of research, it’s not even because of knowledge. It is because of the long-term and defining service to the community through changing the minds and futures of students. Such a teacher, who recognizes this role, would treat students accordingly. Amongst my own teachers I still deeply respect those few who were selfless and more concerned about their students.

Wonderfully put. Can we shift to how you have set up your programming fundamentals course? What are its fundamental ingredients?

US My experience has forced me to the conclusion that if a student has good foundation in just 3 courses from the first 3 semesters, programming fundamentals, object-oriented programming, and data structures/algorithms, then it’s almost impossible for the student to have a bad industry career, and on the flip side if a student has had bad foundations in these 3 courses, then it’s almost impossible to have a great industry career. As soon as this was evident to me, I forgo my graduate level and elective level courses and by choice opted to teach these foundational courses within my university – at the cost of publishing through grad students. In my view, the ideal teachers for these foundational courses should be expert programmers themselves, who are bigger than even the best programming books out there. Pedagogy wise, the course should be problem-based rather than topic-based, i.e. it should be done through posing the problem in front of the students, and collectively solving the problems within the class, and only then embedding the teaching of programming constructs within these solution designs. For example, selling the students the idea of putting a frame around a 2D face image, instead of teaching them abstractly about 2D arrays or loops. Thirdly, to develop a habit, the course is centered around problem solving both within the class and associated assignments outside the shared lecture hours, resulting in 20 + assignments in a single course. But the most important ingredient for me is the development of a faculty of comprehension within the students, i.e., they must imagine the computational abstractions and connections between them within their heads before coding, just based on their teacher’s verbal narratives. This is done through a dialogical process. For the development of this fundamental faculty, it is imperative that the students aren’t shown too many visualizations up front. I show them actual snippets of code only eventually and to only cement the psychological impressions in the students’ head that their teacher is at the top of his programming game. Once this faculty of comprehension is strengthened (and it is often a painful process,) it goes a long way, up to their final year project and later in industry.

SR In one aspect, my emphasis is absolutely the same as Umar Suleman’s. My course is also entirely problem based, I don’t teach loop etc. But where I disagree is that my course is entirely through live coding in front of students in an IDE. It is because of my own bad first encounter with programming when I was a fresh undergrad student. Pseudocode and flowcharts never worked for me. I usually start my course with MIT’s visual programming language called Scratch, hence the students learn programming through the instant visual effect of their code blocks on a visual object. The best programmers are eventually those who, over time, have developed the same muscle or faculty that Umar Suleman mentioned – they can predict more correctly and more often the effect of their code before hitting the Run button. Just like Umar I also believe that I have to inspire my students in every class, but my translation of that term is that my students should look at their teacher as a super problem solver and a super programmer, one they would like to emulate. For that, they have to witness, in every class, their teacher solving problems and programming in front of them, as much as possible. This includes, at times, writing wrong code and getting stuck and then maneuvering collectively out of the issue programmatically. This includes learning and teaching the art of debugging using a debugger, and this can’t be achieved by teaching only through pen and paper. All information regarding my course is publicly accessible online for anyone’s viewing, which also shows how we shift from Scratch to C++, and the kind of problems we solve every week, and the online teaching resources I employ, and how we move from small building blocks to bigger problem breakdown. The whole point is that just like a small kid cannot learn the human language if the adults aren’t talking in the kid’s presence, similarly, when it comes to learning a programming language, it will have to be a similar kind of immersive experience, where the kids are witnessing their elder(s) use the programming language every day.

Dr. Umar, we can readily appreciate when you said that working the computational problem-solving muscle in your students’ mind comes before actual coding, hence the choice of paper and pen makes sense, but what Sarfraz said about programming language being an immersive experience also makes total sense, hence the choice of live coding and debugging inside the classroom. How do you reconcile the two?

US Debugging isn’t about placing a breakpoint. They’ll be placing the breakpoint at all the wrong places if they don’t have the complete detailed picture of their program and its logic in their mind first. Debugging is again, in the head first, and if the student has learnt how to use his or her own mind as a computer, and that is precisely what is the faculty that I want to build in my students, then they’ll be able to sniff or trace either through a breakpoint or some other means, as to the origin of the bug. I demonize the error in my class, as it’s a sign that the students have written the code without solving the problem first.

SR I completely agree that even debugging has to take place in the mind first, but I would like to emphasize that for very large programs, or distributed applications, it’s imperative to have good hands-on debugging skills.

Any parting thoughts?

SR I’ve recently started using leetcode, where the students can submit their code as solutions to my chosen problem instances and at its backend the leetcode service runs tons of unit test cases on the code submission, and let’s them know which test cases have failed. It also tells them the overall global rank of their submission. It’s important because our students only test their codes very weakly.

US In my opinion, there is a psychological tendency when you, as a teacher, throw too many online resources at your students, that you can discharge yourself from the responsibility of guarding your students’ future well-being as a programmer, i.e., if they don’t become a great resource for the industry you could say that it’s not your fault, because you had given them a whole world of resources. So, my parting thought is once again that the teacher should be at the center of everything that happens in the course. In our tradition, a teacher is a person who takes the pain – the pain of taking his students’ responsibility, not just in one course, but forever. In my living experience, the most impact-creating teachers have only been those who have never let anything else in their lives muddle this perspective. For if this perspective is intact, then everything that Sarfraz and I do in our class will matter to students, otherwise a teacher can add a whole lot of methodologies or tools to make the course interesting, it will not have the same impact on their students or their lives!