3 <!DOCTYPE eventdefs SYSTEM "csc.dtd">
7 <eventitem date="2011-07-15" time="7 PM" room="Comfy Lounge" title="Code Party 3">
8 <short>Our third and final code party of the term! As usual, there will be
9 code, code, and more code. Plus energy drinks.
11 The theme for this code party is Open Source Collaboration. We encourage
12 everybody to come out and participate in some open source projects.
14 More details to follow!
16 <abstract>Our third and final code party of the term! As usual, there will be
17 code, code, and more code. Plus energy drinks.
19 The theme for this code party is Open Source Collaboration. We encourage
20 everybody to come out and participate in some open source projects.
22 More details to follow!
25 <eventitem date="2011-07-09" time="2 PM" room="Outdoors" title="picniCS">
27 Join us in July at our picnic and campfire. We'll have snacks, frisbees,
30 More details to follow!
33 Join us in July at our picnic and campfire. We'll have snacks, frisbees,
36 More details to follow!
39 <eventitem date="2011-06-17" time="7 PM" room="Comfy Lounge" title="Code Party 2">
40 <short>Our second code party. This iteration's topic: Puzzles, contests, and
41 interview questions. You can also work on whatever other code you want to.
43 More details to follow!
45 <abstract>Our second code party. This iteration's topic: Puzzles, contests, and
46 interview questions. You can also work on whatever other code you want to.
48 More details to follow!
51 <eventitem date="2011-06-09" time="4:30 PM" room="Location TBA"
52 title="General Purpose Computing on Graphics Cards">
54 GPGPU (general purpose graphics processing unit) computing is an
55 expanding area of interest, with applications in physics, chemistry,
56 applied math, finance, and other fields. nVidia has created an
57 architecture named CUDA to allow programmers to use graphics cards
58 without having to write PTX assembly or understand OpenGL. CUDA is
59 designed to allow for high-performance parallel computation controlled
60 from the CPU while granting the user fine control over the behaviour
61 and performance of the device.
63 In this talk, I'll discuss the basics of nVidia's CUDA architecture
64 (with most emphasis on the CUDA C extensions), the GPGPU programming
65 environment, optimizing code written for the graphics card, algorithms
66 with noteworthy performance on GPU, libraries and tools available to
67 the GPGPU programmer, and some applications to condensed matter
68 physics. No physics background required!
71 <eventitem date="2011-06-03" time="7 PM" room="Comfy Lounge" title="Code Party 1">
73 The Computer Science Club is having our first code party of the term.
74 The theme for this week's code party is personal projects. Come show us
75 what you've been working on! Of course, everybody is welcome, even if you
79 The Computer Science Club is having our first code party of the term.
80 The theme for this week's code party is personal projects. Come show us
81 what you've been working on! Of course, everybody is welcome, even if you
84 Personal projects are a great way to flex your CS muscles, and learn interesting
85 and new things. Come out and have some fun!
87 Two more are scheduled for later in the term.
90 <eventitem date="2011-05-09" time="5:31 PM" room="Comfy Lounge" title="Elections Nominees List">
92 <p>CSC Elections, final list of nominations for Spring 2011</p>
95 <p>The nominations are:
97 <li>President: jdonland, mimcpher, mthiffau</li>
98 <li>Vice-President: jdonland, mimcpher</li>
99 <li>Treasurer: akansong, kspaans</li>
100 <li>Secretary: akansong, jdonland</li>
106 <eventitem date="2011-05-09" time="5:30 PM" room="Comfy Lounge" title="Elections">
108 <p>CSC Elections have begun for the Spring 2011 term, nominations are open!</p>
111 <p>It's time to elect your CSC executive for the Spring 2011 term. The
112 elections will be held on Monday May 9th at 5:30PM in the Comfy Lounge
113 on the 3rd floor of the MC. Nominations can be sent to the Chief
114 Returning Officer, <a href="mailto:cro@csclub.uwaterloo.ca">cro@csclub.uwaterloo.ca</a>.
115 Nominations will be open until 4:30PM on Monday May 9th. You can also stop by the office in
116 person to write your nominations on the white board.</p>
118 <p>The executive positions open for nomination are:
121 <li>Vice-President</li>
125 There are also numerous positions that will be appointed once the
126 executive are elected including systems administrator, office manager,
129 <p>Everyone is encouraged to run if they are interested, regardless of
130 program of study, age, or experience. If you can't make the election,
131 that's OK too! You can give the CRO a statement to read on your
132 behalf. If you can't make it or are out of town, your votes can be
133 sent to the CRO in advance of the elections. For the list of nominees,
134 watch the CSC website, or ask the CRO.</p>
136 <p>Good luck to our candidates!</p>
141 <eventitem date="2011-03-17" time="04:30 PM" room="MC2034" title="Software Patents">
143 <short><p><i>by Stanley Khaing</i>. What are the requirements for obtaining a patent? Should software be patentable?</p></short>
146 <p>Stanley Khaing is a lawyer from Waterloo whose areas of practice are software and high technology. He will be discussing software patents. In particular, he will be addressing the following questions:</p>
148 <li>What are the requirements for obtaining a patent?</li>
149 <li>Should software be patentable?</li>
155 <eventitem date="2011-02-17" time="07:00 PM" room="MC2017" title="A Smorgasbord of Perl Talks">
157 <short><p><i>by KW Perl Mongers</i>. These talks are intended for programmers who are curious about the Swiss Army Chainsaw of languages, Perl.</p></short>
160 <p>Tyler Slijboom will present:</p>
163 <li>Prototyping in Perl,</li>
164 <li>Perl Default Variables,</li>
165 <li>HOWTO on OO Programming, and</li>
166 <li>HOWTO on Installing and Using Modules from CPAN</li>
169 <p>Daniel Allen will present:</p>
172 <li>Coping with Other Peoples' Code</li>
175 <p>Justin Wheeler will present:</p>
178 <li>Moose: a Modern Perl Framework</li>
184 <eventitem date="2011-02-09" time="04:30 PM" room="MC3003" title="UNIX 103: Version Control Systems">
186 <short><p><i>by Calum T. Dalek</i>. In this long-awaited third installment of the popular Unix Tutorials the friendly experts of the CSC will teach you the simple art of version control.
189 <abstract><p>You will learn the purpose and use of two different Version Control Systems (git and subversion). This tutorial will advise you in the discipline of managing the source code of your projects and enable you to quickly learn new Version Control Systems in the work place -- a skill that is much sought after by employers.</p></abstract>
193 <eventitem date="2011-02-04" time="07:00 PM" room="Comfy Lounge" title="Code Party">
195 <short><p><i>by Calum T. Dalek</i>. Come one, come all to the Code Party happening in the Comfy Lounge this Friday. The event starts at 7:00PM and will run through the night.</p></short>
197 <abstract><p>Why sleep when you could be hacking on $your_favourite_project or doing $something_classy in great company? Join us for a night of coding and comraderie! Food and caffeine will be provided.</p></abstract>
201 <eventitem date="2011-02-02" time="04:30 PM" room="MC3003" title="UNIX 102: Documents and Editing in the Unix environment">
203 <short><p><i>by Calum T. Dalek</i>. The next installment in the CS Club's popular Unix tutorials UNIX 102 introduces powerful text editing tools for programming and document formatting.
206 <abstract><p>Unix 102 is a follow up to Unix 101, requiring basic knowledge of the shell. If you missed Unix 101 but still know your way around you should be fine. Topics covered include: "real" editors, document typesetting with LaTeX (great for assignments!), bulk editing, spellchecking, and printing in the student environment and elsewhere. If you aren't interested or feel comfortable with these tasks, watch out for Unix 103 and 104 to get more depth in power programming tools on Unix.</p></abstract>
210 <eventitem date="2011-01-26" time="04:30 PM" room="MC3003" title="UNIX 101: An Introduction to the Shell">
212 <short><p><i>by Calum T. Dalek</i>. New to Unix? No problem, we'll teach you to power use circles around your friends!
216 <abstract><p>This first tutorial is an introduction to the Unix shell environment, both on the student
217 servers and on other Unix environments. Topics covered include: using the shell, both basic
218 interaction and advanced topics like scripting and job control, the filesystem and manipulating
219 it, and ssh. If you feel you're already familiar with these topics don't hesitate to come
220 to Unix 102 to learn about documents, editing, and other related tasks, or watch out
221 for Unix 103 and 104 that get much more in depth into power programming tools on Unix.
228 <eventitem date="2010-11-17" time="04:30 PM" room="MC4061" title="Mathematics and aesthetics in maze design">
230 <short><p><i>by Dr. Craig S. Kaplan</i>. In this talk, I discuss the role of the computer in the process of designing mazes. I present some well known algorithms for maze construction, and more recent research that attempts to novel mazes with non-trivial mathematical or aesthetic properties.
234 <abstract><p>For thousands of years, mazes and labyrinths have played
235 an important role in human culture and myth. Today, solving
236 mazes is a popular pastime, whether with pencil on paper
237 or by navigating through a cornfield.
238 </p><p>The construction of compelling mazes encompasses a variety of
239 challenges in mathematics, algorithm design, and aesthetics.
240 The maze should be visually attractive, but it should also be
241 an engaging puzzle. Master designers balance these two goals
242 with wonderful results.
243 </p><p>In this talk, I discuss the role of the computer in the process
244 of designing mazes. I present some well known algorithms for
245 maze construction, and more recent research that attempts to
246 novel mazes with non-trivial mathematical or aesthetic properties.
250 <eventitem date="2010-11-13" time="12:00 PM" room="Outside DC" title="CSC Invades Toronto">
252 <short><p>The CSC is going to Toronto to visit UofT's <a href="http://cssu.cdf.toronto.edu/">CSSU</a>, see what they do, and have beer with them.
253 If you would like to come along, please come by the office and sign up. The cost for the trip is $2 per member.
255 The bus will be leaving from the Davis Center (DC) Saturday Nov. 13 at NOON (some people may have been told 1pm, this is an error). Please show up a few minutes early so we may
260 <eventitem date="2010-11-05" time="07:00 PM" room="CnD Lounge (MC3002)" title="Hackathon">
262 <short><p>Come join the CSC for a night of code, music with only 8 bits, and comradarie. We will be in the C&D Lounge from 7pm until 7am working on personal projects, open source projects, and whatever else comes to mind. If you're interested in getting involved in free/open source development, some members will be on hand to guide you through the process.
266 <abstract><p>Come join the CSC for a night of code, music with only 8 bits, and comradarie. We will be
267 in the C&D Lounge from 7pm until 7am working on personal projects, open source projects, and
268 whatever else comes to mind. If you're interested in getting involved in free/open source development,
269 some members will be on hand to guide you through the process.
274 <eventitem date="2010-10-26" time="04:30 PM" room="MC4040" title="Analysis of randomized algorithms via the probabilistic method">
276 <short><p>In this talk, we will give a few examples that illustrate the basic method and show how it can be used to prove the existence of objects with desirable combinatorial properties as well as produce them in expected polynomial time via randomized algorithms. Our main goal will be to present a very slick proof from 1995 due to Spencer on the performance of a randomized greedy algorithm for a set-packing problem. Spencer, for seemingly no reason, introduces a time variable into his greedy algorithm and treats set-packing as a Poisson process. Then, like magic, he is able to show that his greedy algorithm is very likely to produce a good result using basic properties of expected value.
280 <abstract><p>The probabilistic method is an extremely powerful tool in combinatorics that can be
281 used to prove many surprising results. The idea is the following: to prove that an
282 object with a certain property exists, we define a distribution of possible objects
283 and use show that, among objects in the distribution, the property holds with
284 non-zero probability. The key is that by using the tools and techniques of
285 probability theory, we can vastly simplify proofs that would otherwise require very
286 complicated combinatorial arguments.
287 </p><p>As a technique, the probabilistic method developed rapidly during the latter half of
288 the 20th century due to the efforts of mathematicians like Paul Erdős and increasing
289 interest in the role of randomness in theoretical computer science. In essence, the
290 probabilistic method allows us to determine how good a randomized algorithm's output
291 is likely to be. Possibly applications range from graph property testing to
292 computational geometry, circuit complexity theory, game theory, and even statistical
294 </p><p>In this talk, we will give a few examples that illustrate the basic method and show
295 how it can be used to prove the existence of objects with desirable combinatorial
296 properties as well as produce them in expected polynomial time via randomized
297 algorithms. Our main goal will be to present a very slick proof from 1995 due to
298 Spencer on the performance of a randomized greedy algorithm for a set-packing
299 problem. Spencer, for seemingly no reason, introduces a time variable into his
300 greedy algorithm and treats set-packing as a Poisson process. Then, like magic,
301 he is able to show that his greedy algorithm is very likely to produce a good
302 result using basic properties of expected value.
303 </p><p>Properties of Poisson and Binomial distributions will be applied, but I'll remind
304 everyone of the needed background for the benefit of those who might be a bit rusty.
305 Stat 230 will be more than enough. Big O notation will be used, but not excessively.
310 <eventitem date="2010-10-19" time="04:30 PM" room="RCH 306" title="Machine learning vs human learning - will scientists become obsolete?">
312 <short><p><i>by Dr. Shai Ben-David</i>.
321 <eventitem date="2010-10-13" time="04:30 PM" room="MC3003" title="UNIX 102">
323 <short><p>This installment in the CS Club's popular Unix tutorials UNIX 102 introduces powerful text editing tools for programming and document formatting.
327 <abstract><p>Unix 102 is a follow up to Unix 101, requiring basic knowledge of the shell.
328 If you missed Unix101 but still know your way around you should be fine.
329 Topics covered include: "real" editors, document typesetting with LaTeX
330 (great for assignments!), bulk editing, spellchecking, and printing in the
331 student environment and elsewhere.
335 <eventitem date="2010-10-06" time="04:30 PM" room="MC3003" title="UNIX 103">
337 <short><p>Unix 103 will cover version control systems and how to use them to manage your projects. Unix 101 would be helpful, but all that is needed is basic knowledge of the Unix command line (how to enter commands).
341 <abstract><p>Unix 103 will cover version control systems and how to use them to manage
342 your projects. Unix 101 would be helpful, but all that is needed is basic
343 knowledge of the Unix command line (how to enter commands).
348 <eventitem date="2010-10-12" time="04:30 PM" room="MC4061" title="How to build a brain: From single neurons to cognition">
350 <short><p><i>By Dr. Chris Eliasmith</i>. Theoretical neuroscience is a new discipline focused on constructing mathematical models of brain function. It has made significant headway in understanding aspects of the neural code. However, past work has largely focused on small numbers of neurons, and so the underlying representations are often simple. In this talk I demonstrate how the ideas underlying these simple forms of representation can underwrite a representational hierarchy that scales to support sophisticated, structure-sensitive representations.
354 <abstract><p><i>By Dr. Chris Eliasmith</i>. Theoretical neuroscience is a new discipline focused on constructing
355 mathematical models of brain function. It has made significant
356 headway in understanding aspects of the neural code. However,
357 past work has largely focused on small numbers of neurons, and
358 so the underlying representations are often simple. In this
359 talk I demonstrate how the ideas underlying these simple forms of
360 representation can underwrite a representational hierarchy that
361 scales to support sophisticated, structure-sensitive
362 representations. I will present a general architecture, the semantic
363 pointer architecture (SPA), which is built on this hierarchy
364 and allows the manipulation, processing, and learning of structured
365 representations in neurally realistic models. I demonstrate the
366 architecture on Progressive Raven's Matrices (RPM), a test of
367 general fluid intelligence.
372 <eventitem date="2010-10-04" time="04:30 PM" room="MC4021" title="BareMetal OS">
374 <short><p><i>By Ian Seyler, Return to Infinity</i>. BareMetal is a new 64-bit OS for x86-64 based computers. The OS is written entirely in Assembly, while applications can be written in Assembly or C/C++. High Performance Computing is the main target application.
378 <abstract><p><i>By Ian Seyler, Return to Infinity</i>. BareMetal is a new 64-bit OS for x86-64 based computers. The OS is written entirely in Assembly,
379 while applications can be written in Assembly or C/C++.
380 High Performance Computing is the main target application.
385 <eventitem date="2010-09-28" time="04:30 PM" room="MC4061" title="A Brief Introduction to Video Encoding">
387 <short><p><i>By Peter Barfuss</i>. In this talk, I will go over the concepts used in video encoding (such as motion estimation/compensation, inter- and intra- frame prediction, quantization and entropy encoding), and then demonstrate these concepts and algorithms in use in the MPEG-2 and the H.264 video codecs. In addition, some clever optimization tricks using SIMD/vectorization will be covered, assuming sufficient time to cover these topics.
391 <abstract><p><i>By Peter Barfuss</i>. With the recent introduction of digital TV and the widespread success
392 of video sharing websites such as youtube, it is clear that the task
393 of lossily compressing video with good quality has become important.
394 Similarly, the complex algorithms involved require high amounts of
395 optimization in order to run fast, another important requirement for
396 any video codec that aims to be widely used/adopted.
397 </p><p>In this talk, I
398 will go over the concepts used in video encoding (such as motion
399 estimation/compensation, inter- and intra- frame prediction,
400 quantization and entropy encoding), and then demonstrate these
401 concepts and algorithms in use in the MPEG-2 and the H.264 video
402 codecs. In addition, some clever optimization tricks using
403 SIMD/vectorization will be covered, assuming sufficient time to cover
409 <eventitem date="2010-09-23" time="04:30 PM" room="DC1301 (The Fishbowl)" title="Calling all CS Frosh">
411 <short><p>Come meet and greet your professors, advisors, and the heads of the school. Talk to the CSC executive and other upper year students about CS at Waterloo. Free food and beverages will also be available, so there is really no excuse to miss this.
415 <abstract><p>Come meet and greet your professors, advisors, and the heads of the school.
416 Talk to the CSC executive and other upper year students about CS at Waterloo.
417 Free food and beverages will also be available, so there is really no excuse
422 <eventitem date="2010-09-29" time="04:30 PM" room="MC3003" title="Unix 101">
424 <short><p>Need to use the Unix environment for a course, want to overcome your fears of the command line, or just curious? Attend the first installment in the CSC's popular series of Unix tutorials to learn the basics of the shell and how to navigate the unix environment. By the end of the hands on workshop you will be able to work efficiently from the command line and power-use circles around your friends.
428 <abstract><p>Need to use the Unix environment for a course, want to overcome your fears of
429 the command line, or just curious? Attend the first installment in the CSC's
430 popular series of Unix tutorails to learn the basics of the shell and how to
431 navigate the unix environment. By the end of the hands on workshop you will
432 be able to work efficiently from the command line and power-use circles around
438 <eventitem date="2010-09-22" time="06:00 PM" room="MC4045" title="Cooking for Geeks">
440 <short><p>The CSC is happy to be hosting Jeff Potter, author of "Cooking for Geeks" for a presentation on the finer arts of food science. Jeff's book has been featured on NPR, BBC and his presentations have wowed audiences of hackers & foodies alike. We're happy to have Jeff joining us for a hands on demonstration.
444 <abstract><p>The CSC is happy to be hosting Jeff Potter, author of "Cooking for Geeks" for a presentation on the finer arts of food science.
445 Jeff's book has been featured on NPR, BBC and his presentations have wowed audiences of hackers & foodies alike.
446 We're happy to have Jeff joining us for a hands on demonstration.
447 </p><p>But you don't have to take our word for it... here's what Jeff has to say:
448 </p><p>Hi! I'm Jeff Potter, author of Cooking for Geeks (O'Reilly Media, 2010), and I'm doing a "D.I.Y. Book Tour" to talk
449 about my just-released book. I'll talk about the food science behind what makes things yummy, giving you a quick
450 primer on how to go into the kitchen and have a fun time turning out a good meal.
451 Depending upon the space, I’ll also bring along some equipment or food that we can experiment with, and give you a chance to play with stuff and pester me with questions.
452 </p><p>If you have a copy of the book, bring it! I’ll happily sign it.
456 <eventitem date="2010-09-21" time="04:30 PM" room="MC4061" title="In the Beginning">
458 <short><p><b>by Dr. Prabhakar Ragde, Cheriton School of Computer Science</b>. I'll be workshopping some lecture ideas involving representations of
459 numbers, specification of computation in functional terms, reasoning about
460 such specifications, and comparing the strengths and weaknesses of different approaches.
464 <abstract><p>I'll be workshopping some lecture ideas involving representations
465 of numbers, specification of computation in
466 functional terms, reasoning about such specifications, and comparing the
467 strengths and weaknesses of
468 different approaches. No prior background is needed; the talk should be accessible
470 the University of Waterloo and, I hope, interesting to both novices and experts.
474 <eventitem date="2010-09-14" time="04:30 PM" room="Comfy Lounge" title="Elections">
475 <short><p>Fall term executive elections and general meeting.</p></short>
480 <eventitem date="2010-07-20" time="04:30 PM" room="MC2066" title="The Incompressibility Method">
482 In this talk, we shall explore the incompressibility method---an interesting and
483 extremely powerful framework for determining the average-case runtime of
484 algorithms. Within the right background knowledge, the heapsort question can be
485 answered with an elegant 3-line proof.
488 <p>Heapsort. It runs in $\Theta(n \log n)$ time in the worst case, and in $O(n)$
489 time in the best case. Do you think that heapsort runs faster than $O(n
490 \log n)$ time on average? Could it be possible that on most inputs,
491 heapsort runs in $O(n)$ time, running more slowly only on a small fraction
493 <p>Most students would say no. It "feels" intuitively obvious that heapsort
494 should take the full $n \log n$ steps on most inputs. However, proving this
495 rigourously with probabilistic arguments turns out to be very difficult.
496 Average case analysis of algorithms is one of those icky subjects that most
497 students don't want to touch with a ten foot pole; why should it be so
498 difficult if it is so intuitively obvious?</p>
499 <p>In this talk, we shall explore the incompressibility method---an interesting
500 and extremely powerful framework for determining the average-case runtime of
501 algorithms. Within the right background knowledge, the heapsort question
502 can be answered with an elegant 3-line proof.</p>
503 <p>The crucial fact is that an overwhelmingly large fraction of randomly
504 generated objects are incompressible. We can show that the inputs to
505 heapsort that run quickly correspond to inputs that can be compressed,
506 thereby proving that heapsort can't run quickly on average. Of course,
507 "compressible" is something that must be rigourously defined, and for this
508 we turn to the fascinating theory of Kolmogorov complexity.</p>
509 <p>In this talk, we'll briefly discuss the proof of the incompressibility
510 theorem and then see a number of applications. We won't dwell too much on
511 gruesome mathemtical details. No specific background is required, but
512 knowledge of some of the topics in CS240 will be helpful in understanding
513 some of the applications.</p>
517 <eventitem date="2010-07-13" time="04:30 PM" room="MC2066" title="Halftoning and Digital Art">
518 <short><p>Edgar Bering will be giving a talk titled: Halftoning and Digital Art</p></short>
519 <abstract><p>Halftoning is the process of simulating a continuous tone image
520 with small dots or regions of one colour. Halftoned images may be seen
521 in older newspapers with a speckled appearance, and to this day colour
522 halftoning is used in printers to reproduce images. In this talk I will
523 present various algorithmic approaches to halftoning, with an eye not
524 toward exact image reproduction but non-photorealistic rendering and
525 art. Included in the talk will be an introduction to digital paper
526 cutting and a tutorial on how to use the CSC's paper cutter to render
532 <eventitem date="2010-07-09" time="07:00 PM" room="MC Comfy" title="Code Party">
533 <short><p>There is a CSC Code Party Friday starting at 7:00PM (1900)
534 until we get bored (likely in the early in morning). Come out for
537 <abstract><p>There is a CSC Code Party Friday starting at 7:00PM (1900)
538 until we get bored (likely in the early in morning). Come out for
543 <eventitem date="2010-07-06" time="04:30 PM" room="MC2054" title="Dataflow Analysis">
544 <short><p>Nomair Naeem, a P.H.D. Student at Waterloo, will be giving a talk about Dataflow Analysis</p></short>
546 After going through an introduction to Lattice Theory and a formal treatment to
547 Dataflow Analysis Frameworks, we will take an in-depth view of the
548 Interprocedural Finite Distributive Subset (IFDS) Algorithm which implements a
549 fully context-sensitive, inter-procedural static dataflow analysis. Then, using
550 a Variable Type Analysis as an example, I will outline recent extensions that we
551 have made to open up the analysis to a larger variety of static analysis
552 problems and making it more efficient.
554 The talk is self-contained and no prior knowledge of program analysis is
559 <eventitem date="2010-06-22" time="04:30 PM" room="MC2066" title="Compiling To Combinators">
560 <short><p>Professor Ragde will be giving the first of our Professor talks for the Spring 2010 term.</p></short>
562 Number theory was thought to be mathematically appealing but practically
563 useless until the RSA encryption algorithm demonstrated its considerable
564 utility. I'll outline how combinatory logic (dating back to 1920) has a
565 similarly unexpected application to efficient and effective compilation,
566 which directly catalyzed the development of lazy functional programming
567 languages such as Haskell. The talk is self-contained; no prior knowledge
568 of functional programming is necessary.
572 <eventitem date="2010-05-25" time="05:00 PM" room="MC2066" title="Gerald Sussman">
573 <short><p>Why Programming is a Good Medium for Expressing Poorly Understood and Sloppily Formulated Ideas</p></short>
574 <abstract>Full details found <a href="http://csclub.uwaterloo.ca/misc/sussman/">here</a></abstract>
577 <eventitem date="2010-05-26" time="03:30 PM" room="MC5136" title="Gerald Sussman">
578 <short><p>Public Reception</p></short>
579 <abstract>Full details found <a href="http://csclub.uwaterloo.ca/misc/sussman/">here</a></abstract>
582 <eventitem date="2010-05-26" time="05:000PM" room="MC5158" title="Gerald Sussman">
583 <short><p>The Art of the Propagator</p></short>
584 <abstract>Full details found <a href="http://csclub.uwaterloo.ca/misc/sussman/">here</a></abstract>
587 <eventitem date="2010-05-11" time="05:30 PM" room="Comfy Lounge" title="Elections">
588 <short><p>Spring term executive elections and general meeting.</p></short>
592 <eventitem date="2010-04-06" time="04:30 PM" room="DC1304" title="Brush-Based Constructive Solid Geometry">
594 <short><p>The last talk in the CS10 series will be presented by Jordan Saunders, in which he will discuss methods for processing brush-based constructive solid geometry.
598 <abstract><p>For some would-be graphics programmers, the biggest barrier-to-entry is getting data to render. This is why there exist so
599 many terrain renderers: by virtue of the fact that rendering height-fields tends to give pretty pictures from next to no
600 "created" information. However, it becomes more difficult when programmers want to do indoor rendering (in the style of the
601 Quake and Unreal games). Ripping map information from the Quake games is possible (and fairly simple), but their tool-chain
602 is fairly clumsy from the point of view of adding a conversion utility.
603 </p><p>My talk is about Constructive Solid Geometry from a Brush-based perspective (nearly identical to Unreal's and still very similar
604 to Quake's). The basic idea is that there are brushes (convex volumes in 3-space) and they can either be additive (solid brushes)
605 or subtractive (hollow, or air brushes). The entire world starts off as an infinite solid lump and you can start removing sections
606 of it then adding them back in. The talk pertains to fast methods of taking the list of brushes and generating world geometry. I may
607 touch on interface problems with the editor, but the primary content will be the different ways I generated the geometry and what I found to be best.
611 <eventitem date="2010-04-07" time="1:00 PM" room="MC2037" title="Windows Azure Lab">
613 <short><p>Get the opportunity to learn about Microsoft's Cloud Services Platform, Windows Azure. Attend this Hands-on-lab session sponsored by Microsoft.
617 <abstract><p>We are in the midst of an industry shift as developers and businesses embrace the Cloud.
618 Technical innovations in the cloud are dramatically changing the economics of computing
619 and reducing barriers that keep businesses from meeting the increasing demands of
620 today's customers. The cloud promises choice and enables scenarios that previously
621 were not economically practical.
622 </p><p>Microsoft's Windows Azure is an internet-scale cloud computing services platform hosted
623 in Microsoft data centers. The Windows Azure platform, allows developers to build and
624 deploy production ready cloud services and applications. With the Windows Azure platform,
625 developers can take advantage of greater choice and flexibility in how they develop and
626 deploy applications, while using familiar tools and programming languages.
627 </p><p>Get the opportunity to learn about Microsoft's Cloud Services Platform, Windows Azure.
628 Attend the Hands-on-lab session sponsored by Microsoft.
632 <eventitem date="2010-04-01" time="6:30 PM" room="CSC Office" title="CTRL-D">
634 <short><p>Once again the CSC will be holding its traditional end of term dinner. It will be at the Vice President's house. If you don't know how to get there meet at the club office at 6:30 PM, a group will be leaving from the MC then. The dinner will be potluck style so bring a dish for 4-6 people, or some plates or pop or something.
638 <abstract><p>Once again the CSC will be holding its traditional end of term dinner. It will
639 be at the Vice President's house. If you don't know how to get there meet
640 at the club office at 6:30 PM, a group will be leaving from the MC then. The
641 dinner will be potluck style so bring a dish for 4-6 people, or some plates
646 <eventitem date="2010-03-30" time="4:30 PM" room="DC1304" title="NUI: The future of robotics and automated systems">
648 <short><p>Member Sam Pasupalak will present some of his ongoing work in Natural User Interfaces and Robotics in this sixth installment of CS10.
652 <abstract><p>Bill Gates in his article “A Robot in every home” in the Scientific American describes how the current
653 robotics industry resembles the 1970’s of the Personal Computer Industry. In fact it is not just
654 Microsoft which has already taken a step forward by starting the Microsoft Robotics studio, but robotics
655 researchers around the world believe that robotics and automation systems are going to be ubiquitous in
656 the next 10-20 years (similar to Mark Weiser’s analogy of Personal Computers 20 years ago). Natural User
657 Interfaces (NUIs) are going to revolutionize the way we interact with computers, cellular phones, household
658 appliances, automated systems in our daily lives. Just like the GUI made personal computing a reality,
659 I believe natural user interfaces will do the same for robotics.
660 </p><p>During the presentation I will be presenting my ongoing software project on natural user interfaces as well
661 as sharing my goals for the future, one of which is to provide an NUI SDK and the other to provide a common
662 Robotics OS for every hardware vendor that will enable people to make applications without worrying about
663 underlying functionality. If time permits I would like to present a demo of my software prototype.
667 <eventitem date="2010-03-26" time="7:00 PM" room="MC7001" title="A Final Party of Code">
669 <short><p>There is a CSC/CMC Code Party Friday starting at 7:00PM (1900) until we get bored (likely in the early in morning). Come out for fun hacking times, spreading Intertube memes (optional), hacking on open source projects, doing some computational math, and other general classiness. There will be free energy drinks for everyone's enjoyment. This is the last of the term so don't miss out.
673 <abstract><p>There is a CSC/CMC Code Party Friday starting at 7:00PM (1900) until we
674 get bored (likely in the early in morning). Come out for fun hacking
675 times, spreading Intertube memes (optional), hacking on open source projects,
676 doing some computational math, and other
677 general classiness. There will be free energy drinks for everyone's
678 enjoyment. This is the last of the term so don't miss out.
682 <eventitem date="2010-03-23" time="4:30 PM" room="MC5158" title="Memory-Corruption Security Holes: How to exploit, patch and prevent them.">
684 <short><p>Despite it being 2010, code is still being exploited due to stack overflows, a 40+ year old class of security vulnerabilities. In this talk, I will go over several common methods of program exploitation, both on the stack and on the heap, as well as going over some of the current mitigation techniques (i.e. stack canaries, ASLR, etc.) for these holes, and similarly, how some of these can be bypassed as well.
688 <abstract><p>Despite it being 2010, code is still being exploited due to
689 stack overflows, a 40+ year old class of security vulnerabilities. In
690 this talk, I will go over several common methods of program
691 exploitation, both on the stack and on the heap, as well as going over
692 some of the current mitigation techniques (i.e. stack canaries, ASLR,
693 etc.) for these holes, and similarly, how some of these can be
698 <eventitem date="2010-03-19" time="7:00 PM" room="Comfy Lounge" title="Another Party of Code">
700 <short><p>There is a CSC Code Party Friday starting at 7:00PM (1900) until we get bored (likely in the early in morning). Come out for fun hacking times, spreading Intertube memes (optional), hacking on the OpenMoko, creating music mixes, and other general classiness. There will be free energy drinks for everyone's enjoyment.
704 <abstract><p>There is a CSC Code Party Friday starting at 7:00PM (1900) until we
705 get bored (likely in the early in morning). Come out for fun hacking
706 times, spreading Intertube memes (optional), hacking on the OpenMoko,
707 creating music mixes, and other
708 general classiness. There will be free energy drinks for everyone's
713 <eventitem date="2010-03-16" time="4:30 PM" room="MC5158" title="Approximation Hardness and the Unique Games Conjecture">
715 <short><p>The fifth installment in CS10: Undergraduate Seminars in CS, features CSC member Elyot Grant introducing the theory of approximation algorithms. Fun times and a lack of gruesome math are promised.
719 <abstract><p>The theory of NP-completeness suggests that some problems in CS are inherently hard—that is,
720 there is likely no possible algorithm that can efficiently solve them. Unfortunately, many of
721 these problems are ones that people in the real world genuinely want to solve! How depressing!
722 What can one do when faced with a real-life industrial optimization problem whose solution may
723 save millions of dollars but is probably impossible to determine without trillions of
724 years of computation time?
725 </p><p>One strategy is to be content with an approximate (but provably "almost ideal") solution, and from
726 here arises the theory of approximation algorithms. However, this theory also has a depressing side,
727 as many well-known optimization problems have been shown to be provably hard to approximate well.
728 </p><p>This talk shall focus on the depressing. We will prove that various optimization problems (such as
729 traveling salesman and max directed disjoint paths) are impossible to approximate well unless P=NP.
730 These proofs are easy to understand and are REALLY COOL thanks to their use of very slick reductions.
731 </p><p>We shall explore many NP-hard optimization problems and state the performance of the best known
732 approximation algorithms and best known hardness results. Tons of open problems will be mentioned,
733 including the unique games conjecture, which, if proven true, implies the optimality of many of the
734 best known approximation algorithms for NP-complete problems like MAX-CUT and INDEPENDENT SET.
735 </p><p>I promise fun times and no gruesome math. Basic knowledge of graph theory and computational
736 complexity might help but is not required.
740 <eventitem date="2010-03-12" time="7:00 PM" room="Comfy Lounge" title="A Party of Code">
742 <short><p>A fevered night of code, friends, fun, energy drinks, and the CSC.
746 <abstract><p>A fevered night of code, friends, fun, energy drinks, and the CSC.
747 </p><p>Come join us for a night of coding. Get in touch with more experianced coders,
748 advertize for/bug squash on your favourite open source project, write that personal
749 project you were planning to do for a while but haven't found the time. Don't
750 have any ideas but want to sit and hack? We can find something for you to do.
755 <eventitem date="2010-03-09" time="4:30 PM" room="DC1304" title="Software Transactional Memory and Using STM in Haskell">
757 <short><p>The fourth Undergraduate Seminar in Computer Science will be presented by Brennan Taylor, a club member. He will be discussing various concurrent computing problems, and introducing Software Transactional Memory as a solution to them.
761 <abstract><p>Concurrency is hard. Well maybe not hard, but it sure is annoying to get right. Even the
762 simplest of synchronization tasks are hard to implement correctly when using synchronization
763 primitives such as locks and semaphores.
764 </p><p>In this talk we explore what Software Transactional Memory (STM) is, what problems STM solves,
765 and how to use STM in Haskell. We explore a number of examples that show how easy STM is to use
766 and how expressive Haskell can be. The goal of this talk is to convince attendees that STM is
767 not only a viable synchronization solution, but superior to how synchronization is typically
772 <eventitem date="2010-03-06" time="5:00 PM" room="Waterloo Bowling Lanes" title="Bowling">
773 <short><p>The CSC is going bowling. $9.75 for shoes and two games. The bowling alley serves fried food and beer. Join us for
774 some or all of the above</p></short>
777 <eventitem date="2010-03-02" time="4:30 PM" room="DC1304" title="QIP=PSPACE">
779 <short><p>Dr. John Watrous of the <a href="http://www.iqc.ca">IQC</a> will present his recent result "QIP=PSPACE". The talk will not assume any familiarity with quantum computing or complexity theory, and light refreshments will be provided.
783 <abstract><p>The interactive proof system model of computation is a cornerstone of
784 complexity theory, and its quantum computational variant has been
785 studied in quantum complexity theory for the past decade. In this
786 talk I will discuss an exact characterization of the power of quantum
787 interactive proof systems that I recently proved in collaboration with
788 Rahul Jain, Zhengfeng Ji, and Sarvagya Upadhyay. The characterization
789 states that the collection of computational problems having quantum
790 interactive proof systems consists precisely of those problems
791 solvable with an ordinary classical computer using a polynomial amount
792 of memory (or QIP = PSPACE in complexity-theoretic terminology). This
793 characterization implies the striking fact that quantum computing does
794 not provide any increase in computational power over classical
795 computing in the context of interactive proof systems.
796 </p><p>I will not assume that the audience for this talk has any familiarity
797 with either quantum computing or complexity theory; and to be true to
798 the spirit of the interactive proof system model, I hope to make this
799 talk as interactive as possible -- I will be happy to explain anything
800 related to the talk that I can that people are interested in learning
805 <eventitem date="2010-02-26" time="7:00 PM" room="CnD Lounge" title="Contest Closing">
806 <short><p>The <a href="http://contest.csclub.uwaterloo.ca">contest</a> is coming to a close tomorrow, so to finish it in style we will be having ice cream and code friday night.
807 It would be a shame if Waterloo lost (we're not on top of the <a href="http://csclub.uwaterloo.ca/contest/rankings.php">leaderboard</a> right now) so come out and hack for the home team.</p></short>
810 <eventitem date="2010-02-25" time="4:30 PM" room="DC1302" title="CSCF Town Hall">
812 <short><p>Come to a town hall style meeting with the managers of CSCF to discuss how to improve the undergraduate (student.cs) computing environment. Have gripes? Suggestions? Requests? Now is the time to voice them.
816 <abstract><p>Come to a town hall style meeting with the managers of CSCF to discuss how
817 to improve the undergraduate (student.cs) computing environment. Have gripes?
818 Suggestions? Requests? Now is the time to voice them.
819 </p><p>CSCF management (Bill Ince, Associate Director; Dave Gawley, Infrastructure Support;
820 Dawn Keenan, User Support; Lawrence Folland, Research Support) will be at the
821 meeting to listen to student concerns and suggestions. Information gathered from
822 the meeting will be summarized and taken to the CSCF advisory committee for
823 discussion and planning.
828 <eventitem date="2010-02-23" time="04:30 PM" room="MC5136B" title="The Best Algorithms are Randomized Algorithms">
830 <short><p>In this talk Nicholas Harvey discusses the prevalence of randomized algorithms and their application to solving optimization problems on graphs; with startling results compared to deterministic algorithms.
834 <abstract><p>For many problems, randomized algorithms are either the fastest algorithm or the simplest algorithm;
835 sometimes they even provide the only known algorithm. Randomized algorithms have become so prevalent
836 that deterministic algorithms could be viewed as a curious special case. In this talk I will describe
837 some startling examples of randomized algorithms for solving some optimization problems on graphs.
842 <eventitem date="2010-02-09" time="4:30 PM" room="DC1304" title="An Introduction to Vector Graphics Libraries with Cairo">
844 <short><p>Cairo is an open source, cross platform, vector graphics library with the ability to output to many kinds of surfaces, including PDF, SVG and PNG surfaces, as well as X-Window, Win32 and Quartz 2D backends. Unlike the raster graphics used with programmes and libraries such as The Gimp and ImageMagick, vector graphics are not defined by grids of pixels, but rather by a collection of drawing operations. These operations detail how to draw lines, fill shapes, and even set text to create the desired image. This has the advantages of being infinitely scalable, smaller in file size, and simpler to express within a computer programme. This talk will be an introduction to the concepts and metaphors used by vector graphics libraries in general and Cairo in particular.
848 <abstract><p>Cairo is an open source, cross platform, vector graphics library with the ability to
849 output to many kinds of surfaces, including PDF, SVG and PNG surfaces, as well as
850 X-Window, Win32 and Quartz 2D backends. Unlike the raster graphics used with programmes
851 and libraries such as The Gimp and ImageMagick, vector graphics are not defined by grids
852 of pixels, but rather by a collection of drawing operations. These operations detail how to
853 draw lines, fill shapes, and even set text to create the desired image. This has the
854 advantages of being infinitely scalable, smaller in file size, and simpler to express within
855 a computer programme. This talk will be an introduction to the concepts and metaphors used
856 by vector graphics libraries in general and Cairo in particular.
861 <eventitem date="2010-02-11" time="4:30 PM" room="MC3005" title="UNIX 101 Encore">
863 <short><p>New to Unix? No problem, we'll teach you to power use circles around your friends! The popular tutorial returns for a second session, in case you missed the first one.
867 <abstract><p>New to Unix? No problem, we'll teach you to power use circles around your friends!
868 The popular tutorial returns for a second session, in case you missed the first one.
869 </p><p>This first tutorial is an introduction to the Unix shell environment, both on the student
870 servers and on other Unix environments. Topics covered include: using the shell, both basic
871 interaction and advanced topics like scripting and job control, the filesystem and manipulating
872 it, and ssh. If you feel you're already familiar with these topics don't hesitate to come
873 to Unix 102 to learn about documents, editing, and other related tasks, or watch out
874 for Unix 103 and 104 that get much more in depth into power programming tools on Unix.
878 <eventitem date="2010-02-10" time="4:30 PM" room="MC3003" title="UNIX 101">
880 <short><p>New to Unix? No problem, we'll teach you to power use circles around your friends!
884 <abstract><p>New to Unix? No problem, we'll teach you to power use circles around your friends!
885 </p><p>This first tutorial is an introduction to the Unix shell environment, both on the student
886 servers and on other Unix environments. Topics covered include: using the shell, both basic
887 interaction and advanced topics like scripting and job control, the filesystem and manipulating
888 it, and ssh. If you feel you're already familiar with these topics don't hesitate to come
889 to Unix 102 to learn about documents, editing, and other related tasks, or watch out
890 for Unix 103 and 104 that get much more in depth into power programming tools on Unix.
894 <eventitem date="2010-01-18" time="15:30 PM" room="MC2066" title="Wilderness Programming">
896 <short><p>Paul Lutus describes his early Apple II software development days, conducted from the far end of a 1200-foot power cord, in a tiny Oregon cabin. Paul describes how he wrote a best-seller (Apple Writer) in assembly language, while dealing with power outages, lightning storms and the occasional curious bear.
900 <abstract><p>Paul Lutus describes his early Apple II software development days, conducted
901 from the far end of a 1200-foot power cord, in a tiny Oregon cabin. Paul
902 describes how he wrote a best-seller (Apple Writer) in assembly language,
903 while dealing with power outages, lightning storms and the occasional
905 </p><p>Paul also describes his subsequent four-year solo around-the-world sail in a
906 31-foot boat. And be ready with your inquiries -- Paul will answer your
908 </p><p>Paul Lutus has a wide background in science and technology. He designed spacecraft
909 components for the NASA Space Shuttle and created a mathematical model of the solar
910 system used during the Viking Mars lander program. Then, at the beginning of the
911 personal computer revolution, Lutus switched career paths and took up computer
912 science. His best-known program is "Apple Writer," an internationally successful
913 word processing program for the early Apple computers.
918 <eventitem date="2010-01-26" time="05:00 PM" room="DC1302" title="Deep learning with multiplicative interactions">
920 <short><p>Geoffrey Hinton, from the University of Toronto and the Canadian Institute for Advanced Research, will discuss some of his latest work in learning networks and artificial intelligence. The talk will be accessable, so don't hesitate to come out. More information about Dr. Hinton's research can be found on <a href="http://www.cs.toronto.edu/~hinton/">his website</a>.
924 <abstract><p>Deep networks can be learned efficiently from unlabeled data. The layers
925 of representation are learned one at a time using a simple learning
926 module, called a "Restricted Boltzmann Machine" that has only one layer
927 of latent variables. The values of the latent variables of one
928 module form the data for training the next module. Although deep
929 networks have been quite successful for tasks such as object
930 recognition, information retrieval, and modeling motion capture data,
931 the simple learning modules do not have multiplicative interactions which
932 are very useful for some types of data.
933 </p><p>The talk will show how a third-order energy function can be factorized to
934 yield a simple learning module that retains advantageous properties of a
935 Restricted Boltzmann Machine such as very simple exact inference and a
936 very simple learning rule based on pair-wise statistics. The new module
937 contains multiplicative interactions that are useful for a variety of
938 unsupervised learning tasks. Researchers at the University of Toronto
939 have been using this type of module to extract oriented energy from image
940 patches and dense flow fields from image sequences. The new module can
941 also be used to allow motions of a particular style to be achieved by
942 blending autoregressive models of motion capture data.
949 <eventitem date="2009-12-05" time="6:30 PM" room="MC3036" edate="2009-12-05" etime="11:55 PM" title="The Club That Really Likes Dinner">
950 <short><p>Come on out to the club's termly end of term dinner, details in the abstract</p></short>
951 <abstract><p>The dinner will be potluck style at the Vice President's house, please RSVP (respond swiftly to the vice president)
952 <a href="https://csclub.uwaterloo.ca/rsvp">here</a> if you plan on attending. If you don't know how to get there meet at the club
953 office at 6:30 PM, a group will be leaving to lead you there.</p></abstract>
956 <eventitem date="2009-11-27" time="7:00 PM" room="Comfy Lounge" edate="2009-11-28" etime="7:00 AM" title="Code Party!!11!!">
958 <short><p>A fevered night of code, friends, fun, energy drinks, and the CSC. Facebook will be around to bring some food and hang out.
962 <abstract><p>Come join us for a night of coding. Get in touch with more experianced coders,
963 advertize for/bug squash on your favourite open source project, write that personal
964 project you were planning to do for a while but haven't found the time. Don't
965 have any ideas but want to sit and hack? Try your hand at the Facebook puzzles,
966 write a new app, or just chill and watch scifi.
971 <eventitem date="2009-11-05" time="4:30 PM" room="MC2065" title="In the Beginning">
973 <short><p>To most CS students an OS kernel is pretty low level. But there is something even lower, the instructions that must be executed to get the CPU ready to accept a kernel. That is, if you look at any processor's reference manual there is a page or two describing the state of the CPU when it powered on. This talk describes what needs to happen next, up to the point where the first kernel instruction executes.
977 <abstract><p>To most CS students an OS kernel is pretty low level. But there is
978 something even lower, the instructions that must be executed to get the
979 CPU ready to accept a kernel. That is, if you look at any processor's
980 reference manual there is a page or two describing the state of the CPU
981 when it powered on. This talk describes what needs to happen next,
982 up to the point where the first kernel instruction executes.
983 </p><p>This part of execution is extremely architecture-dependent. Those of
984 you who have any experience with this aspect of CS probably know the x86
985 architecture, and think it's horrible, which it is. I am going to talk
986 about the ARM architecture, which is inside almost all mobile phones,
987 and which allows us to look at a simple implementation that includes
993 <eventitem date="2009-10-20" time="04:30 PM" room="MC3036" title="CSC Goes To Dooly's">
995 <short><p>We're going to Dooly's to play pool. What more do you want from us? Come to the Club office and we'll all bus there together. We've got discount tables for club members so be sure to be there.
999 <abstract><p>We're going to Dooly's to play pool. What more do you want from us?
1000 Come to the Club office and we'll all bus there together. We've got
1001 discount tables for club members so be sure to be there.
1006 <eventitem date="2009-10-16" time="7:00 PM" room="Comfy Lounge" title="Code Party and Contest Finale">
1008 <short><p>Come on out for a night of code, contests, and energy drinks. Join the Computer Scinece Club for the finale of the Google AI Challenge and an all night code party. Finish up your entry, or start it (its not too late). Not interested in the contest? Come out anyway for a night of coding and comradarie with us.
1012 <abstract><p>Come on out for a night of code, contests, and energy drinks. Join the Computer
1013 Scinece Club for the finale of the Google AI Challenge and an all night code party.
1014 Finish up your entry, or start it (its not too late). Not interested in the contest?
1015 Come out anyway for a night of coding and comradarie with us.
1016 </p><p>Included in the party will be the contest finale and awards cerimony, so if you've
1017 entered be sure to stick arround to collect the spoils of victory, or see just who
1018 that person you couldn't edge off is.
1023 <eventitem date="2009-10-08" time="4:30 PM" room="MC3003" title="UNIX 103">
1025 <short><p>In this long-awaited third installment of the popular Unix Tutorials the friendly experts of the CSC will teach you the simple art of version control. You will learn the purpose and use of two different Version Control Systems (git and subversion). This tutorial will advise you in the discipline of managing the source code of your projects and enable you to quickly learn new Version Control Systems in the work place -- a skill that is much sought after by employers.
1029 <abstract><p>In this long-awaited third installment of the popular Unix Tutorials the
1030 friendly experts of the CSC will teach you the simple art of version control.
1031 You will learn the purpose and use of two different Version Control Systems
1032 (git and subversion). This tutorial will advise you in the discipline of
1033 managing the source code of your projects and enable you to quickly learn new
1034 Version Control Systems in the work place -- a skill that is much sought after
1040 <eventitem date="2009-10-14" time="2:30 PM" room="DC1304" title="UofT Graduate School Information Session">
1041 <short><p> "Is Graduate School for You?" Get the answers to your grad school questions - and have a bite to eat, our treat</p>
1043 <abstract><p> Join Prof. Greg Wilson, faculty member in the Software Engineering research group in the UofT's Department of Computer Science,
1044 as he gives insight into studying at the graduate level-what can be expected, what does UofT offer, is it right for you? Pizza and pop will
1045 be served. <b>Come see what grad school is all about!</b>. All undergraduate students are welcome; registration is not required.</p>
1046 <p>For any questions about the program, visit <a href="http://www.cs.toronto.edu/dcs/prospective-grad.html">UofT's website</a>. This
1047 event is not run by the CS Club, and is announced here for the benefit of our members.</p></abstract>
1050 <eventitem date="2009-10-03" time="10:00 AM" edate="2009-10-03" etime="3:30 PM" room="DC1301 FishBowl" title="Linux Install Fest">
1052 <short><p>Interested in trying Linux but don't know where to start?
1053 Come to the Linux install fest to demo Linux, get help installing it
1054 on your computer, either stand alone or a dual boot, and help setting
1055 up your fresh install. Have lunch and hang around if you like, or just come in for a CD.
1059 <abstract><p>Interested in trying Linux but don't know where to start?
1060 Come to the Linux install fest to demo Linux, get help installing it on
1061 your computer, either stand alone or a dual boot, and help setting
1062 up your fresh install. Have lunch and hang around if you like, or just
1063 come in for a qick install.
1068 <eventitem date="2009-10-01" time="4:30 PM" room="MC3003" title="UNIX 102">
1070 <short><p>The next installment in the CS Club's popular Unix tutorials UNIX 102 introduces powerful text editing tools for programming and document formatting.
1074 <abstract><p>Unix 102 is a follow up to Unix 101, requiring basic knowledge of the shell.
1075 If you missed Unix101 but still know your way around you should be fine.
1076 Topics covered include: "real" editors, document typesetting with LaTeX
1077 (great for assignments!), bulk editing, spellchecking, and printing in the
1078 student environment and elsewhere.
1079 </p><p>If you aren't interested or feel comfortable with these taskes, watch out for
1080 Unix 103 and 104 to get more depth in power programming tools on Unix.
1085 <eventitem date="2009-09-28" time="4:30 PM" edate="2009-10-09" etime="11:59 OM" room="MC3003" title="AI Programming Contest sponsored by Google">
1087 <short><p>Come learn how to write an intelligent game-playing program.
1088 No past experience necessary. Submit your program using the <a href="http://csclub.uwaterloo.ca/contest/">online web interface</a>
1089 to watch it battle against other people's programs. Beginners and experts welcome! Prizes provided by google,
1090 including the delivery of your resume to google recruiters.
1094 <abstract><p>Come learn how to write an intelligent game-playing program.
1095 No past experience necessary. Submit your program using the <a href="http://csclub.uwaterloo.ca/contest/">online
1096 web interface</a> to watch it battle against other people's programs.
1097 Beginners and experts welcome!
1098 </p><p>The contest is sponsored by Google, so be sure to compete for a chance
1099 to get noticed by them.
1100 </p><p>Prizes for the top programs:
1101 <ul><li>$100 in Cash Prizes</li>
1102 <li> Google t-shirts</li>
1103 <li>Fame and recognition</li>
1104 <li>Your resume directly to a Google recruiter</li>
1109 <eventitem date="2009-09-24" time="4:30 PM" room="MC3003" title="UNIX 101">
1112 New to Unix? No problem, we'll teach you to power use circles around your friends!
1117 New to Unix? No problem, we'll teach you to power use circles around your friends!
1119 This first tutorial is an introduction to the Unix shell environment, both on the student
1120 servers and on other Unix environments. Topics covered include: using the shell, both basic
1121 interaction and advanced topics like scripting and job control, the filesystem and manipulating
1122 it, and ssh. If you feel you're already familiar with these topics don't hesitate to come
1123 to Unix 102 to learn about documents, editing, and other related tasks, or watch out
1124 for Unix 103 and 104 that get much more in depth into power programming tools on Unix.
1128 <eventitem date="2009-09-15" time="5:00PM" edate="2009-09-15" etime="6:00 PM"
1129 room="Comfy Lounge" title="Elections">
1131 Nominations are open now, either place your name on the nominees board or
1132 e-mail <a href="mailto:cro@csclub.uwaterloo.ca">the CRO</a>
1133 to nominate someone for a position.
1134 Come to the Comfy Lounge to elect your fall term executive. Contact
1135 <a href="mailto:cro@csclub.uwaterloo.ca">the CRO</a> if you have questions.
1140 <!-- Spring 2009 -->
1141 <eventitem date="2009-07-23" time="4:30 PM" edate="2009-07-23" etime="6:00 PM"
1142 room="MC 3003" title="Unix 103">
1144 In this long-awaited third installment of the popular Unix Tutorials the dark
1145 mages of the CSC will train you in the not-so-arcane magick of version control.
1146 You will learn the purpose and use of two different Version Control Systems
1147 (git and subversion). This tutorial will advise you in the discipline of
1148 managing the source code of your projects and enable you to quickly learn new
1149 Version Control Systems in the work place -- a skill that is much sought after
1154 <eventitem date="2009-07-17" time="7:00 PM" edate="2009-07-18" etime="4:00 AM"
1155 room="MC 3001" title="Code Party">
1157 Have an assignment or project you need to work on? We
1158 will be coding from 7:00pm until 4:00am starting on Friday, July 17th
1159 in the Comfy lounge. Join us!
1163 <eventitem date="2009-07-07" time="3:00 PM" etime="5:00 PM" room="DC 1302"
1164 title="History of CS Curriculum at UW">
1166 This talk provides a personal overview of the evolution of the
1167 undergraduate computer science curriculum at UW over the past forty
1168 years, concluding with an audience discussion of possible future
1173 <eventitem date="2009-06-22" time="4:30 PM" etime="6:30 PM" room="MC 4041"
1175 <short><p> Come and drink tea and read an academic CS paper with
1176 the Paper Club. We will be meeting from 4:30pm until 6:30pm on
1177 Monday, June 22th on the 4th floor of the MC (exact room number
1178 TBA). See http://csclub.uwaterloo.ca/~paper
1182 <eventitem date="2009-06-19" time="5:30 PM" room="Dooly's" title="Dooly's Night">
1184 The CSC will be playing pool at Dooly's. Join us for only a few dollars.
1188 <eventitem date="2009-06-05" time="7:00 PM" edate="2009-06-06" etime="4:00 AM"
1189 room="MC 3001" title="Code Party">
1191 Have an assignment or project you need to work on? We
1192 will be coding from 7:00pm until 7:00am starting on Friday, June 5th
1193 in the Comfy lounge. Join us!
1197 <eventitem date="2009-06-02" time="4:30 PM" room="MC 2037" title="Unix 101">
1199 Need to use the UNIX environment for a course, want to overcome your fears of
1200 the command line, or just curious? Come and learn the arcane secrets of the
1201 UNIX command line interface from CSC mages. After this tutorial you will be
1202 comfortable with the essentials of navigating, manipulating and viewing files,
1203 and processing data at the UNIX shell prompt.
1207 <eventitem date="2009-05-12" time="12:00 PM" room="MC 2034" title="PHP on Windows">
1208 <short><p>PHP Programming Contest Info Session</p></short>
1210 Port or create a new PHP web application and you could win a prize
1211 of up to $10k. Microsoft is running a programming contest for PHP
1212 developers willing to support the Windows platform. The contest is
1213 ongoing; this will be a short introduction to it by
1214 representatives of Microsoft and an opportunity to ask questions.
1215 Pizza and pop will be provided.
1220 <!-- Winter 2009 -->
1221 <eventitem date="2009-04-02" time="4:30 PM" room="DC1302" title="Rapid prototyping and mathematical art">
1223 <short><p>A talk by Craig S. Kaplan.</p></short>
1226 <abstract><p>The combination of computer graphics, geometry, and rapid
1227 prototyping technology has created a wide range of exciting
1228 opportunities for using the computer as a medium for creative
1229 expression. In this talk, I will describe the most popular
1230 technologies for computer-aided manufacturing, discuss
1231 applications of these devices in art and design, and survey
1232 the work of contemporary artists working in the area (with a
1233 focus on mathematical art). The talk will be primarily
1234 non-technical, but I will mention some of the mathematical
1235 and computational techniques that come into play.
1239 <eventitem date="2009-04-03" time="6:00 PM" edate="2009-04-04"
1240 etime="6:00 AM" room="TBA" title="CTRL-D">
1243 Join the Club That Really Likes Dinner for the End Of Term
1244 party! Inquire closer to the date for details.
1249 This is not an official club event and receives no funding.
1250 Bring food, drinks, deserts, etc.
1255 <eventitem date="2009-03-27" time="6:00 PM" edate="2009-03-28"
1256 etime="12:00 PM" room="Comfy Lounge (MC)"
1260 CSC Code Party! Same as always - no sleep, lots of caffeine,
1261 and really nerdy entertainment. Bonus: Free Cake!
1266 This code party will have the usual, plus it will double as the
1267 closing of the programming contest. Our experts will be
1268 available to help you polish off your submission.
1273 <eventitem date="2009-03-19" time="4:30 PM" edate="2009-03-28"
1274 etime="12:00 PM" room="MC2061"
1275 title="Artificial Intelligence Contest">
1278 Come out and try your hand at writing a computer program that
1279 plays Minesweeper Flags, a two-player variant of the classic
1280 computer game, Minesweeper. Once you're done, your program
1281 will compete head-to-head against the other entries in a
1282 fierce Minesweeper Flags tournament. There will be a contest
1283 kick-off session on Thursday March 19 at 4:30 PM in room
1284 MC3036. Submissions will be accepted until Saturday March 28.
1289 Come out and try your hand at writing a computer program that
1290 plays Minesweeper Flags, a two-player variant of the classic
1291 computer game, Minesweeper. Once you're done, your program
1292 will compete head-to-head against the other entries in a
1293 fierce Minesweeper Flags tournament. There will be a contest
1294 kick-off session on Thursday March 19 at 4:30 PM in room
1295 MC3036. Submissions will be accepted until Saturday March 28.
1300 <eventitem date="2009-03-05" time="4:30 PM" edate="2009-03-05"
1301 etime="6:30 PM" room="Comfy Lounge"
1302 title="SIGGRAPH Night">
1305 Come out and watch the SIGGRAPH (Special Interest Group on
1306 Graphics) conference video review. A video of insane, amazing,
1307 and mind blowing computer graphics. .
1312 The ACM SIGGRAPH (Special Interest Group on Graphics) hosts a
1313 conference yearly in which the latest and greatest in computer
1314 graphics premier. They record video and as a result produce a
1315 very nice Video Review of the conference. Come join us watching
1316 these videos, as well as a few professors from the UW Computer
1317 Graphics Lab. There will be some kind of food and drink, and its
1318 guranteed to be dazzling.
1323 <eventitem date="2009-03-12" time="8:00 AM" edate="2009-03-13"
1324 etime="9:00 PM" room="Toronto Hilton"
1325 title="Canadian Undergraduate Technology Conference">
1328 See <a href="http://www.cutc.ca">cutc.ca</a> for more details.
1333 The Canadian Undergraduate Technology Conference is Canada's
1334 largest student-run conference. From humble roots it has emerged
1335 as a venue that offers an environment for students to grow
1336 socially, academically, and professionally. We target to exceed
1337 our past record of 600 students from 47 respected institutions
1338 nationwide. The event mingles ambitious as well as talented
1339 students with leaders from academia and industry to offer
1340 memorable experiences and valuable opportunities.
1345 <eventitem date="2009-03-09" time="3:00 PM" room="DC1302"
1346 title="Prabhakar Ragde">
1348 Functional Lexing and Parsing</p></short>
1351 This talk will describe a non-traditional functional approach
1352 to the classical problems of lexing (breaking a stream of
1353 characters into "words" or tokens) and parsing (identifying
1354 tree structure in a stream of tokens based on a grammar,
1355 e.g. for a programming language that needs to be compiled or
1356 interpreted). The functional approach can clarify and organize
1357 a number of algorithms that tend to be opaque in their
1358 conventional imperative presentation. No prior background in
1359 functional programming, lexing, or parsing is assumed.
1364 <eventitem date="2009-03-12" time="5:00 PM" etime="7:00 PM" room="RAC2009"
1365 title="IQC - Programming Quantum Computers">
1368 A brief intro to Quantum Computing and why it matters,
1369 followed by a talk on programming quantum computers. Meet at
1370 the CSC at 4:00PM for a guided walk to the RAC.
1375 Raymond Laflamme is the director of the Institute for Quantum
1376 Computing at the University of Waterloo and holds the Canada
1377 Research Chair in Quantum Information. He will give a brief
1378 introduction to quantum computing and why it matters, followed
1379 by a talk on programming quantum computers. There will be
1380 tours of the IQC labs at the end, and pizza will be provided
1381 back at the CSC for all attendees.
1386 <eventitem date="2009-02-27" time="5:00 PM" etime="7:00 PM" room="CSC Office: MC3036" title="Dooly's Night">
1388 Come join the CSC as we head to Dooly's.</p></short>
1390 Meet us at the Club office as we head to Dooly's for cheap tables and good times.</p></abstract>
1393 <eventitem date="2009-02-05" time="5:30 PM" room="MC2062 and MC2063" title="UNIX 101 and 102">
1395 Continuing the popular Unix Tutorials with a rerun of 101 and the debut of 102.</p></short>
1397 Unix 101 is an introduction to the Unix shell environment, both on the student
1398 servers and on other Unix environments. Topics covered include: using the shell, both basic
1399 interaction and advanced topics like scripting and job control, the filesystem and manipulating
1400 it, and ssh. </p><p>
1401 Unix 102 is a follow up to Unix 101, requiring basic knowledge of the shell.
1402 If you missed Unix101 but still know your way around you should be fine.
1403 Topics covered include: "real" editors, document typesetting with LaTeX
1404 (great for assignments!), bulk editing, spellchecking, and printing in the
1405 student environment and elsewhere. </p><p>
1406 If you aren't interested or feel comfortable with these taskes, watch out for
1407 Unix 103 and 104 to get more depth in power programming tools on Unix. </p></abstract>
1411 <eventitem date="2009-02-03" time="5:30 PM" room="MC3003" title="UNIX 101">
1412 <short><p> New to Unix? No problem, we'll teach you to power use circles around your friends!</p></short>
1413 <abstract><p>This first tutorial is an introduction to the Unix shell environment, both on the student
1414 servers and on other Unix environments. Topics covered include: using the shell, both basic
1415 interaction and advanced topics like scripting and job control, the filesystem and manipulating
1416 it, and ssh. If you feel you're already familiar with these topics don't hesitate to come
1417 to Unix 102 to learn about documents, editing, and other related tasks, or watch out
1418 for Unix 103 and 104 that get much more in depth into power programming tools on Unix.</p></abstract>
1421 <eventitem date="2009-02-06" time="7:00 PM" room="Comfy Lounge" title="Code Party!">
1424 There is a CSC Code Party starting at 7:00PM (19:00). Come out
1425 and enjoy some good old programming and meet others interested
1426 in writing code! Free energy drinks and snacks for all. Plus,
1427 we have lots of things that need to be done if you're looking
1428 for a project to work on!
1433 Code Party. Awesome. Need we say more?
1438 <eventitem date="2009-01-16" time="7:30 PM" room="Comfy Lounge" title="Code party !!11!!1!!">
1440 <short><p>There is a CSC Code Party Tonight starting at 7:30PM
1441 (1930) until we get bored (likely in the early in morning). Come
1442 out for fun hacking times, spreading Intertube memes (optional),
1443 hacking on the OpenMoko, creating music mixes, and other general
1444 classyness. If we manage to swing it, there will be delicious
1445 energy drinks for your consumption! Alternatively, if we don't we
1446 will have each other as well as some delicious tea and
1447 coffee. Perhaps a crumpet
1451 <abstract><p>There is a CSC Code Party Tonight starting at 7:30PM
1452 (1930) until we get bored (likely in the early in
1453 morning). Come out for fun hacking times, spreading Intertube
1454 memes (optional), hacking on the OpenMoko, creating music
1455 mixes, and other general classyness. If we manage to swing it,
1456 there will be delicious energy drinks for your consumption!
1457 Alternatively, if we don't we will have each other as well as
1458 some delicious tea and coffee. Perhaps a crumpet
1463 <eventitem date="2009-01-29" time="6:30 PM" room="Modern Languages Theatre" title="Richard M. Stallman">
1464 <short><p> The Free Software Movement and the GNU/Linux Operating System </p>
1468 Richard Stallman will speak about the Free Software Movement, which
1469 campaigns for freedom so that computer users can cooperate to
1470 control their own computing activities. The Free Software Movement
1471 developed the GNU operating system, often erroneously referred to as
1472 Linux, specifically to establish these freedoms.</p>
1473 <p><b>About Richard Stallman:</b>
1474 Richard Stallman launched the development of the GNU operating system (see
1475 <a href="http://www.gnu.org">www.gnu.org</a>) in 1984. GNU is free
1476 software: everyone has the freedom to copy it and redistribute it,
1477 as well as to make changes either large or small. The GNU/Linux
1478 system, basically the GNU operating system with Linux added, is used
1479 on tens of millions of computers today. Stallman has received the
1480 ACM Grace Hopper Award, a MacArthur Foundation fellowship, the
1481 Electronic Frontier Foundation's Pioneer award, and the the Takeda
1482 Award for Social/Economic Betterment, as well as several honorary
1487 <eventitem date="2009-01-22" time="12:00 PM" room="MC5136" title="Joel Spolsky">
1488 <short><p> Joel Spolsky, of <a href="http://www.joelonsoftware.com">Joel on Software</a> will be giving a talk entitled "Computer Science Education and the Software Industry".</p>
1490 <abstract><p><b>About Joel Spolsky:</b> Joel Spolsky is a
1491 globally-recognized expert on the software development process. His
1492 website <em>Joel on Software</em>
1493 (<a href="http://www.joelonsoftware.com/">www.joelonsoftware.com</a>)
1494 is popular with software developers around the world and has been
1495 translated into over thirty languages. As the founder
1496 of <a href="http://www.fogcreek.com/">Fog Creek Software</a> in New
1498 created <a href="http://www.fogcreek.com/FogBugz">FogBugz</a>, a
1499 popular project management system for software teams. He is the
1500 co-creator of <a href="http://stackoverflow.com/">Stack
1501 Overflow</a>, a programmer Q&A site. Joel has worked at
1502 Microsoft, where he designed VBA as a member of the Excel team, and
1503 at Juno Online Services, developing an Internet client used by
1505 written <a href="http://www.joelonsoftware.com/BuytheBooks.html">four
1506 books</a>: <em>User Interface Design for Programmers</em> (Apress,
1507 2001), <em>Joel on Software</em> (Apress, 2004), <em>More Joel on
1508 Software </em>(Apress, 2008), and <em>Smart and Gets Things Done:
1509 Joel Spolsky's Concise Guide to Finding the Best Technical
1510 Talent </em>(Apress, 2007). He also writes a monthly column
1511 for<strong> </strong><em><a href="http://www.inc.com/">Inc
1512 Magazine</a>. </em>Joel holds a BS from Yale in Computer
1513 Science. Before college he served in the Israeli Defense Forces as a
1514 paratrooper, and he was one of the founders of Kibbutz Hanaton.</p>
1518 <eventitem date="2009-01-13" time="4:20 PM" room="Comfy Lounge" title="Term Elections">
1519 <short><p>Winter Elections</p>
1524 <eventitem date="2008-11-15" time="6:30 AM" room="Toronto" title="Changing the World Conference">
1526 <short><p>Organized by Queen's students, Changing the World aims to bring together the world's greatest visionaries to inspire people to innovate and better our world. Among these speakers include Nobel Peace Prize winner, Eric Chivian. He was a recipient for his work on stopping nuclear war.
1530 <abstract><p>Organized by Queen's students, Changing the World
1531 aims to bring together the world's greatest visionaries to
1532 inspire people to innovate and better our world. Among these
1533 speakers include Nobel Peace Prize winner, Eric Chivian. He
1534 was a recipient for his work on stopping nuclear war.
1535 </p><p>The conference is modeled after TED (Technology,
1536 Entertainment, Design), an annual conference uniting the
1537 world's most fascinating thinkers and doers, and like TED,
1538 each speaker is given 18 minutes to give the talk of their
1540 </p><p>Specifically for students in CS/Math, 50 tickets have
1541 been reserved (non-students: $500). For those who would like
1542 to attend, please pick up your ticket in the Computer Science
1543 Club office. The tickets are limited and they are first come
1549 <eventitem date="2008-11-06" time="10:00 AM" room="SLC Multipurpose Room" title="Linux Install Fest">
1551 <short><p>Come join the CSC in celebrating the new releases of
1552 Ubuntu Linux, Free BSD and Open BSD, and get a hand installing one
1553 of them on your own system.
1557 <abstract><p>Come join the CSC in celebrating the new releases of
1558 Ubuntu Linux, Free BSD and Open BSD, and get a hand installing
1559 one of them on your own system.
1560 </p><p>This is an event to celebrate the releases of new
1561 versions of Ubuntu Linux, OpenBSD, and FreeBSD. CDs will be
1562 available and everyone is invited to bring their PC or laptop
1563 to get help installing any of these Free operating
1564 systems. Knowledgeable CSC members will be available to help
1565 with any installation troubles, or to troubleshooting any
1566 existing problems that users may have.
1567 </p><p>This event will also promote gaming on Linux, as well as
1568 FLOSS (Free/Libre and Open Source Software) in general. We may
1569 also have a special guest (Ian Darwin, of OpenBSD and OpenMoko
1574 <eventitem date="2008-11-10" time="4:30 PM" room="MC4061" title="Functional Programming">
1576 <short><p>This talk will survey concepts, techniques, and
1577 languages for functional programming from both historical and
1578 contemporary perspectives, with reference to Lisp, Scheme, ML,
1579 Haskell, and Erlang. No prior background is assumed.
1583 <abstract><p>This talk will survey concepts, techniques, and
1584 languages for functional programming from both historical and
1585 contemporary perspectives, with reference to Lisp, Scheme, ML,
1586 Haskell, and Erlang. No prior background is assumed.
1591 <eventitem date="2008-10-24" time="6:00 PM" room="Comfy Lounge" title="Code Party">
1593 Come join us for a night of coding. Get in touch with more experianced coders,
1594 advertize for/bug squash on your favourite open source project, write that personal
1595 project you were planning to do for a while but haven't found the time. Don't
1596 have any ideas but want to sit and hack? We can find something for you to do.
1599 A fevered night of code, friends, fun, free energy drinks, and the CSC.
1603 <eventitem date="2008-10-16" time="4:30 PM" room="Comfy Lounge" title="SIGGRAPH Night">
1605 Come out and watch the SIGGRAPH (Special Interest Group on Graphics) conference video
1606 review. A video of insane, amazing, and mind blowing computer graphics.
1609 The ACM SIGGRAPH (Special Interest Group on Graphics) hosts a conference yearly
1610 in which the latest and greatest in computer graphics premier. They record video
1611 and as a result produce a very nice Video Review of the conference. Come join us
1612 watching these videos, as well as a few professors from the UW Computer Graphics
1613 Lab. There will be some kind of food and drink, and its guranteed to be dazzling.
1617 <eventitem date="2008-09-12" time="4:30 PM" room="Comfy Lounge" title="Meet the CSC">
1619 Come out and meet other CSC members, find out about the CSC, meet the executive
1620 nominees, and join if you like what you see. Nominees should plan on attending.
1624 <eventitem date="2008-09-16" time="4:30 PM" room="Comfy Lounge" title="CSClub Elections">
1626 Elections are scheduled for Tues, Sep 16 @ 4:30 pm in the comfy lounge.
1627 The nomination period closes on Mon, Sep 15 @ 4:30 pm. Nominations may be
1628 sent to cro@csclub.uwaterloo.ca. Candidates should not engage in
1629 campaigning after the nomination period has closed.
1633 <eventitem date="2008-09-25" time="4:30 PM" room="MC2037" title="Unix 101">
1635 New to Unix? No problem, we'll teach you to power use circles around your friends!
1638 This first tutorial is an introduction to the Unix shell environment, both on the student
1639 servers and on other Unix environments. Topics covered include: using the shell, both basic
1640 interaction and advanced topics like scripting and job control, the filesystem and manipulating
1641 it, and ssh. If you feel you're already familiar with these topics don't hesitate to come
1642 to Unix 102 to learn about documents, editing, and other related tasks, or watch out
1643 for Unix 103 and 104 that get much more in depth into power programming tools on Unix.
1647 <eventitem date="2008-10-07" time="4:30 PM" room="MC2037" title="Unix 101">
1649 New to Unix? No problem, we'll teach you to power use circles around your friends!
1652 This first tutorial is an introduction to the Unix shell environment, both on the student
1653 servers and on other Unix environments. Topics covered include: using the shell, both basic
1654 interaction and advanced topics like scripting and job control, the filesystem and manipulating
1655 it, and ssh. If you feel you're already familiar with these topics don't hesitate to come
1656 to Unix 102 to learn about documents, editing, and other related tasks, or watch out
1657 for Unix 103 and 104 that get much more in depth into power programming tools on Unix.
1661 <eventitem date="2008-10-09" time="4:30 PM" room="MC2037" title="Unix 102">
1663 Want more from Unix? No problem, we'll teach you to create and quickly edit high quality documents.
1666 This is a follow up to Unix 101, requiring basic knowledge of the shell. If you missed
1667 Unix101 but still know your way around you should be fine. Topics covered include: "real" editors,
1668 document typesetting with LaTeX (great for assignments!), bulk editing, spellchecking, and printing
1669 in the student environment and elsewhere. If you aren't interested or feel comfortable with these
1670 taskes, watch out for Unix 103 and 104 to get more depth in power programming tools on Unix. If you
1671 don't think you're ready go to Unix 101 on Tuesday to get familiarized with the shell environment.
1675 <eventitem date="2008-10-03" time="4:30 PM" room="MC2065" title="Game Sketching">
1676 <short><p>Juancho Buchanan, CTO Relic Entertainment</p></short>
1678 In this talk I will give an overview of the history of Relic and our
1679 development philosophy. The Talk will then proceed to talk about work
1680 that is being pursued in the area of early game prototyping with the
1681 introduction of game sketching methodology.
1686 Fired from his first job for playing Video Games Juancho Buchanan is
1687 currently the director of Technology for Relic Entertainment. Juancho
1688 Buchanan Wrote his first game in 1984 but then pursued other interests
1689 which included a master's in Program Visualization, A Doctorate in
1690 Computer Graphics, a stint as a professor at the University of Alberta
1691 where he pioneered early work in Non photo realistic rendering, A stint
1692 at Electronic Arts as Director, Advanced Technology, A stint at EA as
1693 the University Liaison Dude, A stint at Carnegie Mellon University where
1694 he researched the Game Sketching idea. His current role at Relic has
1695 him working with the soon to be released Dawn of War II.
1700 <eventitem date="2008-10-02" time="4:30 PM" room="MC4021" title="General Meeting 2">
1702 The second official general meeting of the term. Items on the adgenda are CSC Merch,
1703 upcoming talks, and other possible planned events, as well as the announcement of
1704 a librarian and planning of an office cleanout and a library organization day.
1708 <!-- Spring 2008 -->
1710 <!-- Winter 2008 -->
1712 <eventitem date="2008-02-08" time="4:30 PM" room="MC4042" title="A Brief History of Blackberry and the Wireless Data Telecom Industry">
1713 <short>Tyler Lessard</short>
1715 Tyler Lessard from RIM will present a brief history of BlackBerry
1716 technology and will discuss how the evolution of BlackBerry as an
1717 end-to-end hardware, software and services platform has been
1718 instrumental to its success and growth in the market. Find out how the
1719 BlackBerry service components integrate with wireless carrier networks
1720 and get a sneak peek at where the wireless data market is going.
1724 <eventitem date="2008-02-29" time="5:00 PM" room="BFG2125" title="Quantum Information Processing">
1725 <short>Raymond Laflamme</short>
1727 Information processing devices are pervasive in our society; from the 5
1728 dollar watches to multi-billions satellite network. These devices have
1729 allowed the information revolution which is developing around us. It has
1730 transformed not only the way we communicate or entertain ourselves but
1731 also the way we do science and even the way we think. All this
1732 information is manipulated using the classical approximation to the laws
1733 of physics, but we know that there is a better approximation: the
1734 quantum mechanical laws. Would using quantum mechanics for information
1735 processing be an impediment or could it be an advantage? This is the
1736 fundamental question at the heart of quantum information processing
1737 (QIP). QIP is a young field with an incredible potential impact reaching
1738 from the way we understand fundamental physics to technological
1739 applications. I will give an overview of the Institute for Quantum
1740 Computing, comment on the effort in this field at Waterloo and in
1741 Canada and, time permitted visit some of the IQC labs.
1745 <eventitem date="2008-02-14" time="4:00PM" room="MC2061" title="CSC Programming Contest 1">
1746 <short>Yes, we know this is Valentine's Day.</short>
1748 Contestants will be writing an artificial intelligence to play Risk. The
1749 prize will be awarded to the intelligence which wins the most
1750 head-to-head matches against competing entries. We're providing easy
1751 APIs for several languages, as well as full documentation of the game
1752 protocol so contestants can write wrappers for any additional language
1753 they wish to work in.
1756 We officially support entries in Scheme, Perl, Java, C, and C++. If you
1757 would like help developing an API for some other language contact us
1758 through the systems committee mailing list (we will require that your API
1759 is made available to all entrants).
1762 To kick off the contest we're hosting an in-house coding session starting
1763 at 4:00PM on Thursday, February 14th in MC2061. Members of our contest
1764 administration team will be available to help you work out the details of
1765 our APIs, answer questions, and provide the necessities of life (ie,
1766 pizza). Submissions will open no later than 5:00PM on February 14th
1767 and will close no earlier than 12:00PM on February 17th.
1770 Visit our contest site <a href="http://csclub.uwaterloo.ca/contest/"> here!</a>
1775 <eventitem date="2008-01-23" time="5:00 PM" room="MC 4020" title="Creating Distributed Applications with TIPC">
1776 <short>Elmer Horvath</short>
1778 The problem: coordinating and communicating between multiple processors
1779 in a distributed system (possibly containing heterogeneous elements)
1781 The open source TIPC (transparent interprocess communication) protocol
1782 has been incorporated into the Linux kernel and is available in VxWorks
1783 and, soon, other OSes. This emerging protocol has a number of
1784 advantages in a clustered environment to simplify application
1785 development while maintaining a familiar socket programming interface.
1786 The service oriented capabilities of TIPC help in applications easily
1787 finding required services in a system. The location transparent aspect
1788 of TIPC allows services to be located anywhere in the system as well as
1789 allowing redundant services for both load reduction and backup.
1791 Learn about the emerging cluster protocol.
1795 <eventitem date="2008-01-15" time="4:30 PM" room="Comfy Lounge" title="CSClub Elections">
1797 Elections are scheduled for Tues, Jan 15 @ 4:30 pm in the comfy lounge.
1798 The nomination period closes on Mon, Jan 14 @ 4:30 pm. Candidates should
1799 not engage in campaigning after the nomination period has closed.
1806 <eventitem date="2007-10-19" time="5:00 PM" room="MC4058" title="General Meeting">
1809 There is a general meeting scheduled for Friday, October 19, 2007 at 17:00.
1812 This is a chance to bring out any ideas and concerns about CSC happenings into the open, as well as a chance to make sure all CSC staff is up to speed on current CSC doings. The current agenda can be found at <a href="http://wiki.csclub.uwaterloo.ca/wiki/Friday_19_October_2007">http://wiki.csclub.uwaterloo.ca/wiki/Friday_19_October_2007.</a>
1817 <eventitem date="2007-09-25" time="1:30 PM" room="DC 1302" title="Virtual Reality, Real Law: The regulation of Property in Video Games">
1818 <short>Susan Abramovitch</short>
1821 This talk is run by the School of Computer Science
1824 How should virtual property created in games, such as weapons used in
1825 games like Mir 3 and real estate or clothing created or acquired in
1826 games like Second Life, be treated in law. Although the videogaming
1827 industry continues to multiply in value, virtual property created in
1828 virtual worlds has not been formally recognized by any North American
1829 court or legislature. A bridge has been taking shape from gaming's
1830 virtual economies to real world economies, for example, through
1831 unauthorized copying of designer clothes sold on Second Life for in-game
1832 cash, or real court damages awarded against deletion of player-earned
1833 swords in Mir 3. The trading of virtual property is important to a
1834 large number of people and property rights in virtual property are
1835 currently being recognized by some foreign legal bodies.
1838 Susan Abramovitch will explain the legal considerations in determining
1839 how virtual property can or should be governed, and ways it can be
1840 legally similar to tangible property. Virtual property can carry both
1841 physical and intellectual property rights. Typically video game
1842 developers retain these rights via online agreements, but Ms.
1843 Abramovitch questions whether these rights are ultimately enforceable
1844 and will describe policy issues that may impact law makers in deciding
1845 how to treat virtual property under such agreements.
1850 <eventitem date="2007-10-02" time="4:30 PM" room="MC4061" title="Putting the fun into Functional Languages and Useful Programming with OCaml/F#">
1851 <short>Brennan Taylor</short>
1853 <p>A lecture on why functional languages are important, practical applications, and some neat examples. Starting with an introduction to
1854 basic functional programming with ML syntax, continuing with the strengths of OCaml and F#, followed by some exciting examples. Examples include GUI
1855 programming with F#, Web Crawlers with F#, and OpenGL/GTK programming with OCaml. This lecture aims to display how powerful functional languages can
1859 <eventitem date="2007-10-09" time="4:45 PM" room="MC 4060" title="Join-Calculus with JoCaml. Concurrent programming that doesn't fry your brain">
1860 <short>Brennan Taylor</short>
1863 A lecture on the fundamentals of Pi-Calculus followed by an introduction
1864 to Join-Calculus in JoCaml with some great examples. Various concurrent
1865 control structures are explored, as well as the current limitations of
1866 JoCaml. The examples section will mostly be concurrent programming,
1867 however some basic distributed examples will be explored. This lecture
1868 focuses on how easy concurrent programming can be.
1873 <eventitem date="2007-10-15" time="4:30 PM" room="MC4041" title="Off-the-Record Messaging: Useful Security and Privacy for IM">
1874 <short>Ian Goldberg</short>
1877 Instant messaging (IM) is an increasingly popular mode of communication
1878 on the Internet. Although it is used for personal and private
1879 conversations, it is not at all a private medium. Not only are all of
1880 the messages unencrypted and unauthenticated, but they are all
1881 routedthrough a central server, forming a convenient interception point
1882 for an attacker. Users would benefit from being able to have truly
1883 private conversations over IM, combining the features of encryption,
1884 authentication, deniability, and forward secrecy, while working within
1885 their existing IM infrastructure.
1888 In this talk, I will discuss "Off-the-Record Messaging" (OTR), a widely
1889 used software tool for secure and private instant messaging. I will
1890 outline the properties of Useful Security and Privacy Technologies that
1891 motivated OTR's design, compare it to other IM security mechanisms, and
1892 talk about its ongoing development directions.
1895 Ian Goldberg is an Assistant Professor of Computer Science at the
1896 University of Waterloo, where he is a founding member of the
1897 Cryptography, Security, and Privacy (CrySP) research group. He holds a
1898 Ph.D. from the University of California, Berkeley, where he discovered
1899 serious weaknesses in a number of widely deployed security systems,
1900 including those used by cellular phones and wireless networks. He also
1901 studied systems for protecting the personal privacy of Internet users,
1902 which led to his role as Chief Scientist at Zero-Knowledge Systems (now
1903 known as Radialpoint), where he commercialized his research as the
1910 <eventitem date="2007-11-20" time="4:30 PM" room="MC 4041" title="Why you should care about functional programming with Haskell *New-er Date*">
1911 <short>Andrei Barbu</short>
1915 <eventitem date="2007-11-22" time="4:30 PM" room="MC 4041" title="More Haskell functional programming fun!">
1916 <short>Andrei Barbu</short>
1918 Haskell is a modern lazy, strongly typed functional language with type inferrence. This talk will focus on multiple monads, existential types,
1919 lambda expressions, infix operators and more. Along the way we'll see a parser and interpreter for lambda calculus using monadic parsers. STM,
1920 software transactional memory, a new approach to concurrency, will also be discussed. Before the end we'll also see the solution to an ACM problem
1921 to get a hands on feeling for the language. Don't worry if you haven't seen the first talk, you should be fine for this one anyway!
1926 <eventitem date="2007-11-29" time="4:30 PM" room="MC 4061" title="Concurrent / Distributed programming with JoCaml">
1927 <short>Brennan Taylor</short>
1930 A lecture on the fundamentals of Pi-Calculus followed by an introduction to Join-Calculus in JoCaml with some great examples.
1931 Various concurrent control structures are explored, as well as the current limitations of JoCaml. The examples section will
1932 mostly be concurrent programming, however some basic distributed examples will be explored. This lecture focuses on how easy
1933 concurrent programming can be.
1938 <eventitem date="2007-12-04" time="4:30 PM" room="TBA" title="PE Executable Translation: A solution for legacy games on linux (Postponed)">
1939 <short>David Tenty</short>
1942 With today's fast growing linux user base, a large porportion of legacy applications have established open-source equivalents or ports.
1943 However, legacy games provided an intresting problem to gamers who might be inclinded to migrate to linux or other open platforms.
1944 PE executable translation software will be presented that provides a solution to this dilema and will be contrasted with the windows compatiblity framwork Wine.
1945 Postponed to a later date.
1950 <eventitem date="2007-12-01" time="1:30 PM" room="MC 2037" title="Programming Contest">
1951 <short>Win Prizes!</short>
1954 The Computer Science club is holding a programming contest from 1:00 to 6:30 open to all! C++,C,Perl,Scheme are allowed.
1955 Prizes totalling in value of $75 will be distributed. You can participate online! For more information, including source files visit <a href="http://www.csclub.uwaterloo.ca/contest">http://www.csclub.uwaterloo.ca/contest</a>
1958 And Free Pizzaa for all who attend!
1962 <eventitem date="2007-12-02" time="2:30 PM" room="TBA" title="Multi-Player Linux games for Linux awarness week">
1963 <short>Multi-Player Gaming with Linux [Possibly Pizza!]</short>
1966 Come out for multi-player gaming on Linux. If you don't have linux on your machine, we will have LiveCDs available.
1967 Lots of fun! Possible Pizzaa!
1972 <eventitem date="2007-10-04" time="4:30 PM" room="TBA" title="Distributed Programming with Erlang">
1973 <short>Brennan Taylor</short>
1976 A quick introduction on the current state of distributed programming and various grid computing projects. Followed by some
1977 history and features of the Erlang language and finishing with distributed examples including operating on a cluster.
1982 <eventitem date="2007-12-05" time="4:30 PM" room="MC 4061" title="Google Summer of Code, a look back on 2007">
1983 <short>Holden Karau</short>
1986 An overview on Google Summer of Code 2007. This talk will look at some of the Summer of Code projects, the project organization, etc.
1989 Holden Karau participated in Google Summer of Code 2007 as a student on the subversion team. He created a set of scheme bindings for the
1999 <eventitem date="2007-07-17" time="7:00 PM" room="AL 116" title="C++0x - An Overview">
2000 <short>Bjarne Stroustrup</short>
2002 A good programming language is far more than a simple collection of
2003 features. My ideal is to provide a set of facilities that smoothly work
2004 together to support design and programming styles of a generality beyond
2005 my imagination. Here, I briefly outline rules of thumb (guidelines,
2006 principles) that are being applied in the design of C++0x. Then, I
2007 present the state of the standards process (we are aiming for C++09) and
2008 give examples of a few of the proposals such as concepts, generalized
2009 initialization, being considered in the ISO C++ standards committee.
2010 Since there are far more proposals than could be presented in an hour,
2011 I'll take questions.
2015 <eventitem date="2007-07-06" time="4:30 PM" room="AL 116" title="Copyright vs Community in the Age of Computer Networks">
2016 <short>Richard Stallman</short>
2018 Copyright developed in the age of the printing press, and was designed
2019 to fit with the system of centralized copying imposed by the printing
2020 press. But the copyright system does not fit well with computer
2021 networks, and only draconian punishments can enforce it.
2023 The global corporations that profit from copyright are lobbying for
2024 draconian punishments, and to increase their copyright powers, while
2025 suppressing public access to technology. But if we seriously hope to
2026 serve the only legitimate purpose of copyright--to promote progress, for
2027 the benefit of the public--then we must make changes in the other
2030 The CSC would like to thank MEF and Mathsoc for funding this talk.
2032 <a href="http://www.fsf.org/events/waterloo20070706">The Freedom Software Foundation's description</a><br />
2033 <a href="http://www.defectivebydesign.org">FSF's anti-DRM campaign</a><br />
2034 <a href="http://www.badvista.org">Why you shouldn't use Microsoft Vista</a><br />
2035 <a href="http://www.gnu.org">The GNU's Not Unix Project</a><br />
2039 <eventitem date="2007-06-27" time="4:30 PM" room="MC 4042" title="Usability in the wild">
2040 <short>A talk by Michael Terry</short>
2042 What is the typical monitor resolution of a GIMP user? How many monitors
2043 do they have? What size images do they work on? How many layers are in
2044 their images? The answers to these questions are generally unknown: No
2045 means currently exist for open source applications to collect usage
2046 data. In this talk, I will present ingimp, a version of GIMP that has
2047 been instrumented to automatically collect usage data from real-world
2048 users. I will discuss ingimp's design, the type of data we collect, how
2049 we make the data available on the web, and initial results that begin to
2050 answer the motivating questions.
2052 ingimp can be found at http://www.ingimp.org.
2056 <eventitem date="2007-06-22" time="4:30 PM"
2058 title="Email encryption for the masses">
2059 <short>Ken Ho</short>
2061 E-mail transactions and confirmations have become commonplace and the
2062 information therein can often be sensitive. We use email for purposes as
2063 mundane as inbound marketing, to as sensitive as account passwords and
2064 financial transactions. And nearly all our email is sent in clear text;
2065 we trust only that others will not eavesdrop or modify our messages. But
2066 why rely on the goodness or apathy of your fellow man when you can
2067 ensure your message's confidentiality with encryption so strong not even
2068 the NSA can break? Speaker (Kenneth Ho) will discuss email encryption,
2069 and GNU Privacy Guard to ensure that your messages are sent, knowing
2070 that only your intended recipient can receive it.
2071 </p><p>An optional code-signing party will be held immediately
2072 afterwards; if you already have a PGP or GPG key and wish to
2073 participate, please submit the public key to
2074 <a href="mailto:gpg-keys@csclub.uwaterloo.ca">
2075 gpg-keys@csclub.uwaterloo.ca</a>.
2077 Laptop users are invited also to participate in key-pair sharing
2078 on-site, though it is preferable to send keys ahead of time.
2082 <eventitem date="2007-06-18" time="4:30 PM"
2083 room="DC 4040" title="Fedspulse.ca, Web 3.0, Portals and the Metaverse">
2084 <short>Peter Macdonald</short>
2086 The purpose of the talk is to address how students interact with the
2087 internet, and possibilities for how they could do so more efficiently.
2088 Information on events and happenings on UW campus is currently hosted
2089 on a desperate, series of internet applications. Interactions with
2090 WatSFIC is done over a Yahoo! mailing list, GLOW is organized through a
2091 Facebook group, campus information at large comes from
2092 <a href="http://imprint.uwaterloo.ca">imprint.uwaterloo.ca</a>. There
2093 has been historical pressures from various bodies, including some
2094 thinkers in feds and the administration, to centralize these issues. To
2095 create a one stop shop for students on campus.
2097 It is not through confining data in cages that we will finally link all
2098 student activities together, instead it is by truly freeing it. When
2099 data can be anywhere, then it will be everywhere students need it. This
2100 is the underlying concept behind metadata, data that is freed from the
2101 confines of it's technical imprisonment. Metadata is the extension of
2102 people, organizations, and activities onto the internet in a way that is
2103 above the traditional understanding of how people interact with their
2104 networks. The talk will explore how Metadata can exist freely on the
2105 internet, how this affects concepts like Web 3.0, and how the university
2106 and the federation are poised to take advantage of this burgeoning new
2107 technology through adoptions of portals which will allow students to
2108 interact with a metaverse of data.
2112 <!-- Winter 2007 -->
2114 <eventitem date="2007-04-11" time="3:30 PM" room="Hagey Hall" title="The Free Software Movement and the GNU/Linux Operating System">
2115 <short>A talk by Richard M. Stallman (RMS) <b>[CANCELLED]</b></short>
2117 Richard Stallman has cancelled his trip to Canada.
2121 <eventitem date="2007-04-08" time="4:30pm" room="MC 4041" title="Loop Optimizations">
2122 <short>A talk by Simina Branzei</short>
2124 Abstract coming soon!
2128 <eventitem date="2007-04-01" time="4:30 PM" room="MC 3036" title="Surprise
2132 While reading Slashdot, Bill came across the recently digitized audio
2133 recording of his 1989 talk at the Computer Science Club. As Bill has always
2134 had a soft-spot for the Computer Science Club, he has decided to pay us a
2137 Bill promises to give away free copies of Windows Vista Ultimate, because
2138 frankly, nobody here (except j2simpso) wants to pay for a frisbee. Be sure
2139 to bring your resumes kids, because Bill will be recruiting for some
2140 exciting new positions at Microsoft, including Mindless Drone, Junior Code
2141 Monkey, and Assistant Human Cannonball.
2146 <eventitem date="2007-03-28" time="5:30 PM"
2147 room="MC 1056" title="Computational Physics Simulations">
2148 <short>A talk by David Tenty and Alex Parent</short>
2158 <eventitem date="2007-03-29" time="4:30 PM"
2159 room="MC 1056" title="All The Code">
2160 <short>A demo/introduction to a new source code search engine. A talk by Holden Karau</short>
2163 Source code search engines are a relatively new phenomenon . The general idea of most source code search engines is helping programmers find
2164 pre-existing code. So if you were writing some code and you wanted to find a csv library, for example, you could search for csv.
2165 <a href="http://www.allthecode.com/">All The Code</a> is a
2166 next generation source code search engine. Unlike earlier generations of source code search engines, it considers how code is used to help determine
2170 The talk will primarily be a demo of <a href="http://www.allthecode.com">All The Code</a>,
2171 along with a brief discussion of some of the technology behind it.
2177 <eventitem date="2007-04-04" time="4:00 PM"
2178 room="MC 1056" title="Data Analysis with Kernels: [an introduction]">
2179 <short>A talk by Michael Biggs. This talk is RESCHEDULED due to unexpected
2180 circumstances</short>
2183 I am going to take an intuitive, CS-style approach to a discussion about the
2184 use of kernels in modern data analysis. This approach often lends us
2185 efficient ways to consider a dataset under various choices of inner product,
2186 which is roughly comparable to a measure of "similarity". Many new tools in
2187 AI arise from kernel methods, such as the infamous Support Vector Machines for
2188 classification, and kernel-PCA for nonlinear dimensionality reduction. I will
2189 attempt to highlight, and provide visualization for some of the math involved
2190 in these methods while keeping the material at an accessible, undergraduate
2198 <eventitem date="2007-02-26" time="4:30 pm"
2199 room="DC 1350" title="ReactOS: An Open Source OS Platform for Learning">
2200 <short>A talk by Alex Ionescu</short>
2203 The ReactOS operating system has been in development for over eight years and aims to provide users
2204 with a fully functional and Windows-compatible distribution under the GPL license. ReactOS comes with
2205 its own Windows 2003-based kernel and system utilities and applications, resulting in an environment
2206 identical to Windows, both visually and internally.
2208 More than just an alternative to Windows, ReactOS is a powerful platform for academia, allowing
2209 students to learn a variety of skills useful to software testing, development and management, as well as
2210 providing a rich and clean implementation of Windows NT, with a kernel compatible to published
2211 internals book on the subject.
2213 This talk will introduce the ReactOS project, as well as the various software engineering challenges
2214 behind it. The building platform and development philosophies and utilities will be shown, and
2215 attendees will grasp the vast amount of effort and organization that needs to go into building an
2216 operating system or any other similarly large project. The speaker will gladly answer questions related to
2217 his background, experience and interests and information on joining the project, as well as any other
2218 related information.
2220 <strong>Speaker Bio</strong>
2222 Alex Ionescu is currently studying in Software Engineering at Concordia University in Montreal, Quebec
2223 and is a Microsoft Technical Student Ambassador. He is the lead kernel developer of the ReactOS Project
2224 and project leader of TinyKRNL. He regularly speaks at Linux and Open Source conferences around the
2225 world and will be a lecturer at the 8th International Free Software Forum in Brazil this April, as well as
2226 providing hands-on workshops and lectures on Windows NT internals and security to various companies.
2232 <eventitem date="2007-02-15" time="4:30 PM"
2233 room="MC 2065" title="An Introduction to Recognizing Regular Expressions in Haskell">
2234 <short>A talk by James deBoer</short>
2238 This talk will introduce the Haskell programming language and and walk
2239 through building a recognizer for regular languages. The talk will
2240 include a quick overview of regular expressions, an introduction to
2241 Haskell and finally a line by line analysis of a regular language
2247 <eventitem date="2007-02-09" time="4:30 PM"
2248 room="MC 4041" title="Introduction to 3-d Graphics">
2249 <short>A talk by Chris "The Prof" Evensen</short>
2252 A talk for those interested in 3-dimensional graphics but unsure of where to
2253 start. Covers the basic math and theory behind projecting 3-dimensional
2254 polygons on screen, as well as simple cropping techniques to improve
2255 efficiency. Translation and rotation of polygons will also be discussed.
2260 <eventitem date="2007-02-09" time="8:30 PM"
2261 room="DC 1351" title="Writing World Class Software">
2262 <short>A talk by James Simpson</short>
2265 A common misconception amongst software developers is that top quality software
2266 encompasses certain platforms, is driven by a particular new piece of
2267 technology, or relies solely on a particular programming language. However as
2268 developers we tend to miss the less hyped issues and techniques involved in
2269 writing world class software. These techniques are universal to all
2270 programming languages, platforms and deployed technologies but are often times
2271 viewed as being so obvious that they are ignored by the typical developer. The
2272 topics covered in this lecture will include:
2274 - Writing bug-free to extremely low bug count software in real-time<br/>
2275 - The concept of single-source, universal platform software<br/>
2276 - Programming language interoperability<br/>
2278 ... and other less hyped yet vitally important concepts to writing
2279 World Class Software
2284 <eventitem date="2007-02-08" time="4:30 PM"
2285 room="MC 2066" title="UW Software Start-ups: What Worked and What Did Not">
2286 <short>A talk by Larry Smith</short>
2289 A discussion of software start-ups founded by UW students and what they did
2290 that helped them grow and what failed to help. In order to share the most
2291 insights and guard the confidences of the individuals involved, none of the
2292 companies will be identified.
2298 <eventitem date="2007-02-07" time="4:30 PM"
2299 room="MC 4041" title="Riding The Multi-core Revolution">
2300 <short>How a Waterloo software company is changing the way people program computers.
2301 A talk by Stefanus Du Toit</short>
2304 For decades, mainstream parallel processing has been thought of as
2305 inevitable. Up until recent years, however, improvements in
2306 manufacturing processes and increases in clock speed have provided
2307 software with free Moore's Law-scale performance improvements on
2308 traditional single-core CPUs. As per-core CPU speed increases have
2309 slowed to a halt, processor vendors are embracing parallelism by
2310 multiplying the number of cores on CPUs, following what Graphics
2311 Processing Unit (GPU) vendors have been doing for years. The Multi-
2312 core revolution promises to provide unparalleled increases in
2313 performance, but it comes with a catch: traditional serial
2314 programming methods are not at all suited to programming these
2315 processors and methods such as multi-threading are cumbersome and
2316 rarely scale beyond a few cores. Learn how, with hundreds of cores in
2317 desktop computers on the horizon, a local software company is looking
2318 to revolutionize the way software is written to deliver on the
2319 promise multi-core holds.
2322 Refreshments (and possible pizza!) will be provided.
2327 <!-- <eventitem date="2007-01-24" time="4:00 PM"
2328 room="TBA" title="TBA">
2329 <short>A talk by Reg Quinton</short>
2337 <eventitem date="2007-01-31" time="4:00 PM"
2338 room="MC 4041" title="Network Security -- Intrusion Detection">
2339 <short>A talk by Reg Quinton</short>
2342 IST monitors the campus network for vulnerabilities and scans
2343 systems for security problems.
2344 This informal presentation will look behind the scenes to show the
2345 strategies and technologies used and to show the problem magnitude. We
2346 will review the IST Security web site with an emphasis on these pages
2348 <a href="http://ist.uwaterloo.ca/security/vulnerable/">http://ist.uwaterloo.ca/security/vulnerable/</a><br/>
2349 <a href="http://ist.uwaterloo.ca/security/security-wg/reports/20061101.html">http://ist.uwaterloo.ca/security/security-wg/reports/20061101.html</a><br/>
2350 <a href="http://ist.uwaterloo.ca/security/position/20050524/">http://ist.uwaterloo.ca/security/position/20050524/</a><br/>
2355 <eventitem date="2007-01-31" time="4:30 PM"
2356 room="TBA" title="An Brief Introduction to Projection Graphics">
2357 <short>A talk by Christopher Evensen</short>
2367 <!-- Nothing happened :( -->
2369 <!-- Spring 2006 -->
2372 <eventitem date="2006-07-29" title="CTRL D" time="7:00pm" room="East Side Mario">
2373 <short>Come out for the Club that Really Likes Dinner</short>
2376 Summer: the sparrows whistle through the teapot-steam breeze. The
2377 ubiquitous construction team tears the same pavement up for the third
2378 time, hammering passers-by with dust and noise: our shirts, worn for
2379 the third time, noisome from competing heat and shame. As Nature
2380 continues her Keynesian rotation of policy, and as society decrees yet
2381 another parting of ways, it is proper for the common victims to have
2382 an evening to themselves, looking both back and ahead, imagining new
2383 opportunities, and recognising those long since missed. God fucking
2387 This term's CTRL-D end-of-term dinner is taking place tomorrow
2388 (Saturday) at 7:00 P.M. at East Side Mario's, in the plaza. Meet in
2389 the C.S.C. fifteen minutes beforehand, so they don't take away our
2390 seats or anything nasty like that.
2393 A lot of people wanted to go to the Mongolian Grill, but I'm pretty
2394 sure this place has a similar price-to-tasty ratio; what's more,
2395 they'll actually grant us a reservation more than four nights a week.
2396 I've confirmed that the crazy allergenic peanuts no longer exist
2397 (sad), and they have a good vegetarian selection, which is likely
2398 coincides with their kosher and halal menus.
2401 Come out for the tasty and the awesome! If you pretend it's your
2402 birthday, everyone's a loser! Tell your friends, because I told the
2403 telephone I wanted to reserve for 10 to 12 people, and I don't wish to
2404 sully Calum T. Dalek's good name!
2411 <eventitem date="2006-07-26" title="Lemmings Day" time="3:30pm" room="MC Comfy Lounge">
2412 <short>Come out for some retro Amiga-style Lemmings gaming action!</short>
2415 Does being in CS make you feel like a lemming? Is linear algebra driving you
2416 into walls? Do you pace back and forth, constantly, regardless of whatever's
2417 in your path? Then you should come out to CSC Lemmings Day. This time, we're
2418 playing the pseudo-sequel: Oh No! More Lemmings!
2421 <li>Old-skool retro gaming, Amiga-style (2 mice, 2 players!)</li>
2422 <li>Projector screen: the pixels are man-sized!</li>
2423 <li>Enjoy classic Lemmings tunes</li>
2428 <eventitem date="2006-07-25" title="Linux Installfest!" time="1:00pm" room ="DC Fishbowk">
2429 <short>A part of Linux Awareness Week</short>
2432 The Computer Science Club is once again stepping forward to fulfill its ancient duty to the people-this time by installing one of the many
2433 fine distributions of Linux for you.
2436 Ubuntu? Debian? Gentoo? Fedora? We might not have them all, but we seem to have an awful lot! Bring your boxen down to the D.C. Fishbowl for
2440 Install Linux on your machine-install fear in your opponents!
2446 <eventitem date="2006-07-24" title="Software development gets on the Cluetrain" time="4:30pm" room ="MC 4063">
2447 <short>or How communities of interest drive modern software development.</short>
2450 Simon Law leads the Quality teams for Ubuntu, a free-software operating
2451 system built on Debian GNU/Linux. As such, he leads one of the largest
2452 community-based testing efforts for a software product. This does get a
2456 In this talk, we'll be exploring how the Internet is changing how
2457 software is developed. Concepts like open source and technologies like
2458 message forums are blurring the lines between producer and consumer.
2459 And this melting pot of people is causing people to take note, and
2460 changing the way they sling code.
2463 Co-Sponsored with CS-Commons Committee
2468 <eventitem date="2006-07-21" time="5:30 PM"
2469 room="MC1085" title="March of the Penguins">
2470 <short>The Computer Science Club will be showing March of the Penguins</short>
2473 <a href="http://wip.warnerbros.com/marchofthepenguins/">March of the Penguins</a> , an epic nature documentary, as dictated
2474 by some guy with a funny voice is being shown by the Computer Science club because penguins are cute and were bored [that and the
2475 whole Linux awareness week that forgot to tell people about].
2481 <eventitem date="2006-07-20" time="5:30 PM"
2482 room="MC4041" title="Cool Stuff to do With Python">
2483 <short>Albert O'Connor will be introducing the joys of programming in python</short>
2486 Albert O'Connor, a UW grad, will be giving a ~30 minute talk on introducing the joys of programming python. Python is an open source
2487 object-oriented programming language which is most awesome.
2492 <eventitem date="2006-07-20" time="4:30 PM"
2493 room="MC4041" title="Simulating multi-tasking on an embedded architecture">
2494 <short>Alex Tsay will look at the common hack used to simulate multi-processing in a real time embedded environment.</short>
2497 In an embedded environment resources are fairly limited, especially. Typically an embedded system has strict time constraints in which it must
2498 respond to hardware driven interrupts and do some processing of its own. A full fledged OS would consume most of the available resources, hence
2499 crazy hacks must be used to get the benefits without paying the high costs. This talk will look at the common hack used to simulate multi-processing
2500 in a real time embedded environment.
2506 <eventitem date="2006-07-19" title="Semacode: Image recognition on mobile camera phones" time="4:30 PM" room ="MC1085">
2507 <short>Simon Woodside, founder of Semacode, comes to discuss image what it is like to start a business and how imaging code works</short>
2510 Could you write a good image recognizer for a 100 MHz mobile phone
2511 processor with 1 MB heap, 320x240 image, on a poorly-optimized Java
2512 stack? It needs to locate and read two-dimensional barcodes made up of
2513 square modules which might be no more than a few pixels in size. We
2514 had to do that in order to establish Semacode, a local start up
2515 company that makes a software barcode reader for cell phones. The
2516 applications vary from ubiquitous computing to advertising. Simon
2517 Woodside (founder) will discuss what it's like to start a business and
2518 how the imaging code works.
2527 <eventitem date="2006-07-17" time="11:59 PM"
2528 room="MC3036" title="Midnight Madness, Alpha Edition">
2529 <short>Come out to discuss current & future plans/projects for the Club</short>
2532 The Computer Science Club (CSClub) has "new" DEC Alphas which are most awesome. Come out, help take them part, put them back
2533 together, solder, and eat free food (probably pizza).
2539 <eventitem date="2006-06-21" time="4:30 PM"
2540 room="MC4042" title="CSC General Meeting">
2541 <short>Come out to discuss current & future plans/projects for the Club</short>
2544 The venue will include:</p>
2546 <li><p>Computer usage agreement discussion (Holden has some changes he'd like to propose)</p></li>
2547 <li><p>Web site - Juti is redesigning the web site (you can see <a href="beta/">a beta here</a> - ideas are welcome.</p></li>
2548 <li><p>Frosh Linux cd's that could be put in frosh math faculty kits.</p></li>
2549 <li><p>VoIP "not phone services" ideas.</p></li>
2550 <li><p>Ideas for talks (people, topics, etc...). We requested Steve Jobs and Steve Balmer, so no idea is too crazy.</p></li>
2551 <li><p>Ideas for books.</p></li>
2552 <li><p>General improvements/comments for the club.</p></li>
2555 If you have ideas, but can't attend, please email them to <a href="mailto:president@csclub.uwaterloo.ca">president@csclub.uwaterloo.ca</a> and they will be read them at the meeting.
2561 <eventitem date="2006-05-25" time="4:00 PM" room="MC 4060" title="Eighteen Years in the Software Tools Business">
2562 <short>Eighteen Years in the Software Tools Business at Microsoft, a talk by Rico Mariani, (BMath CS/EEE 1988)</short>
2565 Rico Mariani, (BMath CS/EEE 1988) now an (almost) 18 year Microsoft veteran but then a CSC president comes to talk to us about the
2566 evolution of software tools for microcomputers. This talk promises to be a little bit about history and perspective (at least from
2567 the Microsoft side of things) as well as the evolution of software engineers, different types of programmers and their needs, and what
2568 it's like to try to make the software industry more effective at what it does, and sometimes succeed!
2571 A video of the talk is available for download in our <a href="media/">media</a> section.
2576 <eventitem date="2006-05-14" time="1:00 PM" room="CSC" title="Unix 101 and 102 Recording">
2577 <short>Unix 101 and 102 recording</short>
2580 Have you heard of our famous Unix 101 and Unix 102 tutorials. We've decided to try
2581 and put them on the web. This Sunday we will be doing a first take.
2582 At the same time, we're going to be looking at adding new material
2583 that we haven't covered in the past. </p>
2585 Why should you come out? Not only will you get to hang out with a wonderful group of people,
2586 you can help impart your knowledge to the world. Don't know anything about Unix? That's cool too,
2587 we need people to make sure its easy to follow along and hopefully keep us from leaving something
2593 <eventitem date="2006-05-13" time="1:00 PM" room="CSC" title="Video 4 Linux Day">
2594 <short> We don't know enough about V4L</short>
2597 We don't know Video 4 Linux, but increasingly people are wanting to do interesting stuff with our webcam which
2598 could benefit from a better understanding of Video 4 Linux. So, this Saturday a number of us will be trying to learn
2599 as much as possible about Video 4 Linux and doing weird things with webcam(s).
2604 <eventitem date="2006-05-08" time="4:30 PM" room="The Comfy Lounge" title="CSC
2606 <short>Come out and vote for the Spring 2006 executive!</short>
2609 The Computer Science Club will be holding its elections for the Spring 2006
2610 term on Monday, May 8th. The elections will be held at 4:30 PM in the
2611 Comfy Lounge, on the 3rd floor of the MC. Please remember to come out and
2615 We are accepting nominations for the following positions: President,
2616 Vice-President, Treasurer, and Secretary. The nomination period continues
2617 until 4:30 PM on Sunday, May 7th. If you are interested in running for
2618 a position, or would like to nominate someone else, please email
2619 cro@csclub.uwaterloo.ca before the deadline.
2624 <!-- Winter 2006 -->
2626 <eventitem date="2006-03-06" time="4:45 PM"
2627 room="Physics 145" title="Creating Killer Applications">
2628 <short>A talk by Larry Smith</short>
2631 A discussion of how software creators can identify application opportunities
2632 that offer the promise of great social and commercial significance. Particular
2633 attention will be paid to the challenge of acquiring cross domain knowledge
2634 and setting up effective collaboration.
2640 <eventitem date="2006-02-09" time="5:30 PM" room="Bombshelter Pub" title="Pints With Profs">
2641 <short>Come out and meet your professors. Free food provided!</short>
2643 <p>Come out and meet your professors! This is a great opportunity to
2644 mingle with your professors before midterms or find out who you might
2645 have for future courses. All are welcome!</p>
2647 <p>Best of all, there will be <strong>free food!</strong></p>
2649 <p>You can pick up invitations for your professors at the Computer Science
2650 Club office in MC 3036.</p>
2652 <p>Pints with Profs will be held this term on Thursday, 9 February 2006
2653 from 5:30 to 8:00 PM in the Bombshelter.</p>
2659 <eventitem date="2005-11-29" time="5:30 PM"
2660 room="TBA" title="Programming Contest">
2661 <short>Come out, program, and win shiny things!</short>
2664 The Computer Science club is holding a programming contest open to all students on Tuesday the 29th of November at 5:30PM. C++,C,Perl,Scheme* are allowed. Prizes totalling in value of $75 will be distributed.
2668 <p>And best of all... free food!!!</p>
2673 <eventitem date="2005-10-17" time="5:30 PM"
2674 room="Fishbowl" title="Party with Profs!">
2675 <short>Get to know your profs and be the envy of your
2679 Come out and meet your professors!! This is a great opportunity to
2680 meet professors for Undergraduate Research jobs or to find out who
2681 you might have for future courses. One and all are welcome!
2684 <p>And best of all... free food!!!</p>
2689 <eventitem date="2005-10-11" time="4:30 PM" room="MC 2037" title="UNIX 103: Scripting Unix">
2690 <short>You Too Can Be a Unix Taskmaster</short>
2693 This is the third in a series of seminars that cover the use of the
2694 UNIX Operating System. UNIX is used in a variety of applications, both
2695 in academia and industry. We will provide you with hands-on experience
2696 with the Math Faculty's UNIX environment in this tutorial.
2698 Topics that will be discussed include:
2700 <li>Shell scripting</li>
2701 <li>Searching through text files</li>
2702 <li>Batch editing text files</li>
2705 If you do not have a Math computer account, don't panic; one will be lent to
2706 you for the duration of this class.
2712 <eventitem date="2005-10-06" time="4:30 PM" room="MC3D 2037" title="UNIX 102">
2713 <short>Fun with Unix</short>
2716 This is the second in a series of seminars that cover the use of the
2717 Unix Operating System. Unix is used in a variety of
2718 applications, both in academia and industry. We will provide you with hands-on
2719 experience with the Math Faculty's Unix environment in this tutorial.
2722 Topics that will be discussed include:
2724 <li>Interacting with Bourne and C shells</li>
2725 <li>Editing text using the vi text editor</li>
2726 <li>Editing text using the Emacs display editor</li>
2727 <li>Multi-tasking and the screen multiplexer</li>
2731 If you do not have a Math computer account, don't panic; one will be lent to
2732 you for the duration of this class.
2737 <eventitem date="2005-10-04" time="4:30 PM" room="MC 2037" title="UNIX 101">
2738 <short>First UNIX tutorial</short>
2741 The CSC UNIX tutorials are intended to help first year CS and other
2742 interested learn UNIX and the CS UNIX environment.
2745 This is the first in a series of two or three tutorials. It will cover basic shell
2746 use, and simple text editors.
2752 <!-- Summer 2005 -->
2753 <eventitem date="2005-06-02" time="3:30 PM" room="DC 1302" title="Programming and Verifying the Interactive Web">
2754 <short>Shriram Krishnamurthi will be talking about continuations in Web Programming</short>
2757 Server-side Web applications have grown increasingly common, sometimes
2758 even replacing brick and mortar as the principal interface of
2759 corporations. Correspondingly, Web browsers grow ever more powerful,
2760 empowering users to attach bookmarks, switch between pages, clone
2761 windows, and so forth. As a result, Web interactions are not
2762 straight-line dialogs but complex nets of interaction steps.
2765 In practice, programmers are unaware of or are unable to handle these
2766 nets of interaction, making the Web interfaces of even major
2767 organizations buggy and thus unreliable. Even when programmers do
2768 address these constraints, the resulting programs have a seemingly
2769 mangled structure, making them difficult to develop and hard to
2773 In this talk, I will describe these interactions and then show how
2774 programming language ideas can shed light on the resulting problems
2775 and present solutions at various levels. I will also describe some
2776 challenges these programs pose to computer-aided verification, and
2777 present solutions to these problems.
2781 <eventitem date="2005-06-07" time="4:00 PM" room="MC 4042" title="UW's CS curriculum: past, present, and future">
2782 <short>Come out to here Prabhakar Ragde talk about our UW's CS curriculum</short>
2785 I'll survey the evolution of our computer science curriculum over the
2786 past thirty-five years to try to convey the reasons (not always entirely
2787 rational) behind our current mix of courses and their division into core
2788 and optional. After some remarks about constraints and opportunities in
2789 the near future, I'll open the floor to discussion, and hope to hear
2790 some candid comments about the state of CS at UW and how it might be
2797 Prabhakar Ragde is a Professor in the School of Computer Science at UW.
2798 He was Associate Chair for Curricula during the period that saw the
2799 creation of the Bioinformatics and Software Engineering programs, the
2800 creation of the BCS degree, and the strengthening of the BMath/CS degree.
2805 <!-- Winter 2005 -->
2806 <eventitem date="2005-03-15" time="4:30 PM" room="MC 4060" title="Oh No! More Lemmings Day!">
2807 <short>Come out for some retro Amiga-style Lemmings gaming action!</short>
2810 Does being in CS make you feel like a lemming? Is linear algebra driving you
2811 into walls? Do you pace back and forth, constantly, regardless of whatever's
2812 in your path? Then you should come out to CSC Lemmings Day. This time, we're
2813 playing the pseudo-sequel: Oh No! More Lemmings!
2816 <li>Old-skool retro gaming, Amiga-style (2 mice, 2 players!)</li>
2817 <li>Projector screen: the pixels are man-sized!</li>
2818 <li>Live-Action Lemmings (the rules are better this time)</li>
2819 <li>Lemmings look-alike contest</li>
2820 <li>Enjoy classic Lemmings tunes</li>
2825 <eventitem date="2005-02-01" time="4:30 PM" room="MC 2037" title="UNIX 102">
2826 <short>Fun with Unix</short>
2829 This is the second in a series of seminars that cover the use of the
2830 Unix Operating System. Unix is used in a variety of
2831 applications, both in academia and industry. We will provide you with hands-on
2832 experience with the Math Faculty's Unix environment in this tutorial.
2835 Topics that will be discussed include:
2837 <li>Interacting with Bourne and C shells</li>
2838 <li>Editing text using the vi text editor</li>
2839 <li>Editing text using the Emacs display editor</li>
2840 <li>Multi-tasking and the screen multiplexer</li>
2844 If you do not have a Math computer account, don't panic; one will be lent to
2845 you for the duration of this class.
2851 <eventitem date="2005-01-25" time="4:30 PM" room="MC 2037" title="UNIX 101">
2852 <short>First UNIX tutorial</short>
2855 The CSC UNIX tutorials are intended to help first year CS and other
2856 interested learn UNIX and the CS UNIX environment.
2859 This is the first in a series of two or three tutorials. It will cover basic shell
2860 use, and simple text editors.
2866 <eventitem date="2005-01-13" time="4:30 PM" room="The Comfy Lounge" title="CSC
2868 <short>Come out and vote for the Winter 2005 executive!</short>
2871 The Computer Science Club will be holding its elections for the Winter 2005
2872 term on Thursday, January 13. The elections will be held at 4:30 PM in the
2873 Comfy Lounge, on the 3rd floor of the MC. Please remember to come out and
2877 We are accepting nominations for the following positions: President,
2878 Vice-President, Treasurer, and Secretary. The nomination period continues
2879 until 4:30 PM on Wednesday, January 12. If you are interested in running for
2880 a position, or would like to nominate someone else, please email
2881 cro@csclub.uwaterloo.ca before the deadline.
2889 <eventitem date="2004-12-08" time="4:30 PM" room="Mongolian Grill"
2891 <short> This semesters CTRL-D (or the club that really likes
2892 dinner) is going to be at Mongolian grill. Be there or be square</short>
2895 Come to the end of term CTRL-D (club that really likes dinner) meeting.
2896 Remember : food is good
2902 <eventitem date="2004-12-01" time="2:30 PM" room="MC 4058" title="Knitting needles, hairpins and other tangled objects">
2903 <short>In this talk, I'll study linkages (objects built from sticks that are connected with flexible joints), and explain some
2904 interesting examples that can or cannot be straightened out</short>
2907 In this talk, I'll study linkages (objects built from sticks that are connected with flexible joints), and explain some
2908 interesting examples that can or cannot be straightened out</p>
2914 <eventitem date="2004-11-24" time="4:30 PM" room="MC 2066" title="Eclipse">
2915 <short>How I Stopped Worrying and Learned to Love the IDE</short>
2918 How I stopped worrying and Learned to Love the IDE
2921 Audience: anyone who as ever used the Java programming language to do anything. Especially if you don't like
2922 the IDEs you've seen so far or still use (g)Vi(m) or (X)Emacs.
2926 I'll go through some of the coolest features of the best IDE (which stands for "IDEs Don't Eat" or
2927 "Integrated Development Environment") I've seen. For the first year and seasoned almost-grad alike!
2934 <eventitem date="2004-11-18" time="5:00 PM" room="MC 2066" title="GracefulTavi">
2935 <short>Wiki software in PHP+MySQL</short>
2938 GracefulTavi is an open source wiki programmed by Net Integration
2939 Technologies Inc. It is used internally by more than 25 people, and is
2940 the primary internal wiki for NITI's R&D and QA.
2943 I'll start with a very brief introduction to wikis in general, then
2944 show off our special features: super-condensed formatting syntax,
2945 hierarchy management, version control, highlighted diffs, SchedUlator,
2946 the Table of Contents generator. As part of this, we'll explain the
2947 simple plugin architecture and show people how to write a basic wiki
2952 As well, I will show some of the "waterloo specific" macros that have
2953 been coded, and explain future plans for GracefulTavi.
2957 If time permits, I will explain how gracefulTavi can be easily used
2958 for a personal calendar and notepad system on your laptop.
2965 <eventitem date="2004-11-12" time="2:30 PM" room="MC 4063" title="Lemmings Day!">
2966 <short>Everyone else is doing it!</short>
2969 Does being in CS make you feel like a lemming? Is linear algebra driving you into walls? Do you pace back and forth , constantly ,
2970 regardless of whatever's in your path? Then you should come out to CSC Lemmings Day!
2973 <li>Play some old-skool Lemmings, Amiga-style</li>
2974 <li>Live-action lemmings</li>
2975 <li>Lemmings look-alike contest</li>
2976 <li>Enjoy classic Lemmings tunes</li>
2979 Everyone else is doing it!
2985 <eventitem date="2004-10-23" time="11:00 PM" room="MC 2037" title="CSC Programming Contest">
2986 <short>CSC Programming Contest</short>
2989 The Computer Science Club will be hosting a programming competition.
2990 You have the entire afternoon to design and implement an AI for a simple
2991 game. The competition will run until 5pm.
2997 <eventitem date="2004-10-18" time="4:30 PM" room="MC 2037" title="UNIX 103: Scripting Unix">
2998 <short>You Too Can Be a Unix Taskmaster</short>
3001 This is the third in a series of seminars that cover the use of the
3002 UNIX Operating System. UNIX is used in a variety of applications, both
3003 in academia and industry. We will provide you with hands-on experience
3004 with the Math Faculty's UNIX environment in this tutorial.
3006 Topics that will be discussed include:
3008 <li>Shell scripting</li>
3009 <li>Searching through text files</li>
3010 <li>Batch editing text files</li>
3013 If you do not have a Math computer account, don't panic; one will be lent to
3014 you for the duration of this class.
3019 <eventitem date="2004-10-04" time="4:30 PM" room="MC 2037" title="UNIX 102">
3020 <short>Fun with Unix</short>
3023 This is the second in a series of seminars that cover the use of the
3024 Unix Operating System. Unix is used in a variety of
3025 applications, both in academia and industry. We will provide you with hands-on
3026 experience with the Math Faculty's Unix environment in this tutorial.
3029 Topics that will be discussed include:
3031 <li>Interacting with Bourne and C shells</li>
3032 <li>Editing text using the vi text editor</li>
3033 <li>Editing text using the Emacs display editor</li>
3034 <li>Multi-tasking and the screen multiplexer</li>
3038 If you do not have a Math computer account, don't panic; one will be lent to
3039 you for the duration of this class.
3044 <!-- Spring 2004 -->
3046 <eventitem date="2004-09-27" time="4:30 PM" room="MC 2037" title="UNIX 101">
3047 <short>First UNIX tutorial</short>
3050 The CSC UNIX tutorials are intended to help first year CS and other
3051 interested learn UNIX and the CS UNIX environment.
3054 This is the first in a series of three tutorials. It will cover basic shell
3055 use, and simple text editors.
3059 <eventitem date="2004-09-17" time="4:00 PM" room="The Comfy Lounge" title="CSC
3061 <short>Come out and vote for the Fall 2004 executive!</short>
3064 The Computer Science Club will be holding its elections for the Fall 2004
3065 term on Friday, September 17. The elections will be held at 4:00 PM in the
3066 Comfy Lounge, on the 3rd floor of the MC. Please remember to come out and
3070 We are accepting nominations for the following positions: President,
3071 Vice-President, Treasurer, and Secretary. The nomination period continues
3072 until 4:30 PM on Thursday, September 16. If you are interested in running
3073 for a position, or would like to nominate someone else, please email
3074 cro@csclub.uwaterloo.ca before the deadline.
3079 <eventitem date="2004-07-27" time="4:30 PM" room="MC 2065"
3080 title="Game Complexity Theorists Ponder, by Jonathan Buss">
3081 <short>Attention AI buffs: Game Complexity presentation</short>
3084 Why are some games hard to play well? The study of computational
3085 complexity gives one answer: the games encode long computations.</p>
3087 <p>Any computation can be interpreted as an abstract game. Playing the
3088 game perfectly requires performing the computation. Remarkably, some
3089 natural games can encode these abstract games and thus simulate
3090 general computations. The more complex the game, the more complex the
3091 computations it can encode; games that can encode intractable problems
3092 are themselves intractable.</p>
3095 I will describe how games can encode computations, and discuss some
3096 examples of both provably hard games (checkers, chess, go, etc.) and
3097 games that are believed to be hard (hex, jigsaw puzzles, etc.).
3102 <eventitem date="2004-07-17" time="11:30 AM" room="RCH 308"
3103 title="Case Modding Workshop!">
3104 <short>Come and learn how to make your computer 1337!</short>
3107 Are you bored of beige?<br />
3108 Tired of an overheating computer?<br />
3109 Is your computer's noise level on par with a jet engine?
3112 Got a nifty modded case?<br />
3116 The Computer Science Club will be holding a Case Modding Workshop
3117 to help answer these questions.
3120 There will be demonstrations on how to make a case window, how
3121 to paint your case, managing cables and keeping your computer
3125 The event is FREE and there will be FREE PIZZA. All are welcome!
3128 To help you on your way to getting a wicked computer case, we have a limited
3129 number of "Case Modding Starters Kits" available. They come with an LED fan,
3130 a fan grill, a sheet of Plexan, thumbscrews, wire ties, and more! They're
3131 only $10 and will be on sale at the event. Here's a <a
3132 href="redkit.jpg">picture</a>.
3135 If you already have a modded case, we encourage you to bring it out
3136 and show it off! There will be a prize for the best case!!
3139 We hope to see you there!
3142 This event is sponsored by Bigfoot Computers.
3147 <eventitem date="2004-06-17" time="4:00 PM" room="MC 2066"
3148 title="``Optical Snow'': Motion parallax and heading computation in densely cluttered scenes. -or- Why Computer Vision needs the Fourier Transform!">
3149 <short>A talk by Richard Mann; School of Computer Science</short>
3152 When an observer moves through a 3D scene, nearby surfaces move faster in the
3153 image than do distant surfaces. This effect, called motion parallax, provides
3154 an observer with information both about their own motion relative the scene,
3155 and about the spatial layout and depth of surfaces in the scene.
3158 Classical methods for measuring image motion by computer have concentrated on
3159 the cases of optical flow in which the motion field is continuous, or layered
3160 motion in which the motion field is piecewise continuous. Here we introduce a
3161 third natural category which we call ``optical snow''. Optical snow arises in
3162 many natural situations such as camera motion in a highly cluttered 3-D scene,
3163 or a passive observer watching a snowfall. Optical snow yields dense motion
3164 parallax with depth discontinuities occurring near all image points. As such,
3165 constraints on smoothness or even smoothness in layers do not apply.
3168 We present a Fourier analysis of optical snow. In particular we show that,
3169 while such scenes appear complex in the time domain, there is a simple
3170 structure in the frequency domain, and this may be used to determine the
3171 direction of motion and the range of depths of objects in the scenes. Finally
3172 we show how Fourier analysis of two or more image regions may be combined to
3173 estimate heading direction.
3176 This talk will present current research at the undergraduate level. All are
3183 <eventitem date="2004-05-26" time="5:30 PM"
3184 room="DC 1350" title="Computing's Next Great Empires: The True Future of Software">
3185 <short>A talk by Larry Smith</short>
3188 Larry will challenge conventional assumptions about the directions of
3189 computing and software. The role of AI, expert systems, communications
3190 software and business applications will be presented both from a
3191 functional and commercial point of view. The great gaps in the
3192 marketplace will be highlighted, together with an indication of how
3193 these vacant fields will become home to new empires.
3197 <eventitem date="2004-05-12" time="4:30 PM"
3198 room="The Comfy Lounge" title="CSC Elections">
3199 <short>Come out and vote for the Spring 2004 executive!</short>
3202 The Computer Science Club will be holding its elections for the Spring
3203 2004 term on Wednesday, May 12. The elections will be held at 4:30 PM in
3204 the Comfy Lounge, on the 3rd floor of the MC. Please remember to come out
3208 We are accepting nominations for the following positions: President,
3209 Vice-President, Treasurer, and Secretary. The nomination period continues
3210 until 4:30 PM on Tuesday, May 11. If you are interested in running
3211 for a position, or would like to nominate someone else, please email
3212 cro@csclub.uwaterloo.ca before the deadline.
3217 <!-- Winter 2004 -->
3219 <eventitem date="2004-03-29" time="6:00 PM"
3220 room="MC 4058" title="LaTeXing your work report">
3221 <short>A talk by Simon Law</short>
3224 The work report is a familiar chore for any co-op student. Not only is
3225 there a report to write, but to add insult to injury, your report is
3226 returned if you do not follow your departmental guidelines.
3230 Fear no more! In this talk, you will learn how to use LaTeX and a
3231 specially developed class to automatically format your work reports.
3232 This talk is especially useful to Mathematics, Computer Science,
3233 Electrical & Computer Engineering, and Software Engineeering co-op
3234 students about to go on work term.
3239 <eventitem date="2004-03-30" time="5:30 PM"
3240 room="The Grad House" title="Pints with Profs!">
3241 <short>Get to know your profs and be the envy of your
3245 Come out and meet your professors!! This is a great opportunity to
3246 meet professors for Undergraduate Research jobs or to find out who
3247 you might have for future courses. One and all are welcome!
3250 <p>And best of all... free food!!!</p>
3254 <eventitem date="2004-03-23" time="6:00 PM"
3255 room="MC4058" title="Extending LaTeX with packages">
3256 <short>A talk by Simon Law</short>
3259 LaTeX is a document processing system. What this means is you describe
3260 the structure of your document, and LaTeX typesets it appealingly.
3261 However, LaTeX was developed in the late-80s and is now showing its age.
3265 How does it compete against modern systems? By being easily extensible,
3266 of course. This talk will describe the fundamentals of typesetting in
3267 LaTeX, and will then show you how to extend it with freely available
3268 packages. You will learn how to teach yourself LaTeX and how to find
3269 extensions that do what you want.
3273 As well, there will be a short introduction on creating your own
3274 packages, for your own personal use.
3279 <eventitem date="2004-03-16" time="6:00 PM"
3280 room="MC4058" title="Distributed programming for CS and Engineering
3282 <short>A talk by Simon Law</short>
3285 If you've ever worked with other group members, you know how difficult
3286 it is to code simultaneously. You might be working on one part of your
3287 assignment, and you need to send your source code to everyone else. Or
3288 you might be fixing a bug in someone else's part, and need to merge in
3289 the change. What a mess!
3293 This talk will explain some Best Practices for developing code in a
3294 distributed fashion. Whether you're working side-by-side in the lab, or
3295 developing from home, these methods can apply to your team. You will
3296 learn how to apply these techniques in the Unix environment using GNU
3297 Make, CVS, GNU diff and patch.
3302 <eventitem date="2004-03-15" time="5:30 PM"
3303 room="MC4040" title="SPARC Architecture">
3304 <short>A talk by James Morrison</short>
3307 Making a compiler? Bored? Think CISC sucks and RISC rules?
3311 This talk will run through the SPARC v8, IEEE-P1754, architecture.
3312 Including all the fun that can be had with register windows and the
3313 SPARC instruction set including the basic instructions, floating
3314 point instructions, and vector instructions.
3319 <eventitem date="2004-03-09" time="6:00 PM"
3320 room="MC4062" title="Managing your home directory using CVS">
3321 <short>A talk by Simon Law</short>
3324 If you have used Unix for a while, you know that you've created
3325 configuration files, or dotfiles. Each program seems to want its own
3326 particular settings, and you want to customize your environment. In a
3327 power-user's directory, you could have hundreds of these files.
3331 Isn't it annoying to migrate your configuration if you login to another
3332 machine? What if you build a new computer? Or perhaps you made a
3333 mistake to one of your configuration files, and want to undo it?
3337 In this talk, I will show you how to manage your home directory using
3338 CVS, the Concurrent Versions System. You can manage your files, revert
3339 to old versions in the past, and even send them over the network to
3340 another machine. I'll also discuss how to keep your configuration files
3341 portable, so they'll work even on different Unices, with different
3347 <eventitem date="2004-03-02" time="6:00 PM"
3348 room="MC4042" title="Graphing webs-of-trust">
3349 <short>A talk by Simon Law</short>
3352 In today's world, people have hundreds of connexions. And you can
3353 express these connexions with a graph. For instance, you may wish to
3354 represent the network of your friends.
3358 Originally, webs-of-trust were directed acyclic graphs of people who had
3359 identified each other. This way, if there was a path between you and
3360 the person who want to identify, then you could assume that each person
3361 along that path had verified the next person's identity.
3365 I will show you how to generate your own web-of-trust graph using Free
3366 Software. Of course, you can also use this knowledge to graph anything
3372 <eventitem date="2004-02-18" time="7:00 PM"
3373 room="DC2305" title="KW Perl Mongers">
3374 <short>Perl Modules: A look under the hood</short>
3377 <p>In Perl, a module is the basic unit of code-reuse. The talk will be
3378 mostly a look into GD::Text::Arc, a module written to draw TrueType text
3379 around the edge of a circle. The talk will consider:</p>
3382 <li>using and writing object-oriented perl code</li>
3383 <li>the Virtue of Laziness: or, reusing other peoples' code.</li>
3384 <li>writing tests while coding</li>
3385 <li>beer coasters</li>
3391 <eventitem date="2004-02-05" time="3:30 PM"
3392 room="MC4041" title="Constitutional Change">
3393 <short>Vote to change the CSC Constitution</short>
3396 <p>During the General Meeting on 19 January 2004, a proposed constitution
3397 change was passed around. This change is in response to a change in the
3398 MathSoc Clubs Policy (Policy 4, Section 3, Sub-section f).</p>
3400 <p>This general meeting is called to vote on this proposed change. We must
3401 have quorum of 15 Full Members vote on this change. The following text was
3402 presented at the CSC Winter 2004 Elections.</p>
3404 <pre>We propose to make a Constitutional change on this day, 19 January 2004.
3405 The proposed change is to section 3.1 of the constitution which
3408 In compliance with MathSoc regulations and in recognition of the
3409 club being primarily targeted at undergraduate students, full
3410 membership is open to all undergraduate students in the Faculty of
3411 Mathematics and restricted to the same.
3413 Since MathSoc has changed its requirements for club membership, we
3414 propose that it be changed to:
3416 In compliance with MathSoc regulations and in recognition of the
3417 club being primarily targeted at undergraduate students, full
3418 membership is open to all Social Members of the Mathematics Society
3419 and restricted to the same.</pre>
3423 <eventitem date="2004-01-12" time="3:00 PM"
3424 room="DC1301" title="InstallFest">
3425 <short>See <a href="http://uw-dig.uwaterloo.ca/installfest/">http://uw-dig.uwaterloo.ca/installfest/</a></short>
3428 <p>An Installfest is an opportunity to install software on your computer.
3429 People come with computers. Other people come with experience. The people
3430 get together and (when all goes well) everybody leaves satisfied.</p>
3432 <p>You are invited to our first installfest of the year. Come to get some
3433 software or to learn more about Open Source Software and why it is relevant
3434 to your life. The event is free, but you may want to bring blank CDs and/or
3435 money to purchase some open source action for your computer at home.</p>
3437 <p>See the <a href="http://uw-dig.uwaterloo.ca/installfest/">UW-DIG
3438 website</a> for more details.</p>
3445 <eventitem date="2003-12-01" time="7:00 PM"
3446 room="RCH 101" title="Jon 'maddog' Hall: Free and Open Source: Its uses in Business and Education">
3447 <short> Free and Open Source software has been around for a long
3448 time, even longer then shrink-wrapped code.</short>
3450 <p>Free and Open Source software has been around for a long time, even
3451 longer then shrink-wrapped code. It has a long and noble history in the annals
3452 of education. Even more than ever, due to the drop of hardware prices and the
3453 increase of worldwide communications, Free and Open Source can open new
3454 avenues of teaching and doing research, not only in computer science, but in
3455 other university fields as well.</p>
3456 <p>Learn how Linux as an operating system can
3457 run on anything from a PDA to a supercomputer, and how Linux is reducing the
3458 cost of computing dramatically as the fastest growing operating system in the
3459 world. Learn how other Free and Open Source projects, such as office suites,
3460 audio and video editing and playing software, relational databases, etc. are
3461 created and are freely available.</p>
3463 <p><a href="http://www.csclub.uwaterloo.ca/~cpbell/">Map and directions</a></p>
3464 <h3>Speaker's Biography</h3>
3465 <p>Jon "maddog" Hall is the Executive Director of <a href="http://www.li.org/">Linux International</a>,
3466 a non-profit association of computer vendors who wish to support and promote
3467 the Linux Operating System. During his career which spans over thirty years,
3468 Mr. Hall has been a programmer, systems designer, systems administrator,
3469 product manager, technical marketing manager and educator. He has
3470 worked for such companies as Western Electric Corporation, Aetna Life and
3471 Casualty, Bell Laboratories, Digital Equipment Corporation, VA Linux Systems,
3472 and is currently funded by SGI.</p>
3474 <p>He has taught at Hartford State Technical College, Merrimack College and
3475 Daniel Webster College. He still likes talking to students over pizza and beer
3476 (the pizza can be optional).</p>
3478 <p>Mr. Hall is the author of numerous magazine and newspaper articles, many
3479 presentations and one book, "Linux for Dummies".</p>
3481 <p>Mr. Hall serves on the boards of several companies, and several non-profit
3482 organizations, including the USENIX Association.</p>
3484 <p>Mr. Hall has traveled the world speaking on the benefits of Open Source
3485 Software, and received his BS in Commerce and Engineering from Drexel