Settings

Theme

More Universities Should Shut Down Their Computer Science Programs

blog.jeffreymcmanus.com

27 points by jeffreymcmanus 14 years ago · 42 comments

Reader

zeteo 14 years ago

This kind of reasoning actually led to the establishment of "Java schools" in the late 90s, and I hope we've all read Joel Spolsky's classic piece about them:

http://www.joelonsoftware.com/articles/ThePerilsofJavaSchool...

cube13 14 years ago

I think you're missing the entire point of what a Computer Science program is.

It's not to teach programming. It's to teach computing theory, algorithm design, etc. That's the reason that the top-level university programs are so heavy on theory. That just happens to fit with systems programmers(who somehow aren't software engineers... curious). It also fits with game programmers, which is where I think a lot of CS students want to go after they graduate.

I also disagree that there is any real good way to teach software engineering at this point in time. Unlike other disciplines such as Mechanical or even Electrical engineering with decades, even centuries of practical knowledge that has resulted in a lot of very strict best practices. Software engineering doesn't have that. Everything in the domain is extraordinarily fluid. Processes are changing rapidly. Tools as well. Even the end product we produce is vastly different from what it was 10 years ago. There simply isn't any good way to teach this subject in this environment short of on the job training. It's compounded with the fact that every software development house is different. Nobody has the exact same process, or uses the exact same tools. So teaching SE as a discipline really doesn't make much sense.

  • jeffreymcmanusOP 14 years ago

    did you actually read the post? i actually pre-rebutted both of your arguments.

    i understand quite well what a CS program is, since (as i pointed out in the post) i've been a student in three university CS programs and taught coding at a fourth.

    i'm saying that most of what goes on in academic CS departments is not what we need as a society and it's not what most undergrads hope to get into when they enroll. most undergrads get into CS to write software, not to learn "theory" or "compiler design" (although, again, as i pointed out in the post, if this happens to be your bag, more power to you -- but this isn't really about you, it's about the mismatch between what university CS programs do and what people and society really want or need.)

    software engineering is obviously teachable (i've been doing it for 20 years) and that's true even if you personally didn't have any good software engineering instructors or mentors. it looks like you and i are in agreement that rapid change in software engineering makes universities not the optimal place to teach software engineering (that was the point of my post). but it doesn't follow that because universities are bad at this, that software engineering is "not teachable".

    • ChuckMcM 14 years ago

      Interesting side discussion.

      I do thing cube123 read your post, and I do think a valid conclusion from reading your post is that you have missed the point of what a CS program is.

      I suspect that this comes from your own history, and part from the way in which CS 'grew up' as a discipline.

      The point of your posting is that being employed as a programmer, and learning programming is not what a Computer Science degree is about. Try getting an undergraduate degree in Electrical Engineering, its similar in that you have lots of theory on lots of things but little practical experience.

      The leap you make which causes me to discard your argument is this one, "but this isn't really about you, it's about the mismatch between what university CS programs do and what people and society really want or need." You have taken on the role of speaking for society and yet you haven't successfully made a case that you can accurately represent what society wants.

      You can make an argument that there is a need for a training program between high school and employment that teaches people how to write programs to solve problems. You can call that Computer Engineering, Applied Programming, Programming Technology, what ever. Such programs exist, both in the 'for profit' University world and elsewhere. You can argue that such programs should be structured more along the various processes for producing reliable, testable code, and you do some of that in your education project (always great to put your money where your mouth is like that).

      But the opportunity to teach folks who 'just want to code' does not disqualify CS as being a valid course of study, just like 'Accounting' doesn't disqualify 'Mathematics' as a course of study. So your central thesis that 'more universities should shut down their CS programs' fails the 'sniff' test.

      Now if you said 'More universities should offer applied programming type degrees' and used your points about how it is what many people want to do. That is a reasonable conversation to have, do we want to elevate what have been things like ITT Technical College programs into a more general purpose degree program? Something between 'JavaSchool' and 'CS' ? I can see arguments for and against.

      But if you are going to blurt out things like "Most undergraduates and professional actually want to learn applied software engineering, not 'computer science'" you really should try to develop some foundation for that claim. What evidence do you offer that this claim is valid? Some study on college exit exams, some survey of recent CS graduates? A self selecting poll on Reddit? Its all well and good to wonder if most folks just want to code, but to use it as a claim in your argument that Universities should restructure their CS programs, and expecting your readers to 'buy in' to that requires that you provide some basis for making that claim.

      Your post makes a bunch of claims, four of them in big bold font, for which your provide no supporting evidence or structure at all around why the reader should believe them. Because of that your message is lost.

      I agree with you that it is an interesting topic and as we've moved 'programming' into a more general skill requirement based on the explosion of 'programmable' devices, you might be more successful making the argument that we need to offer a better high school programming class. (much like Typing was offered in the 70's as a way to provide a generally useful skill to High School students).

      • glogla 14 years ago

        Just a terminology note: 'Computer Engineering' is already existing term for the discipline of making computers -- designing CPUs and building hardware in general (our CE has strong security focus, so they do lot of RFID ASIC stuff, and some FPGA crypto stuff) and low level programming like compiler backends (SPARC register windows are pretty!), microcontrollers and interfacing with other hardware too. And whatever Hennessy and Patterson are doing.

        So you shouldn't name gutted code monkey courses Computer Engineering :)

    • kls 14 years ago

      My problem with your position is that what you are proposing does not require a 4 year degree. I think a 6 month to one year vocational program would be of more advantage to a student than a 4 year degree in what amounts to a vocational education. The problem with this, is that no one respects a vocational education and no one views it as a competent replacement for a 4 year degree (even if the student is better prepared for the job). So it is a catch 22, you are wasting the students time with a 4 year vocational degree, as the stuff they learn in year one is out of date and the perception of anything shorter is that it is a fly by night education. I don't disagree with your premise that students are not being served, but maybe the answer is improving vocational education and the perception there and not in butchering university academia, the latter has been tried and was not very successful.

      • jeffreymcmanusOP 14 years ago

        i agree that what i am proposing does not require a 4-year degree. i don't think that most undergraduates should spend four years in school.

        "no one respects a vocational education" is cargo cult thinking. elite universities don't write world-changing software, educated, motivated people do.

        i come not to butcher academia. as one of the least reformable institutions in our society, i'm pretty much indifferent to academia.

        • cube13 14 years ago

          >elite universities don't write world-changing software, educated, motivated people do.

          Mosaic, which was the precursor to Netscape and IE, came from a project at NCSA at the University of Illinois at Urbana-Champaign.

        • eli_gottlieb 14 years ago

          Oh, an industry supremacist.

    • zeteo 14 years ago

      There's no engineering without a solid theoretical background. You want to do civil engineering, they'll make sure you thoroughly understand Newton's laws; electrical, Kirchhoff's. And that's just the start. In fact, you're much better prepared to build big bridges if all you've studied is theoretical physics than if you had personally built a crossing over every ditch on campus.

      • jeffreymcmanusOP 14 years ago

        Wait -- no engineering is possible? None at all? Really? Then how do you explain the success of high school dropout Benjamin Franklin?

        The point of my post is not that theory is worthless (which I call out several times in the post). It's really that there is more than one way to learn this stuff and that most undergraduates pick out a sub-optimal path for cargo-cult reasons (such as the "halo effect" of elite universities which I also called out in the post).

    • zvrba 14 years ago

      > most undergrads get into CS to write software, not to learn "theory" or "compiler design"

      The flip side is also that an undergraduate enrolls into a CS class, discovers (so it's not their bag before enrollment) that "compiler design" is far more exciting and intelectually challenging than developing typical business/CRUD apps, only to find out after graduation that such jobs barely exist. Yes, let's dispense with academic CS departments.

      Maybe the message you tried to convey is that attending mediocre CS courses is much worse than attending good SE courses. That I agree with, but I do not agree that SE should be totally devoid of theory.

    • cube13 14 years ago

      >i'm saying that most of what goes on in academic CS departments is not what we need as a society and it's not what most undergrads hope to get into when they enroll. most undergrads get into CS to write software, not to learn "theory" or "compiler design" (although, again, as i pointed out in the post, if this happens to be your bag, more power to you -- but this isn't really about you, it's about the mismatch between what university CS programs do and what people and society really want or need.)

      I don't think that catering to what undergrads want is a good thing, at all. The majority of undergrads are 17 to 21 year old kids that really don't know what they want to do. They don't know the industries they want to get into. I certainly didn't, and my experiences at UIUC turned me away from going into game programming to a totally different space. And I wasn't a good programmer out of college. I was pretty terrible. But work has taught me a LOT, most of which I wouldn't understand without the theory basis.

      >software engineering is obviously teachable (i've been doing it for 20 years) and that's true even if you personally didn't have any good software engineering instructors or mentors. it looks like you and i are in agreement that rapid change in software engineering makes universities not the optimal place to teach software engineering (that was the point of my post). but it doesn't follow that because universities are bad at this, that software engineering is "not teachable".

      Like I said in my post, the difficulty of teaching programming and SE in general is that it's changing at an incredibly rapid pace. Languages have evolved. C/C++ were the de-facto languages for a while, then Java gained quite bit of popularity. Recently, C# seems to have taken a large majority of the mindshare.

      20 years ago, a lot of SE practices were highly structured, highly documented(and highly wasting of time) systems. IBM's RUP is one example. 10-15 years ago, less structured systems like XP started showing up, and gained quite a bit of popularity. In the last few years, Agile has become very popular. I learned about RUP and XP in my SE courses, but the place I work at doesn't use any of the above.

      So what would the program teach? Just the most current, up to date stuff? Or would you try to teach a bit of everything?

      The problem with teaching just the brand new shiny is that you end up with the Java mills from the 90's. They're not teaching programming. They're teaching Java. And it may be worthless in a year. While that may just be what the student wants, it's not what society needs.

      • jeffreymcmanusOP 14 years ago

        > I don't think that catering to what undergrads want is a good thing, at all

        that's not what i proposed at all. what i propose is to bring curriculum into the 21st century, and to call out the fact that cargo cult thinking and poor organization on the part of universities are standing in the way of that.

        • 10098 14 years ago

          > bring curriculum into the 21st century,

          I don't quite understand what you mean by that. Dijkstra's algorithm is the same both in 20 and 21st centuries, ditto for red-black trees. Are you proposing universities should be teaching iOS programming and web development with ruby instead of data structures and complexity theory?

          • jeffreymcmanusOP 14 years ago

            Not instead of. In addition to.

            • 10098 14 years ago

              I don't think they should be teaching that at all. It's a bigger waste of time than teaching differential equations. At least diff. equations are there forever and might one day come in handy if you end up writing some software for modeling physical processes. Ruby, on the other hand, will be replaced by some other trendy language in a few years. Plus, if you already know a couple of programming languages with different paradigms, picking up Ruby (or Python, or PHP, or Java) is really easy to do on your own, you can start writing production code in matter of weeks.

              • jeffreymcmanusOP 14 years ago

                This isn't about whatever language is the flavor of the month, although seeing universities teach a language that is less than 20 years old would be nice. It's more about CS programs that produce graduates who have no practical ability to code at all, in any language.

                • cube13 14 years ago

                  Language proficiency, by and large, is the easiest thing for anyone to pick up. Again, new CS grads are, on average 21 or 22 years old. I was programming C/C++ for around a decade at that point, and I was still a terrible programmer. Work taught me a lot more on how to write good C code.

                  Programming languages are tools. Knowledge of a language is not the final goal of a CS education, because it's the same as teaching a mechanical engineer how a drill works.

                  Also, the tools are based entirely on the theory of computing. And once you understand the theory, understanding what the tools are doing, and how they work, becomes much easier.

                • eli_gottlieb 14 years ago

                  What makes you think coding proficiency is the goal of a university or a CS program, or the proper goal thereof.

10098 14 years ago

I have a CS degree, and worse than that, it's a double major in CS and applied math. I had to study things that seem really pointless for an "applied software engineer", like differential equations or numerical methods (ok, maybe the latter is not so pointless). We also studied a considerable chunk of other, more "CS-esque" stuff, like introduction to mathematical logic, computability theory, lambda calculus. Does this stuff pay off? Well, my actual job never required me to implement any complex algorithms, because everything has already been written in the standard libraries. It does help to have at least an approximate picture of what's really going on under the hood.

But what really helps me is that 4 years of being exposed to all this crazy theory has affected my brain in a certain way: it has altered my perception of problems.

Before going into CS I was programming by chance: slap some code together (without really understanding the problem domain) and poke it with a stick until it somehow works the you want it to. I think most kids who are just learning to program do that. However, that approach changed radically after I spent some time at the university. In that sense, CS has been really useful, at least in my case. Btw, I'm not saying those skills could not have been obtained elsewhere.

And learning theory really broadens your horizons. Things like computability theory, I have no use for them in my day job, but they're just interesting. Back at the uni, I had a blast writing a turing machine "emulator" and programming it instead of manually writing the assignment on paper :) And yes, you could study them in your spare time, but the truth is, the job eats up so much of your time, and makes you so exhausted that you barely have the resources to follow an online lecture after a long day at work. So why not spend some time learning while you still free from most of the responsibilities of adult life?

  • jeffreymcmanusOP 14 years ago

    No argument there. Like I say in the post, I'm all in favor of the goodness of the basics. I just think that giving undergrads all theory and very little practice is not optimal, and they should have the opportunity to go minimal on theory if it makes sense for them. Very few universities offer such a choice today.

    • 10098 14 years ago

      I know. We lacked practice at the university too. I don't think you can blame the university for that, though. Practical things are better taught by people who actually use them on the job, not by PhDs who write scientific papers. That's why I went to long-term internship at an actual company during my second year, which later turned into a full-time job.

      • jeffreymcmanusOP 14 years ago

        if the university purports to teach this stuff, they should hire people who actually know how to teach it. if their tenured PhDs aren't cutting it, they should look elsewhere. (this is how i got my university teaching job.)

        • 10098 14 years ago

          > if the university purports to teach this stuff,

          It doesn't. The major purpose of a university is to produce scientists who do research, not software engineers who write crud apps. We, the software engineers, are just a byproduct.

          > they should hire people who actually know how to teach it

          They can't and they shouldn't. Why would one want to teach at a university when (s)he has enough skills to work at a company for a big fat compensation, and, possibly, equity? The only way to attract those people to the universities would be for the universities to offer much higher salaries, which would consequently drive up the cost of education (in my own country it wouldn't even work, because education is "free", i.e. mostly paid for by the government). And for what - to teach the students something they could have easily picked up on their own by poking around the internets or participating in internships? That is not optimal. If you study formal grammars in class and don't try writing your own little lexer/parser at home, it's your own fault, don't blame the university. It has taught you everything you need to know to write a parser, and it's your job to put it to use.

    • milroc 14 years ago

      Where I spent most of my undergrad (Georgia Tech), we had a system called threads. Giving students tracks in which they could focus their study of computer science.

      These tracks were generally all theoretical (the exceptions being some classes in platforms and devices), even my friends who had a love for software engineering ended up learning the thoughts behind each process rather than blindly learning the process itself in order to master said process that is currently practical.

      The way I treated academic learning is very similar to the process described above by 10098. The learning you experience in college should be some form of aggregate information about past ideas/trials and tribulations. This is the process by which I (as a customer) have found most universities treat their undergraduates. Rather than tailoring them to become masters of a specific problem they try (albeit not successfully, and there are a vast number of people in universities today that don't enjoy, want to have, or have this mindset) to build the next generation of people to find flaws in our current society, in hopes that they have motivation to fix it.

      That being said you are making the argument that software engineering is a vocational skill. While I'm not denying that the majority of the process that I've found in my limited time in the industry tends to be filled with skills that are akin to any other vocational profession, I don't believe increasing vocational skills help the students. It might in a short term give them a strong basis for obtaining a software related position. It might also give them the ability to perform really well in their jobs at that time being. It does however not enable them to question the process they've learned. It also does not help them find problems within a process.

      It should also be noted that most companies aren't looking for a master software engineer. They test for intelligence and social skills rather than how strict the student is on testing practices or which design cycle they prefer. These biases also lead towards limiting employment because they'll end up fighting rather than adapting to the new work environment that is already established by the companies views on the subject.

      A lot of top schools are taking interest in teaching up to date languages, maybe not clojure or even javascript but python is the language that I've seen most Georgia Tech students prefer to program in after taking several courses in it.

      http://www.cc.gatech.edu/future/undergraduates/threads http://www.cc.gatech.edu/future/undergraduates/bscs/roles/ma...

      • jeffreymcmanusOP 14 years ago

        This kind of thing is one of the reasons why Georgia Tech is consistently among the top 10 computer science schools in the nation.

  • rsanchez1 14 years ago

    Newbies also learn a new approach to problem solving in a summer internship at a major software company too. The internship is also MUCH cheaper than four years learning theory.

    Of course, you could always take a script kiddie job at a minor software company. Those wouldn't be fulfilling to anyone anyway, and those are the jobs that exhaust you and make you feel like they are "eating up" your time, instead of being a productive use of your time.

UK-AL 14 years ago

Hint: pointer arithmetic is a pretty practical, not theory. It's easy to understand, and is usually first year stuff. Program in c and you are likely to use it. pointer arithmetic should be taught for software engineers anyway... Compiler design again is a pretty pratical subject, except for formal grammars. It has tons of practical uses, especially for dsl's.

Theory for me is more like machine learning(Bayesian theory, probability latent semantic analysis and way more advanced stuff). However with the age of big data upon us, we are going to need this for your average programmer more and more. Stuff like that happens to be what interests me, I also find it the difficult much to detriment of consistently high grades..

I think your what your proposing would lower the barrier entry so much, your average software dev won't be very good, and they will be cheap. Is that what you want for the proffesion?

SlipperySlope 14 years ago

This post is spot-on.

During the boom cycles of software development, its not neccessary for someone to go back to university for the skills - online is good enough, more specialized, and much more cost-effective.

Why get in crushing debt to become an app developer? Or to program a startup's back-end, or to administer a cloud infrastructure.

chanian 14 years ago

Cherry picking applied software engineering (and glancing over your curriculum, specifically web programming/app development) as the only modern relevant subset of computer science seems a bit dramatic. I personally don't really care how/where people learn how to code, and like you, I don't care much for the "priesthood of the technologist" I see so often in our industry.

But so confidently suggesting that ".. academic CS departments is not what we need as a society" is no different "cargo-cult" thinking than the poster who suggested that many don't take vocational training seriously. You are blogging about and representing a vocational training service, obviously the readers on HN are going to be skeptical.

Choosing the path of academia in education and as a career is a perfectly valid and respectable choice. Suggesting that the works of groups like the ACM, IEEE are not addressing real societal problem is pretty harsh, regardless of how elitist they may or may not be, and regardless of whether those individuals are making a significant contribution to society or not. There's no need to shit on smart and passionate people in specialized / esoteric fields in computer science simply because their work can't be easily app'ified or conjured into an mvp (http://cs.nyu.edu/~jhan/, http://www.dgp.toronto.edu/~ravin/ ...)

I studied computer science in my undergrad. I didn't go to learn how to code nor did I expect my university to teach me how to code, I already knew how to do that. Many of my friends discovered a passion for CS because of their overlapping math/logic/theory breadth courses, not despite it. Assuming the typical CS student is someone who only enrolls to learn things like applied programming grossly oversimplifies and generalizes a person's intentions and motivations for learning, even though I'm sure there are many with that primary motivation.

Online/alternative learning programs, like your company, are a great approach on education which have lived happily in parallel with universities for years. It's not a replacement though, it is an alternative. I don't think the shortcomings in some universities warrant the "academic butchering" as suggested so boldly in the post's title. To suggest that we should start systematically shutting down CS departments simply because their current curriculum doesn't produce good programmers in a way that aligns with your model/curriculum, is a scary and dangerous thought. When you take away university departments, you chop the legs off entire disciplines.

StuffMaster 14 years ago

>one of the most pressing problems that humanity has today is obtaining clean drinking water. Yet no university has a Department of Water.

He made some interesting points, but this just sounds crazy.

jeffreymcmanusOP 14 years ago

Looks like ye olde blog is a bit slammed at the moment, apologies. (If only my university CS program taught me how to be a Wordpress sysadmin!)

Keyboard Shortcuts

j
Next item
k
Previous item
o / Enter
Open selected item
?
Show this help
Esc
Close modal / clear selection