f10 unix101
[dtbartle/www.git] / events.xml
1 <?xml version='1.0'?>
2
3 <!DOCTYPE eventdefs SYSTEM "csc.dtd">
4 <eventdefs>
5
6 <!-- Fall 2010 -->
7 <eventitem date="2010-09-29" time="04:30 PM" room="MC3003" title="Unix 101">
8   
9     <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 tutorails 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.
10 </p></short>
11   
12   
13     <abstract><p>Need to use the Unix environment for a course, want to overcome your fears of
14 the command line, or just curious? Attend the first installment in the CSC's
15 popular series of Unix tutorails to learn the basics of the shell and how to
16 navigate the unix environment. By the end of the hands on workshop you will
17 be able to work efficiently from the command line and power-use circles around
18 your friends.
19 </p></abstract>
20   
21 </eventitem>
22
23 <eventitem date="2010-09-22" time="06:00 PM" room="MC4045" title="Cooking for Geeks">
24   
25     <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 &amp; foodies alike. We're happy to have Jeff joining us for a hands on demonstration.
26 </p></short>
27   
28   
29     <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. 
30 Jeff's book has been featured on NPR, BBC and his presentations have wowed audiences of hackers &amp; foodies alike.
31 We're happy to have Jeff joining us for a hands on demonstration.
32 </p><p>But you don't have to take our word for it... here's what Jeff has to say:
33 </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 
34 about my just-released book. I'll talk about the food science behind what makes things yummy, giving you a quick 
35 primer on how to go into the kitchen and have a fun time turning out a good meal.
36 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.
37 </p><p>If you have a copy of the book, bring it! I’ll happily sign it.
38 </p></abstract>
39   
40 </eventitem>
41 <eventitem date="2010-09-21" time="04:30 PM" room="MC4061" title="In the Beginning">
42   
43     <short><p><b>by Dr. Prabhakar Ragde, Cheriton School of Computer Science</b>. I'll be workshopping some lecture ideas involving representations of 
44     numbers, specification of computation in  functional terms, reasoning about 
45     such specifications, and comparing the strengths and weaknesses of  different approaches. 
46 </p></short>
47   
48   
49     <abstract><p>I'll be workshopping some lecture ideas involving representations 
50     of numbers, specification of computation in 
51     functional terms, reasoning about such specifications, and comparing the 
52     strengths and weaknesses of 
53     different approaches. No prior background is needed; the talk should be accessible 
54     to anyone attending 
55     the University of Waterloo and, I hope, interesting to both novices and experts.
56 </p></abstract>
57   
58 </eventitem>
59 <eventitem date="2010-09-14" time="04:30 PM" room="Comfy Lounge" title="Elections">
60   <short><p>Fall term executive elections and general meeting.</p></short>
61 </eventitem>
62
63 <!-- Spring 2010 -->
64
65 <eventitem date="2010-07-20" time="04:30 PM" room="MC2066" title="The Incompressibility Method">
66 <short>
67 In this talk, we shall explore the incompressibility method---an interesting and
68 extremely powerful framework for determining the average-case runtime of
69 algorithms.  Within the right background knowledge, the heapsort question can be
70 answered with an elegant 3-line proof.
71 </short>
72 <abstract>
73 <p>Heapsort. It runs in $\Theta(n \log n)$ time in the worst case, and in $O(n)$
74     time in the best case.  Do you think that heapsort runs faster than $O(n
75     \log n)$ time on average?  Could it be possible that on most inputs,
76     heapsort runs in $O(n)$ time, running more slowly only on a small fraction
77     of inputs?</p>
78 <p>Most students would say no. It "feels" intuitively obvious that heapsort
79     should take the full $n \log n$ steps on most inputs.  However, proving this
80     rigourously with probabilistic arguments turns out to be very difficult.
81     Average case analysis of algorithms is one of those icky subjects that most
82     students don't want to touch with a ten foot pole; why should it be so
83     difficult if it is so intuitively obvious?</p>
84 <p>In this talk, we shall explore the incompressibility method---an interesting
85     and extremely powerful framework for determining the average-case runtime of
86     algorithms.  Within the right background knowledge, the heapsort question
87     can be answered with an elegant 3-line proof.</p>
88 <p>The crucial fact is that an overwhelmingly large fraction of randomly
89     generated objects are incompressible. We can show that the inputs to
90     heapsort that run quickly correspond to inputs that can be compressed,
91     thereby proving that heapsort can't run quickly on average.  Of course,
92     "compressible" is something that must be rigourously defined, and for this
93     we turn to the fascinating theory of Kolmogorov complexity.</p>
94 <p>In this talk, we'll briefly discuss the proof of the incompressibility
95     theorem and then see a number of applications.  We won't dwell too much on
96     gruesome mathemtical details.  No specific background is required, but
97     knowledge of some of the topics in CS240 will be helpful in understanding
98     some of the applications.</p>
99 </abstract>
100 </eventitem>
101
102 <eventitem date="2010-07-13" time="04:30 PM" room="MC2066" title="Halftoning and Digital Art">
103     <short><p>Edgar Bering will be giving a talk titled: Halftoning and Digital Art</p></short>
104     <abstract><p>Halftoning is the process of simulating a continuous tone image
105         with small dots or regions of one colour. Halftoned images may be seen
106         in older newspapers with a speckled appearance, and to this day colour
107         halftoning is used in printers to reproduce images. In this talk I will
108         present various algorithmic approaches to halftoning, with an eye not
109         toward exact image reproduction but non-photorealistic rendering and
110         art. Included in the talk will be an introduction to digital paper
111         cutting and a tutorial on how to use the CSC's paper cutter to render
112         creations.
113 </p></abstract>
114 </eventitem>
115
116
117 <eventitem date="2010-07-09" time="07:00 PM" room="MC Comfy" title="Code Party">
118     <short><p>There is a CSC Code Party Friday starting at 7:00PM (1900)
119             until we get bored (likely in the early in morning). Come out for
120             fun hacking times.
121     </p></short>
122     <abstract><p>There is a CSC Code Party Friday starting at 7:00PM (1900)
123             until we get bored (likely in the early in morning). Come out for
124             fun hacking times.
125     </p></abstract>
126 </eventitem>
127
128 <eventitem date="2010-07-06" time="04:30 PM" room="MC2054" title="Dataflow Analysis">
129   <short><p>Nomair Naeem, a P.H.D. Student at Waterloo, will be giving a talk about Dataflow Analysis</p></short>
130   <abstract><p>
131     After going through an introduction to Lattice Theory and a formal treatment to
132     Dataflow Analysis Frameworks, we will take an in-depth view of the
133     Interprocedural Finite Distributive Subset (IFDS) Algorithm which implements a
134     fully context-sensitive, inter-procedural static dataflow analysis. Then, using
135     a Variable Type Analysis as an example, I will outline recent extensions that we
136     have made to open up the analysis to a larger variety of static analysis
137     problems and making it more efficient.
138     </p><p>
139     The talk is self-contained and no prior knowledge of program analysis is
140     necessary.
141   </p></abstract>
142 </eventitem>
143
144 <eventitem date="2010-06-22" time="04:30 PM" room="MC2066" title="Compiling To Combinators">
145   <short><p>Professor Ragde will be giving the first of our Professor talks for the Spring 2010 term.</p></short>
146   <abstract><p>
147     Number theory was thought to be mathematically appealing but practically
148     useless until the RSA encryption algorithm demonstrated its considerable
149     utility. I'll outline how combinatory logic (dating back to 1920) has a
150     similarly unexpected application to efficient and effective compilation,
151     which directly catalyzed the development of lazy functional programming
152     languages such as Haskell. The talk is self-contained; no prior knowledge
153     of functional programming is necessary.
154   </p></abstract>
155 </eventitem>
156
157 <eventitem date="2010-05-25" time="05:00 PM" room="MC2066" title="Gerald Sussman">
158   <short><p>Why Programming is a Good Medium for Expressing Poorly Understood and Sloppily Formulated Ideas</p></short>
159   <abstract>Full details found <a href="http://csclub.uwaterloo.ca/misc/sussman/">here</a></abstract>
160 </eventitem>
161
162 <eventitem date="2010-05-26" time="03:30 PM" room="MC5136" title="Gerald Sussman">
163   <short><p>Public Reception</p></short>
164   <abstract>Full details found <a href="http://csclub.uwaterloo.ca/misc/sussman/">here</a></abstract>
165 </eventitem>
166
167 <eventitem date="2010-05-26" time="05:000PM" room="MC5158" title="Gerald Sussman">
168   <short><p>The Art of the Propagator</p></short>
169   <abstract>Full details found <a href="http://csclub.uwaterloo.ca/misc/sussman/">here</a></abstract>
170 </eventitem>
171
172 <eventitem date="2010-05-11" time="05:30 PM" room="Comfy Lounge" title="Elections">
173   <short><p>Spring term executive elections and general meeting.</p></short>
174 </eventitem>
175
176 <!-- Winter 2010 -->
177 <eventitem date="2010-04-06" time="04:30 PM" room="DC1304" title="Brush-Based Constructive Solid Geometry">
178   
179     <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.
180 </p></short>
181   
182   
183     <abstract><p>For some would-be graphics programmers, the biggest barrier-to-entry is getting data to render. This is why there exist so 
184 many terrain renderers: by virtue of the fact that rendering height-fields tends to give pretty pictures from next to no 
185 "created" information. However, it becomes more difficult when programmers want to do indoor rendering (in the style of the 
186 Quake and Unreal games). Ripping map information from the Quake games is possible (and fairly simple), but their tool-chain 
187 is fairly clumsy from the point of view of adding a conversion utility.
188 </p><p>My talk is about Constructive Solid Geometry from a Brush-based perspective (nearly identical to Unreal's and still very similar 
189 to Quake's). The basic idea is that there are brushes (convex volumes in 3-space) and they can either be additive (solid brushes) 
190 or subtractive (hollow, or air brushes). The entire world starts off as an infinite solid lump and you can start removing sections 
191 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 
192 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.
193 </p></abstract>
194   
195 </eventitem>
196 <eventitem date="2010-04-07" time="1:00 PM" room="MC2037" title="Windows Azure Lab">
197   
198     <short><p>Get the opportunity to learn about Microsoft's Cloud Services Platform, Windows Azure.   Attend this Hands-on-lab session sponsored by Microsoft. 
199 </p></short>
200   
201   
202     <abstract><p>We are in the midst of an industry shift as developers and businesses embrace the Cloud.  
203 Technical innovations in the cloud are dramatically changing the economics of computing 
204 and reducing barriers that keep businesses from meeting the increasing demands of 
205 today's customers.  The cloud promises choice and enables scenarios that previously 
206 were not economically practical.  
207 </p><p>Microsoft's Windows Azure is an internet-scale cloud computing services platform hosted 
208 in Microsoft data centers.  The Windows Azure platform, allows developers to build and 
209 deploy production ready cloud services and applications. With the Windows Azure platform, 
210 developers can take advantage of greater choice and flexibility in how they develop and 
211 deploy applications, while using familiar tools and programming languages.
212 </p><p>Get the opportunity to learn about Microsoft's Cloud Services Platform, Windows Azure.  
213 Attend the Hands-on-lab session sponsored by Microsoft. 
214 </p></abstract>
215   
216 </eventitem>
217 <eventitem date="2010-04-01" time="6:30 PM" room="CSC Office" title="CTRL-D">
218   
219     <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.
220 </p></short>
221   
222   
223     <abstract><p>Once again the CSC will be holding its traditional end of term dinner. It will
224 be at the Vice President's house. If you don't know how to get there meet
225 at the club office at 6:30 PM, a group will be leaving from the MC then. The
226 dinner will be potluck style so bring a dish for 4-6 people, or some plates
227 or pop or something.
228 </p></abstract>
229   
230 </eventitem>
231 <eventitem date="2010-03-30" time="4:30 PM" room="DC1304" title="NUI: The future of robotics and automated systems">
232   
233     <short><p>Member Sam Pasupalak will present some of his ongoing work in Natural User Interfaces and Robotics in this sixth installment of CS10.
234 </p></short>
235   
236   
237     <abstract><p>Bill Gates in his article “A Robot in every home” in the Scientific American describes how the current 
238 robotics industry resembles the 1970’s of the Personal Computer Industry. In fact it is not just 
239 Microsoft which has already taken a step forward by starting the Microsoft Robotics studio, but robotics 
240 researchers around the world believe that robotics and automation systems are going to be ubiquitous in 
241 the next 10-20 years (similar to Mark Weiser’s analogy of Personal Computers 20 years ago). Natural User 
242 Interfaces (NUIs) are going to revolutionize the way we interact with computers, cellular phones, household 
243 appliances, automated systems in our daily lives. Just like the GUI made personal computing a reality, 
244 I believe natural user interfaces will do the same for robotics. 
245 </p><p>During the presentation I will be presenting my ongoing software project on natural user interfaces as well 
246 as sharing my goals for the future, one of which is to provide an NUI SDK and the other to provide a common 
247 Robotics OS for every hardware vendor that will enable people to make applications without worrying about 
248 underlying functionality. If time permits I would like to present a demo of my software prototype.
249 </p></abstract>
250   
251 </eventitem>
252 <eventitem date="2010-03-26" time="7:00 PM" room="MC7001" title="A Final Party of Code">
253   
254     <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.
255 </p></short>
256   
257   
258     <abstract><p>There is a CSC/CMC Code Party Friday starting at 7:00PM (1900) until we
259 get bored (likely in the early in morning). Come out for fun hacking
260 times, spreading Intertube memes (optional), hacking on open source projects,
261 doing some computational math, and other
262 general classiness. There will be free energy drinks for everyone's
263 enjoyment. This is the last of the term so don't miss out.
264 </p></abstract>
265   
266 </eventitem>
267 <eventitem date="2010-03-23" time="4:30 PM" room="MC5158" title="Memory-Corruption Security Holes: How to exploit, patch and prevent them.">
268   
269     <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.
270 </p></short>
271   
272   
273     <abstract><p>Despite it being 2010, code is still being exploited due to
274 stack overflows, a 40+ year old class of security vulnerabilities. In
275 this talk, I will go over several common methods of program
276 exploitation, both on the stack and on the heap, as well as going over
277 some of the current mitigation techniques (i.e. stack canaries, ASLR,
278 etc.) for these holes, and similarly, how some of these can be
279 bypassed as well.
280 </p></abstract>
281   
282 </eventitem>
283 <eventitem date="2010-03-19" time="7:00 PM" room="Comfy Lounge" title="Another Party of Code">
284   
285     <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.
286 </p></short>
287   
288   
289     <abstract><p>There is a CSC Code Party Friday starting at 7:00PM (1900) until we
290 get bored (likely in the early in morning). Come out for fun hacking
291 times, spreading Intertube memes (optional), hacking on the OpenMoko,
292 creating music mixes, and other
293 general classiness. There will be free energy drinks for everyone's
294 enjoyment.
295 </p></abstract>
296   
297 </eventitem>
298 <eventitem date="2010-03-16" time="4:30 PM" room="MC5158" title="Approximation Hardness and the Unique Games Conjecture">
299   
300     <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.
301 </p></short>
302   
303   
304     <abstract><p>The theory of NP-completeness suggests that some problems in CS are inherently hard—that is, 
305 there is likely no possible algorithm that can efficiently solve them.  Unfortunately, many of 
306 these problems are ones that people in the real world genuinely want to solve!  How depressing!  
307 What can one do when faced with a real-life industrial optimization problem whose solution may 
308 save millions of dollars but is probably impossible to determine without trillions of 
309 years of computation time?
310 </p><p>One strategy is to be content with an approximate (but provably "almost ideal") solution, and from 
311 here arises the theory of approximation algorithms.  However, this theory also has a depressing side, 
312 as many well-known optimization problems have been shown to be provably hard to approximate well.
313 </p><p>This talk shall focus on the depressing.  We will prove that various optimization problems (such as 
314 traveling salesman and max directed disjoint paths) are impossible to approximate well unless P=NP.  
315 These proofs are easy to understand and are REALLY COOL thanks to their use of very slick reductions.
316 </p><p>We shall explore many NP-hard optimization problems and state the performance of the best known 
317 approximation algorithms and best known hardness results.  Tons of open problems will be mentioned, 
318 including the unique games conjecture, which, if proven true, implies the optimality of many of the 
319 best known approximation algorithms for NP-complete problems like MAX-CUT and INDEPENDENT SET.
320 </p><p>I promise fun times and no gruesome math.  Basic knowledge of graph theory and computational 
321 complexity might help but is not required.
322 </p></abstract>
323   
324 </eventitem>
325 <eventitem date="2010-03-12" time="7:00 PM" room="Comfy Lounge" title="A Party of Code">
326   
327     <short><p>A fevered night of code, friends, fun, energy drinks, and the CSC.
328 </p></short>
329   
330   
331     <abstract><p>A fevered night of code, friends, fun, energy drinks, and the CSC.
332 </p><p>Come join us for a night of coding. Get in touch with more experianced coders,
333 advertize for/bug squash on your favourite open source project, write that personal
334 project you were planning to do for a while but haven't found the time. Don't
335 have any ideas but want to sit and hack? We can find something for you to do.
336 </p></abstract>
337   
338 </eventitem>
339
340 <eventitem date="2010-03-09" time="4:30 PM" room="DC1304" title="Software Transactional Memory and Using STM in Haskell">
341   
342     <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.
343 </p></short>
344   
345   
346     <abstract><p>Concurrency is hard. Well maybe not hard, but it sure is annoying to get right. Even the
347 simplest of synchronization tasks are hard to implement correctly when using synchronization
348 primitives such as locks and semaphores.
349 </p><p>In this talk we explore what Software Transactional Memory (STM) is, what problems STM solves,
350 and how to use STM in Haskell. We explore a number of examples that show how easy STM is to use
351 and how expressive Haskell can be. The goal of this talk is to convince attendees that STM is
352 not only a viable synchronization solution, but superior to how synchronization is typically
353 done today.
354 </p></abstract>
355   
356 </eventitem>
357 <eventitem date="2010-03-06" time="5:00 PM" room="Waterloo Bowling Lanes" title="Bowling">
358     <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
359     some or all of the above</p></short>
360 </eventitem>
361
362 <eventitem date="2010-03-02" time="4:30 PM" room="DC1304" title="QIP=PSPACE">
363   
364     <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.
365 </p></short>
366   
367   
368     <abstract><p>The interactive proof system model of computation is a cornerstone of
369 complexity theory, and its quantum computational variant has been
370 studied in quantum complexity theory for the past decade.  In this
371 talk I will discuss an exact characterization of the power of quantum
372 interactive proof systems that I recently proved in collaboration with
373 Rahul Jain, Zhengfeng Ji, and Sarvagya Upadhyay.  The characterization
374 states that the collection of computational problems having quantum
375 interactive proof systems consists precisely of those problems
376 solvable with an ordinary classical computer using a polynomial amount
377 of memory (or QIP = PSPACE in complexity-theoretic terminology).  This
378 characterization implies the striking fact that quantum computing does
379 not provide any increase in computational power over classical
380 computing in the context of interactive proof systems.
381 </p><p>I will not assume that the audience for this talk has any familiarity
382 with either quantum computing or complexity theory; and to be true to
383 the spirit of the interactive proof system model, I hope to make this
384 talk as interactive as possible -- I will be happy to explain anything
385 related to the talk that I can that people are interested in learning
386 about.
387 </p></abstract>
388   
389 </eventitem>
390 <eventitem date="2010-02-26" time="7:00 PM" room="CnD Lounge" title="Contest Closing">
391     <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.
392     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>
393 </eventitem>
394
395 <eventitem date="2010-02-25" time="4:30 PM" room="DC1302" title="CSCF Town Hall">
396   
397     <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.
398 </p></short>
399   
400   
401     <abstract><p>Come to a town hall style meeting with the managers of CSCF to discuss how
402 to improve the undergraduate (student.cs) computing environment. Have gripes?
403 Suggestions? Requests? Now is the time to voice them.
404 </p><p>CSCF management (Bill Ince, Associate Director; Dave Gawley, Infrastructure Support; 
405 Dawn Keenan, User Support; Lawrence Folland, Research Support) will be at the
406 meeting to listen to student concerns and suggestions.  Information gathered from 
407 the meeting will be summarized and taken to the CSCF advisory committee for
408 discussion and planning.
409 </p></abstract>
410   
411 </eventitem>
412
413 <eventitem date="2010-02-23" time="04:30 PM" room="MC5136B" title="The Best Algorithms are Randomized Algorithms">
414   
415     <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.
416 </p></short>
417   
418   
419     <abstract><p>For many problems, randomized algorithms are either the fastest algorithm or the simplest algorithm; 
420 sometimes they even provide the only known algorithm. Randomized algorithms have become so prevalent 
421 that deterministic algorithms could be viewed as a curious special case. In this talk I will describe 
422 some startling examples of randomized algorithms for solving some optimization problems on graphs.
423 </p></abstract>
424   
425 </eventitem>
426
427 <eventitem date="2010-02-09" time="4:30 PM" room="DC1304" title="An Introduction to Vector Graphics Libraries with Cairo">
428   
429     <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.
430 </p></short>
431   
432   
433     <abstract><p>Cairo is an open source, cross platform, vector graphics library with the ability to 
434 output to many kinds of surfaces, including PDF, SVG and PNG surfaces, as well as 
435 X-Window, Win32 and Quartz 2D backends. Unlike the raster graphics used with programmes 
436 and libraries such as The Gimp and ImageMagick, vector graphics are not defined by grids 
437 of pixels, but rather by a collection of drawing operations. These operations detail how to 
438 draw lines, fill shapes, and even set text to create the desired image. This has the 
439 advantages of being infinitely scalable, smaller in file size, and simpler to express within 
440 a computer programme. This talk will be an introduction to the concepts and metaphors used 
441 by vector graphics libraries in general and Cairo in particular.
442 </p></abstract>
443   
444 </eventitem>
445
446 <eventitem date="2010-02-11" time="4:30 PM" room="MC3005" title="UNIX 101 Encore">
447   
448     <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.
449 </p></short>
450   
451   
452     <abstract><p>New to Unix? No problem, we'll teach you to power use circles around your friends!
453 The popular tutorial returns for a second session, in case you missed the first one.
454 </p><p>This first tutorial is an introduction to the Unix shell environment, both on the student
455 servers and on other Unix environments. Topics covered include: using the shell, both basic
456 interaction and advanced topics like scripting and job control, the filesystem and manipulating
457 it, and ssh. If you feel you're already familiar with these topics don't hesitate to come
458 to Unix 102 to learn about documents, editing, and other related tasks, or watch out
459 for Unix 103 and 104 that get much more in depth into power programming tools on Unix.
460 </p></abstract>
461   
462 </eventitem>
463 <eventitem date="2010-02-10" time="4:30 PM" room="MC3003" title="UNIX 101">
464   
465     <short><p>New to Unix? No problem, we'll teach you to power use circles around your friends!
466 </p></short>
467   
468   
469     <abstract><p>New to Unix? No problem, we'll teach you to power use circles around your friends!
470 </p><p>This first tutorial is an introduction to the Unix shell environment, both on the student
471 servers and on other Unix environments. Topics covered include: using the shell, both basic
472 interaction and advanced topics like scripting and job control, the filesystem and manipulating
473 it, and ssh. If you feel you're already familiar with these topics don't hesitate to come
474 to Unix 102 to learn about documents, editing, and other related tasks, or watch out
475 for Unix 103 and 104 that get much more in depth into power programming tools on Unix.
476 </p></abstract>
477   
478 </eventitem>
479 <eventitem date="2010-01-18" time="15:30 PM" room="MC2066" title="Wilderness Programming">
480   
481     <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.
482 </p></short>
483   
484   
485     <abstract><p>Paul Lutus describes his early Apple II software development days, conducted 
486 from the far end of a 1200-foot power cord, in a tiny Oregon cabin. Paul 
487 describes how he wrote a best-seller (Apple Writer) in assembly language, 
488 while dealing with power outages, lightning storms and the occasional 
489 curious bear.
490 </p><p>Paul also describes his subsequent four-year solo around-the-world sail in a 
491 31-foot boat. And be ready with your inquiries -- Paul will answer your 
492 questions.
493 </p><p>Paul Lutus has a wide background in science and technology. He designed spacecraft 
494 components for the NASA Space Shuttle and created a mathematical model of the solar 
495 system used during the Viking Mars lander program. Then, at the beginning of the 
496 personal computer revolution, Lutus switched career paths and took up computer 
497 science. His best-known program is "Apple Writer," an internationally successful 
498 word processing program for the early Apple computers.
499 </p></abstract>
500   
501 </eventitem>
502
503 <eventitem date="2010-01-26" time="05:00 PM" room="DC1302" title="Deep learning with multiplicative interactions">
504   
505     <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>.
506 </p></short>
507   
508   
509     <abstract><p>Deep networks can be learned efficiently from unlabeled data. The layers 
510 of representation are learned one at a time using a simple learning 
511 module, called a "Restricted Boltzmann Machine" that has only one layer 
512 of latent variables. The values of the latent variables of one 
513 module form the data for training the next module.  Although deep 
514 networks have been quite successful for tasks such as object 
515 recognition, information retrieval, and modeling motion capture data, 
516 the simple learning modules do not have multiplicative interactions which
517 are very useful for some types of data.
518 </p><p>The talk will show how a third-order energy function can be factorized to 
519 yield a simple learning module that retains advantageous properties of a 
520 Restricted Boltzmann Machine such as very simple exact inference and a
521 very simple learning rule based on pair-wise statistics. The new module 
522 contains multiplicative interactions that are useful for a variety of 
523 unsupervised learning tasks. Researchers at the University of Toronto 
524 have been using this type of module to extract oriented energy from image 
525 patches and dense flow fields from image sequences. The new module can 
526 also be used to allow motions of a particular style to be achieved by 
527 blending autoregressive models of motion capture data.
528 </p></abstract>
529   
530 </eventitem>
531
532
533 <!-- Fall 2009 -->
534 <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">
535     <short><p>Come on out to the club's termly end of term dinner, details in the abstract</p></short>
536     <abstract><p>The dinner will be potluck style at the Vice President's house, please RSVP (respond swiftly to the vice president)
537     <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
538     office at 6:30 PM, a group will be leaving to lead you there.</p></abstract>
539 </eventitem>
540
541 <eventitem date="2009-11-27" time="7:00 PM" room="Comfy Lounge" edate="2009-11-28" etime="7:00 AM" title="Code Party!!11!!">
542   
543     <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.
544 </p></short>
545   
546   
547     <abstract><p>Come join us for a night of coding. Get in touch with more experianced coders,
548 advertize for/bug squash on your favourite open source project, write that personal
549 project you were planning to do for a while but haven't found the time. Don't
550 have any ideas but want to sit and hack? Try your hand at the Facebook puzzles,
551 write a new app, or just chill and watch scifi.
552 </p></abstract>
553   
554 </eventitem>
555
556 <eventitem date="2009-11-05" time="4:30 PM" room="MC2065" title="In the Beginning">
557
558     <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.
559 </p></short>
560
561
562     <abstract><p>To most CS students an OS kernel is pretty low level. But there is
563 something even lower, the instructions that must be executed to get the
564 CPU ready to accept a kernel.  That is, if you look at any processor's
565 reference manual there is a page or two describing the state of the CPU
566 when it powered on.  This talk describes what needs to happen next,
567 up to the point where the first kernel instruction executes.
568 </p><p>This part of execution is extremely architecture-dependent.  Those of
569 you who have any experience with this aspect of CS probably know the x86
570 architecture, and think it's horrible, which it is. I am going to talk
571 about the ARM architecture, which is inside almost all mobile phones,
572 and which allows us to look at a simple implementation that includes
573 all the essentials.
574 </p></abstract>
575
576 </eventitem>
577
578 <eventitem date="2009-10-20" time="04:30 PM" room="MC3036" title="CSC Goes To Dooly's">
579   
580     <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.
581 </p></short>
582   
583   
584     <abstract><p>We're going to Dooly's to play pool. What more do you want from us?
585 Come to the Club office and we'll all bus there together. We've got
586 discount tables for club members so be sure to be there.
587 </p></abstract>
588   
589 </eventitem>
590
591 <eventitem date="2009-10-16" time="7:00 PM" room="Comfy Lounge" title="Code Party and Contest Finale">
592   
593     <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.
594 </p></short>
595   
596   
597     <abstract><p>Come on out for a night of code, contests, and energy drinks. Join the Computer
598 Scinece Club for the finale of the Google AI Challenge and an all night code party.
599 Finish up your entry, or start it (its not too late). Not interested in the contest?
600 Come out anyway for a night of coding and comradarie with us.
601 </p><p>Included in the party will be the contest finale and awards cerimony, so if you've
602 entered be sure to stick arround to collect the spoils of victory, or see just who
603 that person you couldn't edge off is.
604 </p></abstract>
605   
606 </eventitem>
607
608 <eventitem date="2009-10-08" time="4:30 PM" room="MC3003" title="UNIX 103">
609   
610     <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. 
611 </p></short>
612   
613   
614     <abstract><p>In this long-awaited third installment of the popular Unix Tutorials the 
615 friendly experts of the CSC will teach you the simple art of version control. 
616 You will learn the purpose and use of two different Version Control Systems 
617 (git and subversion). This tutorial will advise you in the discipline of 
618 managing the source code of your projects and enable you to quickly learn new 
619 Version Control Systems in the work place -- a skill that is much sought after 
620 by employers. 
621 </p></abstract>
622   
623 </eventitem>
624
625 <eventitem date="2009-10-14" time="2:30 PM" room="DC1304" title="UofT Graduate School Information Session">
626     <short><p> "Is Graduate School for You?" Get the answers to your grad school questions - and have a bite to eat, our treat</p>
627     </short>
628     <abstract><p> Join Prof. Greg Wilson, faculty member in the Software Engineering research group in the UofT's Department of Computer Science,
629     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
630     be served. <b>Come see what grad school is all about!</b>. All undergraduate students are welcome; registration is not required.</p>
631     <p>For any questions about the program, visit <a href="http://www.cs.toronto.edu/dcs/prospective-grad.html">UofT's website</a>. This
632     event is not run by the CS Club, and is announced here for the benefit of our members.</p></abstract>
633 </eventitem>
634
635 <eventitem date="2009-10-03" time="10:00 AM" edate="2009-10-03" etime="3:30 PM" room="DC1301 FishBowl" title="Linux Install Fest">
636   
637     <short><p>Interested in trying Linux but don't know where to start? 
638     Come to the Linux install fest to demo Linux, get help installing it 
639     on your computer, either stand alone or a dual boot, and help setting 
640     up your fresh install. Have lunch and hang around if you like, or just come in for a CD.
641 </p></short>
642   
643   
644     <abstract><p>Interested in trying Linux but don't know where to start?
645 Come to the Linux install fest to demo Linux, get help installing it on
646 your computer, either stand alone or a dual boot, and help setting 
647 up your fresh install. Have lunch and hang around if you like, or just
648 come in for a qick install.
649 </p></abstract>
650   
651 </eventitem>
652
653 <eventitem date="2009-10-01" time="4:30 PM" room="MC3003" title="UNIX 102">
654   
655     <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. 
656 </p></short>
657   
658   
659     <abstract><p>Unix 102 is a follow up to Unix 101, requiring basic knowledge of the shell. 
660 If you missed Unix101 but still know your way around you should be fine. 
661 Topics covered include: "real" editors, document typesetting with LaTeX 
662 (great for assignments!), bulk editing, spellchecking, and printing in the 
663 student environment and elsewhere. 
664 </p><p>If you aren't interested or feel comfortable with these taskes, watch out for 
665 Unix 103 and 104 to get more depth in power programming tools on Unix. 
666 </p></abstract>
667   
668 </eventitem>
669
670 <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">
671   
672     <short><p>Come learn how to write an intelligent game-playing program.   
673       No past experience necessary.  Submit your program using the <a href="http://csclub.uwaterloo.ca/contest/">online web interface</a> 
674       to watch it battle against other people's programs.   Beginners and experts welcome! Prizes provided by google,
675       including the delivery of your resume to google recruiters.
676 </p></short>
677   
678   
679     <abstract><p>Come learn how to write an intelligent game-playing program.  
680         No past experience necessary.  Submit your program using the <a href="http://csclub.uwaterloo.ca/contest/">online 
681         web interface</a> to watch it battle against other people's programs.  
682         Beginners and experts welcome!
683     </p><p>The contest is sponsored by Google, so be sure to compete for a chance
684          to get noticed by them.
685     </p><p>Prizes for the top programs:
686    <ul><li>$100 in Cash Prizes</li>
687        <li> Google t-shirts</li>
688        <li>Fame and recognition</li>
689        <li>Your resume directly to a Google recruiter</li>
690    </ul>
691 </p></abstract>
692   
693 </eventitem>
694 <eventitem date="2009-09-24" time="4:30 PM" room="MC3003" title="UNIX 101">
695   
696     <short><p>
697         New to Unix? No problem, we'll teach you to power use circles around your friends!
698     </p></short>
699   
700   
701     <abstract><p>
702         New to Unix? No problem, we'll teach you to power use circles around your friends!
703     </p><p>
704         This first tutorial is an introduction to the Unix shell environment, both on the student
705         servers and on other Unix environments. Topics covered include: using the shell, both basic
706         interaction and advanced topics like scripting and job control, the filesystem and manipulating
707         it, and ssh. If you feel you're already familiar with these topics don't hesitate to come
708         to Unix 102 to learn about documents, editing, and other related tasks, or watch out
709         for Unix 103 and 104 that get much more in depth into power programming tools on Unix.
710     </p></abstract>
711 </eventitem>
712
713 <eventitem date="2009-09-15" time="5:00PM" edate="2009-09-15" etime="6:00 PM"
714        room="Comfy Lounge" title="Elections">
715     <short><p>
716      Nominations are open now, either place your name on the nominees board or
717      e-mail <a href="mailto:cro@csclub.uwaterloo.ca">the CRO</a>
718      to nominate someone for a position. 
719      Come to the Comfy Lounge to elect your fall term executive. Contact
720      <a href="mailto:cro@csclub.uwaterloo.ca">the CRO</a> if you have questions.
721     </p></short>
722 </eventitem>
723
724
725 <!-- Spring 2009 -->
726 <eventitem date="2009-07-23" time="4:30 PM" edate="2009-07-23" etime="6:00 PM"
727            room="MC 3003" title="Unix 103">
728     <short><p>
729      In this long-awaited third installment of the popular Unix Tutorials the dark
730      mages of the CSC will train you in the not-so-arcane magick of version control.
731      You will learn the purpose and use of two different Version Control Systems
732      (git and subversion). This tutorial will advise you in the discipline of
733      managing the source code of your projects and enable you to quickly learn new
734      Version Control Systems in the work place -- a skill that is much sought after
735      by employers.
736     </p></short>
737 </eventitem>
738
739 <eventitem date="2009-07-17" time="7:00 PM" edate="2009-07-18" etime="4:00 AM"
740            room="MC 3001" title="Code Party">
741     <short><p>
742      Have an assignment or project you need to work on? We
743      will be coding from 7:00pm until 4:00am starting on Friday, July 17th
744      in the Comfy lounge. Join us!
745     </p></short>
746 </eventitem>
747
748 <eventitem date="2009-07-07" time="3:00 PM" etime="5:00 PM" room="DC 1302" 
749            title="History of CS Curriculum at UW">
750     <short><p>
751      This talk provides a personal overview of the evolution of the
752      undergraduate computer science curriculum at UW over the past forty
753      years, concluding with an audience discussion of possible future
754      developments.
755     </p></short>
756 </eventitem>
757
758 <eventitem date="2009-06-22" time="4:30 PM" etime="6:30 PM" room="MC 4041" 
759            title="Paper Club">
760     <short><p> Come and drink tea and read an academic CS paper with
761      the Paper Club.  We will be meeting from 4:30pm until 6:30pm on
762      Monday, June 22th on the 4th floor of the MC (exact room number
763      TBA).  See http://csclub.uwaterloo.ca/~paper
764     </p></short>
765 </eventitem>
766
767 <eventitem date="2009-06-19" time="5:30 PM" room="Dooly's" title="Dooly's Night">
768     <short><p>
769     The CSC will be playing pool at Dooly's. Join us for only a few dollars.
770     </p></short>
771 </eventitem>
772
773 <eventitem date="2009-06-05" time="7:00 PM" edate="2009-06-06" etime="4:00 AM"
774            room="MC 3001" title="Code Party">
775     <short><p>
776      Have an assignment or project you need to work on? We
777      will be coding from 7:00pm until 7:00am starting on Friday, June 5th
778      in the Comfy lounge. Join us!
779     </p></short>
780 </eventitem>
781
782 <eventitem date="2009-06-02" time="4:30 PM" room="MC 2037" title="Unix 101">
783     <short><p>
784         Need to use the UNIX environment for a course, want to overcome your fears of
785         the command line, or just curious? Come and learn the arcane secrets of the
786         UNIX command line interface from CSC mages. After this tutorial you will be
787         comfortable with the essentials of navigating, manipulating and viewing files,
788         and processing data at the UNIX shell prompt.
789     </p></short>
790 </eventitem>
791
792 <eventitem date="2009-05-12" time="12:00 PM" room="MC 2034" title="PHP on Windows">
793     <short><p>PHP Programming Contest Info Session</p></short>
794     <abstract><p>
795     Port or create a new PHP web application and you could win a prize
796     of up to $10k. Microsoft is running a programming contest for PHP
797     developers willing to support the Windows platform. The contest is
798     ongoing; this will be a short introduction to it by
799     representatives of Microsoft and an opportunity to ask questions.
800     Pizza and pop will be provided.
801     </p></abstract>
802 </eventitem>
803
804
805 <!-- Winter 2009 -->
806 <eventitem date="2009-04-02" time="4:30 PM" room="DC1302" title="Rapid prototyping and mathematical art">
807   
808     <short><p>A talk by Craig S. Kaplan.</p></short>
809   
810   
811     <abstract><p>The combination of computer graphics, geometry, and rapid
812 prototyping technology has created a wide range of exciting
813 opportunities for using the computer as a medium for creative
814 expression.  In this talk, I will describe the most popular
815 technologies for computer-aided manufacturing, discuss
816 applications of these devices in art and design, and survey
817 the work of contemporary artists working in the area (with a
818 focus on mathematical art).  The talk will be primarily
819 non-technical, but I will mention some of the mathematical
820 and computational techniques that come into play.
821 </p></abstract>
822   
823 </eventitem>
824 <eventitem date="2009-04-03" time="6:00 PM" edate="2009-04-04"
825            etime="6:00 AM" room="TBA" title="CTRL-D">
826   <short>
827     <p>
828       Join the Club That Really Likes Dinner for the End Of Term
829       party!  Inquire closer to the date for details.
830     </p>
831   </short>
832   <abstract>
833     <p>
834       This is not an official club event and receives no funding.
835       Bring food, drinks, deserts, etc.
836     </p>
837   </abstract>
838 </eventitem>
839
840 <eventitem date="2009-03-27" time="6:00 PM" edate="2009-03-28"
841            etime="12:00 PM" room="Comfy Lounge (MC)"
842            title="Code Party">
843   <short>
844     <p>
845       CSC Code Party!  Same as always - no sleep, lots of caffeine,
846       and really nerdy entertainment.  Bonus:  Free Cake!
847     </p>
848   </short>
849   <abstract>
850     <p>
851       This code party will have the usual, plus it will double as the
852       closing of the programming contest.  Our experts will be
853       available to help you polish off your submission.
854     </p>
855   </abstract>
856 </eventitem>
857
858 <eventitem date="2009-03-19" time="4:30 PM" edate="2009-03-28"
859            etime="12:00 PM" room="MC2061"
860            title="Artificial Intelligence Contest">
861     <short>
862       <p>
863         Come out and try your hand at writing a computer program that
864         plays Minesweeper Flags, a two-player variant of the classic
865         computer game, Minesweeper.  Once you're done, your program
866         will compete head-to-head against the other entries in a
867         fierce Minesweeper Flags tournament.  There will be a contest
868         kick-off session on Thursday March 19 at 4:30 PM in room
869         MC3036.  Submissions will be accepted until Saturday March 28.
870       </p>
871     </short>
872     <abstract>
873       <p>
874         Come out and try your hand at writing a computer program that
875         plays Minesweeper Flags, a two-player variant of the classic
876         computer game, Minesweeper.  Once you're done, your program
877         will compete head-to-head against the other entries in a
878         fierce Minesweeper Flags tournament.  There will be a contest
879         kick-off session on Thursday March 19 at 4:30 PM in room
880         MC3036.  Submissions will be accepted until Saturday March 28.
881       </p>
882     </abstract>
883 </eventitem>
884
885 <eventitem date="2009-03-05" time="4:30 PM" edate="2009-03-05"
886            etime="6:30 PM" room="Comfy Lounge"
887            title="SIGGRAPH Night">
888   <short>
889     <p>
890       Come out and watch the SIGGRAPH (Special Interest Group on
891       Graphics) conference video review.  A video of insane, amazing,
892       and mind blowing computer graphics. .
893     </p>
894   </short>
895   <abstract>
896     <p>
897       The ACM SIGGRAPH (Special Interest Group on Graphics) hosts a
898       conference yearly in which the latest and greatest in computer
899       graphics premier. They record video and as a result produce a
900       very nice Video Review of the conference. Come join us watching
901       these videos, as well as a few professors from the UW Computer
902       Graphics Lab. There will be some kind of food and drink, and its
903       guranteed to be dazzling.
904     </p>
905   </abstract>
906 </eventitem>
907
908 <eventitem date="2009-03-12" time="8:00 AM" edate="2009-03-13"
909            etime="9:00 PM" room="Toronto Hilton"
910            title="Canadian Undergraduate Technology Conference">
911   <short>
912     <p>
913       See <a href="http://www.cutc.ca">cutc.ca</a> for more details.
914     </p>
915   </short>
916   <abstract>
917     <p>
918       The Canadian Undergraduate Technology Conference is Canada's
919       largest student-run conference. From humble roots it has emerged
920       as a venue that offers an environment for students to grow
921       socially, academically, and professionally. We target to exceed
922       our past record of 600 students from 47 respected institutions
923       nationwide. The event mingles ambitious as well as talented
924       students with leaders from academia and industry to offer
925       memorable experiences and valuable opportunities.
926     </p>
927   </abstract>
928 </eventitem>
929
930 <eventitem date="2009-03-09" time="3:00 PM" room="DC1302"
931            title="Prabhakar Ragde">
932     <short><p>
933     Functional Lexing and Parsing</p></short>
934     <abstract>
935       <p>
936         This talk will describe a non-traditional functional approach
937         to the classical problems of lexing (breaking a stream of
938         characters into "words" or tokens) and parsing (identifying
939         tree structure in a stream of tokens based on a grammar,
940         e.g. for a programming language that needs to be compiled or
941         interpreted). The functional approach can clarify and organize
942         a number of algorithms that tend to be opaque in their
943         conventional imperative presentation. No prior background in
944         functional programming, lexing, or parsing is assumed.
945       </p>
946     </abstract>
947 </eventitem>
948
949 <eventitem date="2009-03-12" time="5:00 PM" etime="7:00 PM" room="RAC2009"
950            title="IQC - Programming Quantum Computers">
951     <short>
952       <p>
953         A brief intro to Quantum Computing and why it matters,
954         followed by a talk on programming quantum computers.  Meet at
955         the CSC at 4:00PM for a guided walk to the RAC.
956       </p>
957     </short>
958     <abstract>
959       <p>
960         Raymond Laflamme is the director of the Institute for Quantum
961         Computing at the University of Waterloo and holds the Canada
962         Research Chair in Quantum Information.  He will give a brief
963         introduction to quantum computing and why it matters, followed
964         by a talk on programming quantum computers.  There will be
965         tours of the IQC labs at the end, and pizza will be provided
966         back at the CSC for all attendees.
967       </p>
968     </abstract>
969 </eventitem>
970
971 <eventitem date="2009-02-27" time="5:00 PM" etime="7:00 PM" room="CSC Office: MC3036" title="Dooly's Night">
972     <short><p>
973     Come join the CSC as we head to Dooly's.</p></short>
974     <abstract><p>
975     Meet us at the Club office as we head to Dooly's for cheap tables and good times.</p></abstract>
976 </eventitem>
977
978 <eventitem date="2009-02-05" time="5:30 PM" room="MC2062 and MC2063" title="UNIX 101 and 102">
979     <short><p>
980     Continuing the popular Unix Tutorials with a rerun of 101 and the debut of 102.</p></short>
981     <abstract><p>
982     Unix 101 is an introduction to the Unix shell environment, both on the student
983     servers and on other Unix environments. Topics covered include: using the shell, both basic
984     interaction and advanced topics like scripting and job control, the filesystem and manipulating
985     it, and ssh. </p><p>
986     Unix 102 is a follow up to Unix 101, requiring basic knowledge of the shell. 
987     If you missed Unix101 but still know your way around you should be fine. 
988     Topics covered include: "real" editors, document typesetting with LaTeX 
989     (great for assignments!), bulk editing, spellchecking, and printing in the 
990     student environment and elsewhere. </p><p>
991     If you aren't interested or feel comfortable with these taskes, watch out for 
992     Unix 103 and 104 to get more depth in power programming tools on Unix. </p></abstract>
993 </eventitem>
994
995
996 <eventitem date="2009-02-03" time="5:30 PM" room="MC3003" title="UNIX 101">
997     <short><p> New to Unix? No problem, we'll teach you to power use circles around your friends!</p></short>
998     <abstract><p>This first tutorial is an introduction to the Unix shell environment, both on the student
999         servers and on other Unix environments. Topics covered include: using the shell, both basic
1000         interaction and advanced topics like scripting and job control, the filesystem and manipulating
1001         it, and ssh. If you feel you're already familiar with these topics don't hesitate to come
1002         to Unix 102 to learn about documents, editing, and other related tasks, or watch out
1003         for Unix 103 and 104 that get much more in depth into power programming tools on Unix.</p></abstract>
1004 </eventitem>
1005
1006 <eventitem date="2009-02-06" time="7:00 PM" room="Comfy Lounge" title="Code Party!">
1007   <short>
1008     <p>
1009       There is a CSC Code Party starting at 7:00PM (19:00).  Come out
1010       and enjoy some good old programming and meet others interested
1011       in writing code!  Free energy drinks and snacks for all.  Plus,
1012       we have lots of things that need to be done if you're looking
1013       for a project to work on!
1014     </p>
1015   </short>
1016   <abstract>
1017     <p>
1018       Code Party.  Awesome.  Need we say more?
1019     </p>
1020   </abstract>
1021 </eventitem>
1022
1023 <eventitem date="2009-01-16" time="7:30 PM" room="Comfy Lounge" title="Code party !!11!!1!!">
1024   
1025     <short><p>There is a CSC Code Party Tonight starting at 7:30PM
1026     (1930) until we get bored (likely in the early in morning). Come
1027     out for fun hacking times, spreading Intertube memes (optional),
1028     hacking on the OpenMoko, creating music mixes, and other general
1029     classyness. If we manage to swing it, there will be delicious
1030     energy drinks for your consumption! Alternatively, if we don't we
1031     will have each other as well as some delicious tea and
1032     coffee. Perhaps a crumpet
1033 </p></short>
1034   
1035   
1036     <abstract><p>There is a CSC Code Party Tonight starting at 7:30PM
1037         (1930) until we get bored (likely in the early in
1038         morning). Come out for fun hacking times, spreading Intertube
1039         memes (optional), hacking on the OpenMoko, creating music
1040         mixes, and other general classyness. If we manage to swing it,
1041         there will be delicious energy drinks for your consumption!
1042         Alternatively, if we don't we will have each other as well as
1043         some delicious tea and coffee. Perhaps a crumpet
1044 </p></abstract>
1045   
1046 </eventitem>
1047
1048 <eventitem date="2009-01-29" time="6:30 PM" room="Modern Languages Theatre" title="Richard M. Stallman">
1049   <short><p> The Free Software Movement and the GNU/Linux Operating System </p>
1050   </short>
1051   <abstract>
1052   <p>
1053   Richard Stallman will speak about the Free Software Movement, which
1054   campaigns for freedom so that computer users can cooperate to
1055   control their own computing activities. The Free Software Movement
1056   developed the GNU operating system, often erroneously referred to as
1057   Linux, specifically to establish these freedoms.</p>
1058   <p><b>About Richard Stallman:</b> 
1059   Richard Stallman launched the development of the GNU operating system (see
1060   <a href="http://www.gnu.org">www.gnu.org</a>) in 1984. GNU is free
1061   software: everyone has the freedom to copy it and redistribute it,
1062   as well as to make changes either large or small. The GNU/Linux
1063   system, basically the GNU operating system with Linux added, is used
1064   on tens of millions of computers today. Stallman has received the
1065   ACM Grace Hopper Award, a MacArthur Foundation fellowship, the
1066   Electronic Frontier Foundation's Pioneer award, and the the Takeda
1067   Award for Social/Economic Betterment, as well as several honorary
1068   doctorates.</p>
1069   </abstract>
1070 </eventitem>
1071
1072 <eventitem date="2009-01-22" time="12:00 PM" room="MC5136" title="Joel Spolsky">
1073   <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>
1074   </short>
1075   <abstract><p><b>About Joel Spolsky:</b> Joel Spolsky is a
1076   globally-recognized expert on the software development process. His
1077   website <em>Joel on Software</em>
1078   (<a href="http://www.joelonsoftware.com/">www.joelonsoftware.com</a>)
1079   is popular with software developers around the world and has been
1080   translated into over thirty languages. As the founder
1081   of <a href="http://www.fogcreek.com/">Fog Creek Software</a> in New
1082   York City, he
1083   created <a href="http://www.fogcreek.com/FogBugz">FogBugz</a>, a
1084   popular project management system for software teams. He is the
1085   co-creator of <a href="http://stackoverflow.com/">Stack
1086   Overflow</a>, a programmer Q&amp;A site. Joel has worked at
1087   Microsoft, where he designed VBA as a member of the Excel team, and
1088   at Juno Online Services, developing an Internet client used by
1089   millions. He has
1090   written <a href="http://www.joelonsoftware.com/BuytheBooks.html">four
1091   books</a>: <em>User Interface Design for Programmers</em> (Apress,
1092   2001), <em>Joel on Software</em> (Apress, 2004), <em>More Joel on
1093   Software </em>(Apress, 2008), and <em>Smart and Gets Things Done:
1094   Joel Spolsky's Concise Guide to Finding the Best Technical
1095   Talent </em>(Apress, 2007). He also writes a monthly column
1096   for<strong> </strong><em><a href="http://www.inc.com/">Inc
1097   Magazine</a>. </em>Joel holds a BS from Yale in Computer
1098   Science. Before college he served in the Israeli Defense Forces as a
1099   paratrooper, and he was one of the founders of Kibbutz Hanaton.</p>
1100  </abstract>
1101 </eventitem>
1102
1103 <eventitem date="2009-01-13" time="4:20 PM" room="Comfy Lounge" title="Term Elections">
1104   <short><p>Winter Elections</p>
1105   </short>
1106 </eventitem>
1107
1108 <!-- Fall 2008 -->
1109 <eventitem date="2008-11-15" time="6:30 AM" room="Toronto" title="Changing the World Conference">
1110   
1111     <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. 
1112 </p></short>
1113   
1114   
1115     <abstract><p>Organized by Queen's students, Changing the World
1116         aims to bring together the world's greatest visionaries to
1117         inspire people to innovate and better our world.  Among these
1118         speakers include Nobel Peace Prize winner, Eric Chivian.  He
1119         was a recipient for his work on stopping nuclear war.
1120       </p><p>The conference is modeled after TED (Technology,
1121         Entertainment, Design), an annual conference uniting the
1122         world's most fascinating thinkers and doers, and like TED,
1123         each speaker is given 18 minutes to give the talk of their
1124         lives.
1125       </p><p>Specifically for students in CS/Math, 50 tickets have
1126         been reserved (non-students: $500).  For those who would like
1127         to attend, please pick up your ticket in the Computer Science
1128         Club office.  The tickets are limited and they are first come
1129         first serve.
1130 </p></abstract>
1131   
1132 </eventitem>
1133
1134 <eventitem date="2008-11-06" time="10:00 AM" room="SLC Multipurpose Room" title="Linux Install Fest">
1135   
1136     <short><p>Come join the CSC in celebrating the new releases of
1137     Ubuntu Linux, Free BSD and Open BSD, and get a hand installing one
1138     of them on your own system.
1139 </p></short>
1140   
1141   
1142     <abstract><p>Come join the CSC in celebrating the new releases of
1143         Ubuntu Linux, Free BSD and Open BSD, and get a hand installing
1144         one of them on your own system.
1145       </p><p>This is an event to celebrate the releases of new
1146         versions of Ubuntu Linux, OpenBSD, and FreeBSD. CDs will be
1147         available and everyone is invited to bring their PC or laptop
1148         to get help installing any of these Free operating
1149         systems. Knowledgeable CSC members will be available to help
1150         with any installation troubles, or to troubleshooting any
1151         existing problems that users may have.
1152       </p><p>This event will also promote gaming on Linux, as well as
1153         FLOSS (Free/Libre and Open Source Software) in general. We may
1154         also have a special guest (Ian Darwin, of OpenBSD and OpenMoko
1155         fame).
1156 </p></abstract>
1157 </eventitem>
1158
1159 <eventitem date="2008-11-10" time="4:30 PM" room="MC4061" title="Functional Programming">
1160   
1161     <short><p>This talk will survey concepts, techniques, and
1162     languages for functional programming from both historical and
1163     contemporary perspectives, with reference to Lisp, Scheme, ML,
1164     Haskell, and Erlang. No prior background is assumed.
1165 </p></short>
1166   
1167   
1168     <abstract><p>This talk will survey concepts, techniques, and
1169         languages for functional programming from both historical and
1170         contemporary perspectives, with reference to Lisp, Scheme, ML,
1171 Haskell, and Erlang. No prior background is assumed.
1172 </p></abstract>
1173   
1174 </eventitem>
1175
1176 <eventitem date="2008-10-24" time="6:00 PM" room="Comfy Lounge" title="Code Party">
1177   <abstract><p>
1178     Come join us for a night of coding. Get in touch with more experianced coders,
1179     advertize for/bug squash on your favourite open source project, write that personal
1180     project you were planning to do for a while but haven't found the time. Don't 
1181     have any ideas but want to sit and hack? We can find something for you to do.
1182   </p></abstract>
1183   <short><p>
1184     A fevered night of code, friends, fun, free energy drinks, and the CSC.
1185   </p></short>
1186 </eventitem>
1187
1188 <eventitem date="2008-10-16" time="4:30 PM" room="Comfy Lounge" title="SIGGRAPH Night">
1189   <short><p>
1190     Come out and watch the SIGGRAPH (Special Interest Group on Graphics) conference video
1191     review. A video of insane, amazing, and mind blowing computer graphics.
1192   </p></short>
1193   <abstract><p>
1194     The ACM SIGGRAPH (Special Interest Group on Graphics) hosts a conference yearly
1195     in which the latest and greatest in computer graphics premier. They record video
1196     and as a result produce a very nice Video Review of the conference. Come join us
1197     watching these videos, as well as a few professors from the UW Computer Graphics
1198     Lab. There will be some kind of food and drink, and its guranteed to be dazzling.
1199   </p></abstract>
1200 </eventitem>
1201
1202 <eventitem date="2008-09-12" time="4:30 PM" room="Comfy Lounge" title="Meet the CSC">
1203   <short><p>
1204     Come out and meet other CSC members, find out about the CSC, meet the executive
1205     nominees, and join if you like what you see. Nominees should plan on attending.
1206   </p></short>
1207 </eventitem>
1208
1209 <eventitem date="2008-09-16" time="4:30 PM" room="Comfy Lounge" title="CSClub Elections">
1210   <short><p>
1211     Elections are scheduled for Tues, Sep 16 @ 4:30 pm in the comfy lounge.
1212     The nomination period closes on Mon, Sep 15 @ 4:30 pm. Nominations may be
1213     sent to cro@csclub.uwaterloo.ca. Candidates should not engage in
1214     campaigning after the nomination period has closed.
1215   </p></short>
1216 </eventitem>
1217
1218 <eventitem date="2008-09-25" time="4:30 PM" room="MC2037" title="Unix 101">
1219   <short><p>
1220     New to Unix? No problem, we'll teach you to power use circles around your friends!
1221   </p></short>
1222   <abstract><p>
1223     This first tutorial is an introduction to the Unix shell environment, both on the student
1224     servers and on other Unix environments. Topics covered include: using the shell, both basic
1225     interaction and advanced topics like scripting and job control, the filesystem and manipulating
1226     it, and ssh. If you feel you're already familiar with these topics don't hesitate to come 
1227     to Unix 102 to learn about documents, editing, and other related tasks, or watch out
1228     for Unix 103 and 104 that get much more in depth into power programming tools on Unix.
1229   </p></abstract>
1230 </eventitem>
1231
1232 <eventitem date="2008-10-07" time="4:30 PM" room="MC2037" title="Unix 101">
1233   <short><p>
1234     New to Unix? No problem, we'll teach you to power use circles around your friends!
1235   </p></short>
1236   <abstract><p>
1237     This first tutorial is an introduction to the Unix shell environment, both on the student
1238     servers and on other Unix environments. Topics covered include: using the shell, both basic
1239     interaction and advanced topics like scripting and job control, the filesystem and manipulating
1240     it, and ssh. If you feel you're already familiar with these topics don't hesitate to come 
1241     to Unix 102 to learn about documents, editing, and other related tasks, or watch out
1242     for Unix 103 and 104 that get much more in depth into power programming tools on Unix.
1243   </p></abstract>
1244 </eventitem>
1245
1246 <eventitem date="2008-10-09" time="4:30 PM" room="MC2037" title="Unix 102">
1247   <short><p>
1248     Want more from Unix? No problem, we'll teach you to create and quickly edit high quality documents.
1249   </p></short>
1250   <abstract><p>
1251     This is a follow up to Unix 101, requiring basic knowledge of the shell. If you missed 
1252     Unix101 but still know your way around you should be fine. Topics covered include: "real" editors,
1253     document typesetting with LaTeX (great for assignments!), bulk editing, spellchecking, and printing
1254     in the student environment and elsewhere. If you aren't interested or feel comfortable with these
1255     taskes, watch out for Unix 103 and 104 to get more depth in power programming tools on Unix. If you
1256     don't think you're ready go to Unix 101 on Tuesday to get familiarized with the shell environment.
1257   </p></abstract>
1258 </eventitem>
1259
1260 <eventitem date="2008-10-03" time="4:30 PM" room="MC2065" title="Game Sketching">
1261   <short><p>Juancho Buchanan, CTO Relic Entertainment</p></short>
1262   <abstract><p>
1263       In this talk I will give an overview of the history of Relic and our
1264       development philosophy.  The Talk will then proceed to talk about work
1265       that is being pursued in the area of early game prototyping with the
1266       introduction of game sketching methodology.
1267     </p>
1268     <p>
1269       Bio:
1270
1271       Fired from his first job for playing Video Games Juancho Buchanan is
1272       currently the director of Technology for Relic Entertainment.  Juancho
1273       Buchanan Wrote his first game in 1984 but then pursued other interests
1274       which included a master's in Program Visualization, A Doctorate in
1275       Computer Graphics, a stint as a professor at the University of Alberta
1276       where he pioneered early work in Non photo realistic rendering, A stint
1277       at Electronic Arts as Director, Advanced Technology, A stint at EA as
1278       the University Liaison Dude, A stint at Carnegie Mellon University where
1279       he researched the Game Sketching idea.  His current role at Relic has
1280       him working with the soon to be released Dawn of War II.
1281   </p></abstract>
1282 </eventitem>
1283
1284
1285 <eventitem date="2008-10-02" time="4:30 PM" room="MC4021" title="General Meeting 2">
1286   <short><p>
1287     The second official general meeting of the term. Items on the adgenda are CSC Merch,
1288     upcoming talks, and other possible planned events, as well as the announcement of
1289     a librarian and planning of an office cleanout and a library organization day.
1290   </p></short>
1291 </eventitem>
1292
1293 <!-- Spring 2008 -->
1294
1295 <!-- Winter 2008 -->
1296
1297 <eventitem date="2008-02-08" time="4:30 PM" room="MC4042" title="A Brief History of Blackberry and the Wireless Data Telecom Industry">
1298   <short>Tyler Lessard</short>
1299   <abstract><p>
1300 Tyler Lessard from RIM will present a brief history of BlackBerry
1301 technology and will discuss how the evolution of BlackBerry as an
1302 end-to-end hardware, software and services platform has been
1303 instrumental to its success and growth in the market.  Find out how the
1304 BlackBerry service components integrate with wireless carrier networks
1305 and get a sneak peek at where the wireless data market is going.
1306   </p></abstract>
1307 </eventitem>
1308
1309 <eventitem date="2008-02-29" time="5:00 PM" room="BFG2125" title="Quantum Information Processing">
1310   <short>Raymond Laflamme</short>
1311   <abstract><p>
1312       Information processing devices are pervasive in our society; from the 5
1313       dollar watches to multi-billions satellite network.  These devices have
1314       allowed the information revolution which is developing around us. It has
1315       transformed not only the way we communicate or entertain ourselves but
1316       also the way we do science and even the way we think. All this
1317       information is manipulated using the classical approximation to the laws
1318       of physics, but we know that there is a better approximation: the
1319       quantum mechanical laws.  Would using quantum mechanics for information
1320       processing be an impediment or could  it be an advantage?  This is the
1321       fundamental question at the heart of quantum information processing
1322       (QIP). QIP is a young field with an incredible potential impact reaching
1323       from the way we understand fundamental physics to technological
1324       applications. I will give an overview of the Institute for Quantum
1325       Computing,  comment on the effort in this field at Waterloo and in
1326       Canada and, time permitted visit some of the IQC labs.
1327   </p></abstract>
1328 </eventitem>
1329
1330 <eventitem date="2008-02-14" time="4:00PM" room="MC2061" title="CSC Programming Contest 1">
1331   <short>Yes, we know this is Valentine's Day.</short>
1332   <abstract><p>
1333       Contestants will be writing an artificial intelligence to play Risk.  The
1334       prize will be awarded to the intelligence which wins the most
1335       head-to-head matches against competing entries.  We're providing easy
1336       APIs for several languages, as well as full documentation of the game
1337       protocol so contestants can write wrappers for any additional language
1338       they wish to work in.
1339     </p>
1340     <p>
1341       We officially support entries in Scheme, Perl, Java, C, and C++.  If you
1342       would like help developing an API for some other language contact us
1343       through the systems committee mailing list (we will require that your API
1344       is made available to all entrants).
1345     </p>
1346     <p>
1347       To kick off the contest we're hosting an in-house coding session starting
1348       at 4:00PM on Thursday, February 14th in MC2061.  Members of our contest
1349       administration team will be available to help you work out the details of
1350       our APIs, answer questions, and provide the necessities of life (ie,
1351       pizza).  Submissions will open no later than 5:00PM on February 14th
1352       and will close no earlier than 12:00PM on February 17th.
1353     </p>
1354     <p>
1355       Visit our contest site <a href="http://csclub.uwaterloo.ca/contest/"> here!</a>
1356   </p></abstract>
1357 </eventitem>
1358
1359
1360 <eventitem date="2008-01-23" time="5:00 PM" room="MC 4020" title="Creating Distributed Applications with TIPC">
1361   <short>Elmer Horvath</short>
1362   <abstract><p>
1363       The problem:  coordinating and communicating between multiple processors
1364       in a distributed system (possibly containing heterogeneous elements)
1365       </p><p>
1366       The open source TIPC (transparent interprocess communication) protocol
1367       has been incorporated into the Linux kernel and is available in VxWorks
1368       and, soon, other OSes.  This emerging protocol has a number of
1369       advantages in a clustered environment to simplify application
1370       development while maintaining a familiar socket programming interface.
1371       The service oriented capabilities of TIPC help in applications easily
1372       finding required services in a system.  The location transparent aspect
1373       of TIPC allows services to be located anywhere in the system as well as
1374       allowing redundant services for both load reduction and backup.
1375       
1376       Learn about the emerging cluster protocol.
1377   </p></abstract>
1378 </eventitem>
1379
1380 <eventitem date="2008-01-15" time="4:30 PM" room="Comfy Lounge" title="CSClub Elections">
1381   <abstract><p>
1382     Elections are scheduled for Tues, Jan 15 @ 4:30 pm in the comfy lounge.
1383     The nomination period closes on Mon, Jan 14 @ 4:30 pm. Candidates should
1384     not engage in campaigning after the nomination period has closed.
1385   </p></abstract>
1386 </eventitem>
1387
1388
1389 <!-- fall 2007 -->
1390
1391         <eventitem date="2007-10-19" time="5:00 PM" room="MC4058" title="General Meeting">
1392         <abstract>
1393         <p>
1394         There is a general meeting scheduled for Friday, October 19, 2007 at 17:00.
1395         </p>
1396         <p>
1397         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>
1398         </p>
1399         </abstract>
1400         </eventitem>
1401
1402         <eventitem date="2007-09-25" time="1:30 PM" room="DC 1302" title="Virtual Reality, Real Law: The regulation of Property in Video Games">
1403          <short>Susan Abramovitch</short>
1404          <abstract>
1405         <p>
1406         This talk is run by the School of Computer Science
1407         </p>
1408         <p>
1409         How should virtual property created in games, such as weapons used in
1410 games like Mir 3 and real estate or clothing created or acquired in
1411 games like Second Life, be treated in law.  Although the videogaming
1412 industry continues to multiply in value, virtual property created in
1413 virtual worlds has not been formally recognized by any North American
1414 court or legislature.  A bridge has been taking shape from gaming's
1415 virtual economies to real world economies, for example, through
1416 unauthorized copying of designer clothes sold on Second Life for in-game
1417 cash, or real court damages awarded against deletion of player-earned
1418 swords in Mir 3.  The trading of virtual property is important to a
1419 large number of people and property rights in virtual property are
1420 currently being recognized by some foreign legal bodies.
1421 </p>
1422 <p>
1423 Susan Abramovitch will explain the legal considerations in determining
1424 how virtual property can or should be governed, and ways it can be
1425 legally similar to tangible property.  Virtual property can carry both
1426 physical and intellectual property rights.  Typically video game
1427 developers retain these rights via online agreements, but Ms.
1428 Abramovitch questions whether these rights are ultimately enforceable
1429 and will describe policy issues that may impact law makers in deciding
1430 how to treat virtual property under such agreements.
1431 </p>
1432          </abstract>
1433         </eventitem>
1434
1435         <eventitem date="2007-10-02" time="4:30 PM" room="MC4061" title="Putting the fun into Functional Languages and Useful Programming with OCaml/F#">
1436          <short>Brennan Taylor</short>
1437          <abstract>
1438         <p>A lecture on why functional languages are important, practical applications, and some neat examples. Starting with an introduction to
1439 basic functional programming with ML syntax, continuing with the strengths of OCaml and F#, followed by some exciting examples. Examples include GUI 
1440 programming with F#, Web Crawlers with F#, and OpenGL/GTK programming with OCaml. This lecture aims to display how powerful functional languages can 
1441 be.</p>
1442          </abstract>
1443         </eventitem>
1444         <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">
1445          <short>Brennan Taylor</short>
1446          <abstract>
1447         <p>
1448         A lecture on the fundamentals of Pi-Calculus followed by an introduction
1449 to Join-Calculus in JoCaml with some great examples. Various concurrent
1450 control structures are explored, as well as the current limitations of
1451 JoCaml. The examples section will mostly be concurrent programming,
1452 however some basic distributed examples will be explored. This lecture
1453 focuses on how easy concurrent programming can be.
1454         </p>
1455          </abstract>
1456         </eventitem>
1457
1458         <eventitem date="2007-10-15" time="4:30 PM" room="MC4041" title="Off-the-Record Messaging: Useful Security and Privacy for IM">
1459          <short>Ian Goldberg</short>
1460          <abstract>
1461 <p>
1462 Instant messaging (IM) is an increasingly popular mode of communication
1463 on the Internet.  Although it is used for personal and private
1464 conversations, it is not at all a private medium.  Not only are all of
1465 the messages unencrypted and unauthenticated, but they are all
1466 routedthrough a central server, forming a convenient interception point
1467 for an attacker.  Users would benefit from being able to have truly
1468 private conversations over IM, combining the features of encryption,
1469 authentication, deniability, and forward secrecy, while working within
1470 their existing IM infrastructure.
1471 </p>
1472 <p>
1473 In this talk, I will discuss "Off-the-Record Messaging" (OTR), a widely
1474 used software tool for secure and private instant messaging.  I will
1475 outline the properties of Useful Security and Privacy Technologies that
1476 motivated OTR's design, compare it to other IM security mechanisms, and
1477 talk about its ongoing development directions.
1478 </p>
1479 <p>
1480 Ian Goldberg is an Assistant Professor of Computer Science at the
1481 University of Waterloo, where he is a founding member of the
1482 Cryptography, Security, and Privacy (CrySP) research group.  He holds a
1483 Ph.D. from the University of California, Berkeley, where he discovered
1484 serious weaknesses in a number of widely deployed security systems,
1485 including those used by cellular phones and wireless networks. He also
1486 studied systems for protecting the personal privacy of Internet users,
1487 which led to his role as Chief Scientist at Zero-Knowledge Systems (now
1488 known as Radialpoint), where he commercialized his research as the
1489 Freedom Network.
1490 </p>
1491          </abstract>
1492         </eventitem>
1493
1494
1495         <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*">
1496          <short>Andrei Barbu</short>
1497          <abstract>
1498          </abstract>
1499         </eventitem>
1500         <eventitem date="2007-11-22" time="4:30 PM" room="MC 4041" title="More Haskell functional programming fun!">
1501          <short>Andrei Barbu</short>
1502          <abstract>
1503 Haskell is a modern lazy, strongly typed functional language with type inferrence. This talk will focus on multiple monads, existential types,
1504 lambda expressions, infix operators and more. Along the way we'll see a parser and interpreter for lambda calculus using monadic parsers. STM,
1505 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
1506 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!
1507
1508          </abstract>
1509         </eventitem>
1510
1511         <eventitem date="2007-11-29" time="4:30 PM" room="MC 4061" title="Concurrent / Distributed programming with JoCaml">
1512          <short>Brennan Taylor</short>
1513          <abstract>
1514         <p>
1515         A lecture on the fundamentals of Pi-Calculus followed by an introduction to Join-Calculus in JoCaml with some great examples. 
1516         Various concurrent control structures are explored, as well as the current limitations of JoCaml. The examples section will 
1517         mostly be concurrent programming, however some basic distributed examples will be explored. This lecture focuses on how easy 
1518         concurrent programming can be.
1519         </p>
1520          </abstract>
1521         </eventitem>
1522
1523         <eventitem date="2007-12-04" time="4:30 PM" room="TBA" title="PE Executable Translation: A solution for legacy games on linux (Postponed)">
1524          <short>David Tenty</short>
1525          <abstract>
1526         <p>
1527         With today's fast growing linux user base, a large porportion of legacy applications have established open-source equivalents or ports.
1528         However, legacy games provided an intresting problem to gamers who might be inclinded to migrate to linux or other open platforms.
1529         PE executable translation software will be presented that provides a solution to this dilema and will be contrasted with the windows compatiblity framwork Wine.
1530         Postponed to a later date.
1531         </p>
1532          </abstract>
1533         </eventitem>
1534
1535         <eventitem date="2007-12-01" time="1:30 PM" room="MC 2037" title="Programming Contest">
1536          <short>Win Prizes!</short>
1537          <abstract>
1538         <p>
1539         The Computer Science club is holding a programming contest from 1:00 to 6:30 open to all! C++,C,Perl,Scheme are allowed. 
1540         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>
1541         </p>
1542         <p>
1543         And Free Pizzaa for all who attend!
1544         </p>
1545          </abstract>
1546         </eventitem>
1547         <eventitem date="2007-12-02" time="2:30 PM" room="TBA" title="Multi-Player Linux games for Linux awarness week">
1548          <short>Multi-Player Gaming with Linux [Possibly Pizza!]</short>
1549          <abstract>
1550         <p>
1551         Come out for multi-player gaming on Linux. If you don't have linux on your machine, we will have LiveCDs available.
1552         Lots of fun! Possible Pizzaa!
1553         </p>
1554          </abstract>
1555         </eventitem>
1556
1557         <eventitem date="2007-10-04" time="4:30 PM" room="TBA" title="Distributed Programming with Erlang">
1558          <short>Brennan Taylor</short>
1559          <abstract>
1560         <p>
1561         A quick introduction on the current state of distributed programming and various grid computing projects. Followed by some 
1562         history and features of the Erlang language and finishing with distributed examples including operating on a cluster.
1563         </p>
1564          </abstract>
1565         </eventitem>
1566
1567         <eventitem date="2007-12-05" time="4:30 PM" room="MC 4061" title="Google Summer of Code, a look back on 2007">
1568          <short>Holden Karau</short>
1569          <abstract>
1570         <p>
1571         An overview on Google Summer of Code 2007. This talk will look at some of the Summer of Code projects, the project organization, etc.
1572         </p>
1573         <p>
1574         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 
1575         subversion project.
1576         </p>
1577          </abstract>
1578         </eventitem>
1579
1580
1581
1582 <!--spring 2007-->
1583
1584   <eventitem date="2007-07-17" time="7:00 PM" room="AL 116" title="C++0x - An Overview">
1585     <short>Bjarne Stroustrup</short>
1586     <abstract><p>
1587       A good programming language is far more than a simple collection of
1588       features. My ideal is to provide a set of facilities that smoothly work
1589       together to support design and programming styles of a generality beyond
1590       my imagination. Here, I briefly outline rules of thumb (guidelines,
1591       principles) that are being applied in the design of C++0x. Then, I
1592       present the state of the standards process (we are aiming for C++09) and
1593       give examples of a few of the proposals such as concepts, generalized
1594       initialization, being considered in the ISO C++ standards committee.
1595       Since there are far more proposals than could be presented in an hour,
1596       I'll take questions.
1597     </p></abstract>
1598   </eventitem>
1599
1600   <eventitem date="2007-07-06" time="4:30 PM" room="AL 116" title="Copyright vs Community in the Age of Computer Networks">
1601     <short>Richard Stallman</short>
1602     <abstract><p>
1603       Copyright developed in the age of the printing press, and was designed 
1604       to fit with the system of centralized copying imposed by the printing 
1605       press. But the copyright system does not fit well with computer 
1606       networks, and only draconian punishments can enforce it.
1607     </p><p>
1608       The global corporations that profit from copyright are lobbying for 
1609       draconian punishments, and to increase their copyright powers, while 
1610       suppressing public access to technology. But if we seriously hope to 
1611       serve the only legitimate purpose of copyright--to promote progress, for 
1612       the benefit of the public--then we must make changes in the other 
1613       direction.
1614     </p><p>
1615       The CSC would like to thank MEF and Mathsoc for funding this talk.
1616     </p><p>
1617       <a href="http://www.fsf.org/events/waterloo20070706">The Freedom Software Foundation's description</a><br />
1618       <a href="http://www.defectivebydesign.org">FSF's anti-DRM campaign</a><br />
1619       <a href="http://www.badvista.org">Why you shouldn't use Microsoft Vista</a><br />
1620       <a href="http://www.gnu.org">The GNU's Not Unix Project</a><br />
1621     </p></abstract>
1622   </eventitem>
1623
1624   <eventitem date="2007-06-27" time="4:30 PM" room="MC 4042" title="Usability in the wild">
1625     <short>A talk by Michael Terry</short>
1626     <abstract><p>
1627       What is the typical monitor resolution of a GIMP user? How many monitors 
1628       do they have? What size images do they work on? How many layers are in 
1629       their images? The answers to these questions are generally unknown: No 
1630       means currently exist for open source applications to collect usage 
1631       data. In this talk, I will present ingimp, a version of GIMP that has 
1632       been instrumented to automatically collect usage data from real-world 
1633       users. I will discuss ingimp's design, the type of data we collect, how 
1634       we make the data available on the web, and initial results that begin to 
1635       answer the motivating questions.
1636       </p><p>
1637       ingimp can be found at http://www.ingimp.org.
1638       </p></abstract>
1639   </eventitem>
1640
1641   <eventitem date="2007-06-22" time="4:30 PM"
1642         room="MC 4042"
1643         title="Email encryption for the masses">
1644         <short>Ken Ho</short>
1645         <abstract><p>
1646       E-mail transactions and confirmations have become commonplace and the
1647       information therein can often be sensitive. We use email for purposes as
1648       mundane as inbound marketing, to as sensitive as account passwords and
1649       financial transactions. And nearly all our email is sent in clear text;
1650       we trust only that others will not eavesdrop or modify our messages. But
1651       why rely on the goodness or apathy of your fellow man when you can
1652       ensure your message's confidentiality with encryption so strong not even
1653       the NSA can break? Speaker (Kenneth Ho) will discuss email encryption,
1654       and GNU Privacy Guard to ensure that your messages are sent, knowing
1655       that only your intended recipient can receive it.
1656       </p><p>An optional code-signing party will be held immediately 
1657       afterwards; if you already have a PGP or GPG key and wish to 
1658       participate, please submit the public key to 
1659       <a href="mailto:gpg-keys@csclub.uwaterloo.ca">
1660       gpg-keys@csclub.uwaterloo.ca</a>.
1661     </p><p>
1662       Laptop users are invited also to participate in key-pair sharing 
1663       on-site, though it is preferable to send keys ahead of time.
1664     </p></abstract>
1665  </eventitem>
1666
1667   <eventitem date="2007-06-18" time="4:30 PM"
1668         room="DC 4040" title="Fedspulse.ca, Web 3.0, Portals and the Metaverse">
1669         <short>Peter Macdonald</short>
1670         <abstract><p>
1671       The purpose of the talk is to address how students interact with the
1672       internet, and possibilities for how they could do so more efficiently. 
1673       Information on events and happenings on UW campus is currently hosted 
1674       on a desperate, series of internet applications. Interactions with 
1675       WatSFIC is done over a Yahoo! mailing list, GLOW is organized through a 
1676       Facebook group, campus information at large comes from 
1677       <a href="http://imprint.uwaterloo.ca">imprint.uwaterloo.ca</a>. There 
1678       has been historical pressures from various bodies, including some 
1679       thinkers in feds and the administration, to centralize these issues. To 
1680       create a one stop shop for students on campus.
1681     </p><p>
1682       It is not through confining data in cages that we will finally link all 
1683       student activities together, instead it is by truly freeing it. When 
1684       data can be anywhere, then it will be everywhere students need it. This 
1685       is the underlying concept behind metadata, data that is freed from the 
1686       confines of it's technical imprisonment. Metadata is the extension of 
1687       people, organizations, and activities onto the internet in a way that is 
1688       above the traditional understanding of how people interact with their 
1689       networks. The talk will explore how Metadata can exist freely on the 
1690       internet, how this affects concepts like Web 3.0, and how the university 
1691       and the federation are poised to take advantage of this burgeoning new 
1692       technology through adoptions of portals which will allow students to 
1693       interact with a metaverse of data.
1694     </p></abstract>
1695   </eventitem>
1696
1697 <!-- Winter 2007 -->
1698
1699   <eventitem date="2007-04-11" time="3:30 PM" room="Hagey Hall" title="The Free Software Movement and the GNU/Linux Operating System">
1700     <short>A talk by Richard M. Stallman (RMS) <b>[CANCELLED]</b></short>
1701     <abstract><p>
1702       Richard Stallman has cancelled his trip to Canada.
1703     </p></abstract>
1704   </eventitem>
1705
1706   <eventitem date="2007-04-08" time="4:30pm" room="MC 4041" title="Loop Optimizations">
1707     <short>A talk by Simina Branzei</short>
1708     <abstract><p>
1709       Abstract coming soon!
1710     </p></abstract>
1711   </eventitem>
1712
1713   <eventitem date="2007-04-01" time="4:30 PM" room="MC 3036" title="Surprise
1714     Bill Gates Visit">
1715    <abstract>
1716    <p>
1717    While reading Slashdot, Bill came across the recently digitized audio
1718    recording of his 1989 talk at the Computer Science Club. As Bill has always
1719    had a soft-spot for the Computer Science Club, he has decided to pay us a
1720    surprise visit.
1721    </p><p>
1722    Bill promises to give away free copies of Windows Vista Ultimate, because
1723    frankly, nobody here (except j2simpso) wants to pay for a frisbee. Be sure
1724    to bring your resumes kids, because Bill will be recruiting for some 
1725    exciting new positions at Microsoft, including Mindless Drone, Junior Code
1726    Monkey, and Assistant Human Cannonball.
1727    </p>
1728    </abstract>
1729  </eventitem>
1730
1731   <eventitem date="2007-03-28" time="5:30 PM"
1732    room="MC 1056" title="Computational Physics Simulations">
1733    <short>A talk by David Tenty and Alex Parent</short>
1734    <abstract>
1735    <p>
1736         Coming Soon!
1737     </p>
1738     </abstract>
1739   </eventitem>
1740
1741
1742
1743   <eventitem date="2007-03-29" time="4:30 PM"
1744    room="MC 1056" title="All The Code">
1745    <short>A demo/introduction to a new source code search engine. A talk by Holden Karau</short>
1746    <abstract>
1747    <p>
1748 Source code search engines are a relatively new phenomenon . The general idea of most source code search engines is helping programmers find 
1749 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. 
1750 <a href="http://www.allthecode.com/">All The Code</a> is a 
1751 next generation source code search engine. Unlike earlier generations of source code search engines, it considers how code is used to help determine 
1752 relevance of code.
1753 </p>
1754 <p>
1755 The talk will primarily be a demo of <a href="http://www.allthecode.com">All The Code</a>, 
1756 along with a brief discussion of some of the technology behind it.
1757     </p>
1758     </abstract>
1759   </eventitem>
1760
1761
1762   <eventitem date="2007-04-04" time="4:00 PM"
1763    room="MC 1056" title="Data Analysis with Kernels: [an introduction]">
1764    <short>A talk by Michael Biggs. This talk is RESCHEDULED due to unexpected
1765    circumstances</short>
1766    <abstract>
1767    <p>
1768 I am going to take an intuitive, CS-style approach to a discussion about the
1769 use of kernels in modern data analysis.  This approach often lends us
1770 efficient ways to consider a dataset under various choices of inner product,
1771 which is roughly comparable to a measure of "similarity".  Many new tools in
1772 AI arise from kernel methods, such as the infamous Support Vector Machines for
1773 classification, and kernel-PCA for nonlinear dimensionality reduction.  I will
1774 attempt to highlight, and provide visualization for some of the math involved
1775 in these methods while keeping the material at an accessible, undergraduate
1776 level.
1777     </p>
1778     </abstract>
1779   </eventitem>
1780
1781
1782
1783   <eventitem date="2007-02-26" time="4:30 pm"
1784    room="DC 1350" title="ReactOS: An Open Source OS Platform for Learning">
1785    <short>A talk by Alex Ionescu</short>
1786    <abstract>
1787    <p>
1788 The ReactOS operating system has been in development for over eight years and aims to provide users
1789 with a fully functional and Windows-compatible distribution under the GPL license. ReactOS comes with
1790 its own Windows 2003-based kernel and system utilities and applications, resulting in an environment
1791 identical to Windows, both visually and internally.
1792 </p><p>
1793 More than just an alternative to Windows, ReactOS is a powerful platform for academia, allowing
1794 students to learn a variety of skills useful to software testing, development and management, as well as
1795 providing a rich and clean implementation of Windows NT, with a kernel compatible to published
1796 internals book on the subject.
1797 </p><p>
1798 This talk will introduce the ReactOS project, as well as the various software engineering challenges
1799 behind it. The building platform and development philosophies and utilities will be shown, and
1800 attendees will grasp the vast amount of effort and organization that needs to go into building an
1801 operating system or any other similarly large project. The speaker will gladly answer questions related to
1802 his background, experience and interests and information on joining the project, as well as any other
1803 related information.
1804 </p><p>
1805 <strong>Speaker Bio</strong>
1806 </p><p>
1807 Alex Ionescu is currently studying in Software Engineering at Concordia University in Montreal, Quebec
1808 and is a Microsoft Technical Student Ambassador. He is the lead kernel developer of the ReactOS Project
1809 and project leader of TinyKRNL. He regularly speaks at Linux and Open Source conferences around the
1810 world and will be a lecturer at the 8th International Free Software Forum in Brazil this April, as well as
1811 providing hands-on workshops and lectures on Windows NT internals and security to various companies.
1812     </p>
1813     </abstract>
1814   </eventitem>
1815
1816
1817   <eventitem date="2007-02-15" time="4:30 PM"
1818    room="MC 2065" title="An Introduction to Recognizing Regular Expressions in Haskell">
1819    <short>A talk by James deBoer</short>
1820    <abstract>
1821    <p>
1822
1823 This talk will introduce the Haskell programming language and and walk
1824 through building a recognizer for regular languages. The talk will
1825 include a quick overview of regular expressions, an introduction to
1826 Haskell and finally a line by line analysis of a regular language
1827 recognizer.
1828     </p>
1829     </abstract>
1830   </eventitem>
1831
1832   <eventitem date="2007-02-09" time="4:30 PM"
1833    room="MC 4041" title="Introduction to 3-d Graphics">
1834    <short>A talk by Chris "The Prof" Evensen</short>
1835    <abstract>
1836    <p>
1837  A talk for those interested in 3-dimensional graphics but unsure of where to
1838  start.  Covers the basic math and theory behind projecting 3-dimensional
1839  polygons on screen, as well as simple cropping techniques to improve
1840  efficiency.  Translation and rotation of polygons will also be discussed.
1841    </p>
1842    </abstract>
1843   </eventitem>
1844
1845   <eventitem date="2007-02-09" time="8:30 PM"
1846    room="DC 1351" title="Writing World Class Software">
1847    <short>A talk by James Simpson</short>
1848    <abstract>
1849    <p>
1850 A common misconception amongst software developers is that top quality software 
1851 encompasses certain platforms, is driven by a particular new piece of 
1852 technology, or relies solely on a particular programming language.  However as 
1853 developers we tend to miss the less hyped issues and techniques involved in 
1854 writing world class software.  These techniques are universal to all 
1855 programming languages, platforms and deployed technologies but are often times 
1856 viewed as being so obvious that they are ignored by the typical developer.  The 
1857 topics covered in this lecture will include:
1858 </p><p>
1859 - Writing bug-free to extremely low bug count software in real-time<br/>
1860 - The concept of single-source, universal platform software<br/>
1861 - Programming language interoperability<br/>
1862 <br/>
1863 ... and other less hyped yet vitally important concepts to writing
1864 World Class Software
1865    </p>
1866     </abstract>
1867   </eventitem>
1868
1869   <eventitem date="2007-02-08" time="4:30 PM"
1870    room="MC 2066" title="UW Software Start-ups: What Worked and What Did Not">
1871    <short>A talk by Larry Smith</short>
1872    <abstract>
1873    <p>
1874  A discussion of software start-ups founded by UW students and what they did 
1875  that helped them grow and what failed to help.  In order to share the most 
1876  insights and guard the confidences of the individuals involved, none of the 
1877  companies will be identified.
1878    </p>
1879     </abstract>
1880   </eventitem>
1881
1882
1883   <eventitem date="2007-02-07" time="4:30 PM"
1884    room="MC 4041" title="Riding The Multi-core Revolution">
1885    <short>How a Waterloo software company is changing the way people program computers. 
1886      A talk by Stefanus Du Toit</short>
1887    <abstract>
1888    <p>
1889         For decades, mainstream parallel processing has been thought of as
1890 inevitable. Up until recent years, however, improvements in
1891 manufacturing processes and increases in clock speed have provided
1892 software with free Moore's Law-scale performance improvements on
1893 traditional single-core CPUs. As per-core CPU speed increases have
1894 slowed to a halt, processor vendors are embracing parallelism by
1895 multiplying the number of cores on CPUs, following what Graphics
1896 Processing Unit (GPU) vendors have been doing for years. The Multi-
1897 core revolution promises to provide unparalleled increases in
1898 performance, but it comes with a catch: traditional serial
1899 programming methods are not at all suited to programming these
1900 processors and methods such as multi-threading are cumbersome and
1901 rarely scale beyond a few cores. Learn how, with hundreds of cores in
1902 desktop computers on the horizon, a local software company is looking
1903 to revolutionize the way software is written to deliver on the
1904 promise multi-core holds.
1905     </p>
1906     <p>
1907         Refreshments (and possible pizza!) will be provided.
1908     </p>
1909     </abstract>
1910   </eventitem>
1911
1912 <!--  <eventitem date="2007-01-24" time="4:00 PM"
1913    room="TBA" title="TBA">
1914    <short>A talk by Reg Quinton</short>
1915    <abstract>
1916    <p>
1917         To be announced
1918     </p>
1919     </abstract>
1920   </eventitem>
1921 -->
1922   <eventitem date="2007-01-31" time="4:00 PM"
1923    room="MC 4041" title="Network Security -- Intrusion Detection">
1924    <short>A talk by Reg Quinton</short>
1925    <abstract>
1926    <p>
1927  IST monitors the campus network for vulnerabilities and scans
1928  systems for security problems.
1929  This informal presentation will look behind the scenes to show the
1930  strategies and technologies used and to show the problem magnitude. We
1931  will review the IST Security web site with an emphasis on these pages
1932  </p><p>
1933  <a href="http://ist.uwaterloo.ca/security/vulnerable/">http://ist.uwaterloo.ca/security/vulnerable/</a><br/>
1934  <a href="http://ist.uwaterloo.ca/security/security-wg/reports/20061101.html">http://ist.uwaterloo.ca/security/security-wg/reports/20061101.html</a><br/>
1935  <a href="http://ist.uwaterloo.ca/security/position/20050524/">http://ist.uwaterloo.ca/security/position/20050524/</a><br/>
1936     </p>
1937     </abstract>
1938   </eventitem>
1939 <!--
1940   <eventitem date="2007-01-31" time="4:30 PM"
1941    room="TBA" title="An Brief Introduction to Projection Graphics">
1942    <short>A talk by Christopher Evensen</short>
1943    <abstract>
1944    <p>
1945         To be announced
1946     </p>
1947     </abstract>
1948   </eventitem>
1949 -->
1950
1951 <!-- Fall 2006 -->
1952 <!-- Nothing happened :( -->
1953
1954 <!-- Spring 2006 -->
1955
1956
1957 <eventitem date="2006-07-29" title="CTRL D" time="7:00pm" room="East Side Mario">
1958  <short>Come out for the Club that Really Likes Dinner</short>
1959  <abstract>
1960  <p>
1961 Summer: the sparrows whistle through the teapot-steam breeze.  The
1962 ubiquitous construction team tears the same pavement up for the third
1963 time, hammering passers-by with dust and noise: our shirts, worn for
1964 the third time, noisome from competing heat and shame.  As Nature
1965 continues her Keynesian rotation of policy, and as society decrees yet
1966 another parting of ways, it is proper for the common victims to have
1967 an evening to themselves, looking both back and ahead, imagining new
1968 opportunities, and recognising those long since missed.  God fucking
1969 damn it.
1970 </p>
1971 <p>
1972 This term's CTRL-D end-of-term dinner is taking place tomorrow
1973 (Saturday) at 7:00 P.M. at East Side Mario's, in the plaza.  Meet in
1974 the C.S.C. fifteen minutes beforehand, so they don't take away our
1975 seats or anything nasty like that.
1976 </p>
1977 <p>
1978 A lot of people wanted to go to the Mongolian Grill, but I'm pretty
1979 sure this place has a similar price-to-tasty ratio; what's more,
1980 they'll actually grant us a reservation more than four nights a week.
1981 I've confirmed that the crazy allergenic peanuts no longer exist
1982 (sad), and they have a good vegetarian selection, which is likely
1983 coincides with their kosher and halal menus.
1984 </p>
1985 <p>
1986 Come out for the tasty and the awesome!  If you pretend it's your
1987 birthday, everyone's a loser!  Tell your friends, because I told the
1988 telephone I wanted to reserve for 10 to 12 people, and I don't wish to
1989 sully Calum T. Dalek's good name!
1990  </p>
1991  </abstract>
1992
1993 </eventitem>
1994
1995
1996 <eventitem date="2006-07-26" title="Lemmings Day" time="3:30pm" room="MC Comfy Lounge">
1997  <short>Come out for some retro Amiga-style Lemmings gaming action!</short>
1998  <abstract>
1999  <p>
2000  Does being in CS make you feel like a lemming?  Is linear algebra driving you
2001  into walls?  Do you pace back and forth, constantly, regardless of whatever's
2002  in your path?  Then you should come out to CSC Lemmings Day.  This time, we're
2003  playing the pseudo-sequel:  Oh No! More Lemmings!
2004  </p>
2005  <ul>
2006   <li>Old-skool retro gaming, Amiga-style (2 mice, 2 players!)</li>
2007   <li>Projector screen: the pixels are man-sized!</li>
2008   <li>Enjoy classic Lemmings tunes</li>
2009  </ul>
2010  </abstract>
2011
2012 </eventitem>
2013 <eventitem date="2006-07-25" title="Linux Installfest!" time="1:00pm" room ="DC Fishbowk">
2014         <short>A part of Linux Awareness Week</short>
2015         <abstract>
2016         <p>
2017         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 
2018 fine distributions of Linux for you. 
2019         </p>
2020         <p>
2021         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 
2022 the awesome!
2023         </p>
2024         <p>
2025         Install Linux on your machine-install fear in your opponents!
2026         </p>
2027 </abstract>
2028 </eventitem>
2029
2030
2031 <eventitem date="2006-07-24" title="Software development gets on the Cluetrain" time="4:30pm" room ="MC 4063">
2032         <short>or How communities of interest drive modern software development.</short>
2033         <abstract>
2034         <p>
2035                 Simon Law leads the Quality teams for Ubuntu, a free-software operating
2036                 system built on Debian GNU/Linux.  As such, he leads one of the largest
2037                 community-based testing efforts for a software product.  This does get a
2038                 bit busy sometimes.
2039         </p>
2040         <p>
2041                 In this talk, we'll be exploring how the Internet is changing how
2042                 software is developed.  Concepts like open source and technologies like
2043                 message forums are blurring the lines between producer and consumer.
2044                 And this melting pot of people is causing people to take note, and
2045                 changing the way they sling code.
2046         </p>
2047         <p>
2048                 Co-Sponsored with CS-Commons Committee
2049         </p>
2050 </abstract>
2051 </eventitem>
2052
2053   <eventitem date="2006-07-21" time="5:30 PM"
2054    room="MC1085" title="March of the Penguins">
2055    <short>The Computer Science Club will be showing March of the Penguins</short>
2056    <abstract>
2057         <p>
2058         <a href="http://wip.warnerbros.com/marchofthepenguins/">March of the Penguins</a> , an epic nature documentary, as dictated
2059 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
2060 whole Linux awareness week that forgot to tell people about].
2061         </p>
2062    </abstract>
2063   </eventitem>
2064
2065
2066   <eventitem date="2006-07-20" time="5:30 PM"
2067    room="MC4041" title="Cool Stuff to do With Python">
2068    <short>Albert O'Connor will be introducing the joys of programming in python</short>
2069    <abstract>
2070         <p>
2071         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 
2072 object-oriented programming language which is most awesome. 
2073         </p>
2074    </abstract>
2075   </eventitem>
2076
2077   <eventitem date="2006-07-20" time="4:30 PM"
2078    room="MC4041" title="Simulating multi-tasking on an embedded architecture">
2079    <short>Alex Tsay will look at the common hack used to simulate multi-processing in a real time embedded environment.</short>
2080    <abstract>
2081         <p>
2082 In an embedded environment resources are fairly limited, especially. Typically an embedded system has strict time constraints in which it must 
2083 respond to hardware driven interrupts and do some processing of its own. A full fledged OS would consume most of the available resources, hence 
2084 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 
2085 in a real time embedded environment.
2086         </p>
2087    </abstract>
2088   </eventitem>
2089
2090
2091 <eventitem date="2006-07-19" title="Semacode: Image recognition on mobile camera phones" time="4:30 PM" room ="MC1085">
2092         <short>Simon Woodside, founder of Semacode, comes to discuss image what it is like to start a business and how imaging code works</short>
2093         <abstract>
2094         <p>
2095 Could you write a good image recognizer for a 100 MHz mobile phone
2096 processor with 1 MB heap, 320x240 image, on a poorly-optimized Java
2097 stack? It needs to locate and read two-dimensional barcodes made up of
2098 square modules which might be no more than a few pixels in size. We
2099 had to do that in order to establish Semacode, a local start up
2100 company that makes a software barcode reader for cell phones. The
2101 applications vary from ubiquitous computing to advertising. Simon
2102 Woodside (founder) will discuss what it's like to start a business and
2103 how the imaging code works.
2104         </p>
2105 </abstract>
2106 </eventitem>
2107
2108
2109
2110
2111
2112   <eventitem date="2006-07-17" time="11:59 PM"
2113    room="MC3036" title="Midnight Madness, Alpha Edition">
2114    <short>Come out to discuss current &amp; future plans/projects for the Club</short>
2115    <abstract>
2116         <p>
2117         The Computer Science Club (CSClub) has "new" DEC Alphas which are most awesome. Come out, help take them part, put them back
2118 together, solder, and eat free food (probably pizza).
2119         </p>
2120    </abstract>
2121   </eventitem>
2122
2123
2124   <eventitem date="2006-06-21" time="4:30 PM"
2125    room="MC4042" title="CSC General Meeting">
2126    <short>Come out to discuss current &amp; future plans/projects for the Club</short>
2127    <abstract>
2128         <p>
2129         The venue will include:</p>
2130                 <p><ul>
2131                 <li><p>Computer usage agreement discussion (Holden has some changes he'd like to propose)</p></li>
2132                 <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>
2133                 <li><p>Frosh Linux cd's that could be put in frosh math faculty kits.</p></li>
2134                 <li><p>VoIP "not phone services" ideas.</p></li>
2135                 <li><p>Ideas for talks (people, topics, etc...). We requested Steve Jobs and Steve Balmer, so no idea is too crazy.</p></li>
2136                 <li><p>Ideas for books.</p></li>
2137                 <li><p>General improvements/comments for the club.</p></li>
2138                 </ul></p>
2139         <p>
2140         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.
2141         </p>
2142    </abstract>
2143   </eventitem>
2144
2145
2146 <eventitem date="2006-05-25" time="4:00 PM" room="MC 4060" title="Eighteen Years in the Software Tools Business">
2147  <short>Eighteen Years in the Software Tools Business at Microsoft, a talk by Rico Mariani, (BMath CS/EEE 1988)</short>
2148  <abstract>
2149   <p>
2150   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 
2151 evolution of software tools for microcomputers.  This talk promises to be a little bit about history and perspective (at least from 
2152 the Microsoft side of things) as well as the evolution of software engineers, different types of programmers and their needs, and what 
2153 it's like to try to make the software industry more effective at what it does, and sometimes succeed!
2154   </p>
2155 <p>
2156 A video of the talk is available for download in our <a href="media/">media</a> section.
2157 </p>
2158  </abstract>
2159 </eventitem>
2160
2161 <eventitem date="2006-05-14" time="1:00 PM" room="CSC" title="Unix 101 and 102 Recording">
2162  <short>Unix 101 and 102 recording</short>
2163  <abstract>
2164   <p>
2165   Have you heard of our famous Unix 101 and Unix 102 tutorials. We've decided to try 
2166   and put them on the web. This Sunday we will be doing a first take.
2167   At the same time, we're going to be looking at adding new material
2168   that we haven't covered in the past. </p>
2169   <p>
2170   Why should you come out? Not only will you get to hang out with a wonderful group of people,
2171   you can help impart your knowledge to the world. Don't know anything about Unix? That's cool too,
2172   we need people to make sure its easy to follow along and hopefully keep us from leaving something
2173   out by mistake. 
2174   </p>
2175   </abstract>
2176 </eventitem>
2177
2178 <eventitem date="2006-05-13" time="1:00 PM" room="CSC" title="Video 4 Linux Day">
2179  <short> We don't know enough about V4L</short>
2180  <abstract>
2181   <p>
2182   We don't know Video 4 Linux, but increasingly people are wanting to do interesting stuff with our webcam which 
2183 could benefit from a better understanding of Video 4 Linux. So, this Saturday a number of us will be trying to learn 
2184 as much as possible about Video 4 Linux and doing weird things with webcam(s).
2185   </p>
2186   </abstract>
2187 </eventitem>
2188
2189 <eventitem date="2006-05-08" time="4:30 PM" room="The Comfy Lounge" title="CSC
2190 Elections">
2191  <short>Come out and vote for the Spring 2006 executive!</short>
2192  <abstract>
2193   <p>
2194   The Computer Science Club will be holding its elections for the Spring 2006
2195   term on Monday, May 8th.  The elections will be held at 4:30 PM in the
2196   Comfy Lounge, on the 3rd floor of the MC. Please remember to come out and
2197   vote!
2198   </p>
2199   <p>
2200   We are accepting nominations for the following positions: President,
2201   Vice-President, Treasurer, and Secretary. The nomination period continues
2202   until 4:30 PM on Sunday, May 7th. If you are interested in running for
2203   a position, or would like to nominate someone else, please email
2204   cro@csclub.uwaterloo.ca before the deadline. 
2205   </p>
2206  </abstract>
2207 </eventitem>
2208
2209 <!-- Winter 2006 -->
2210
2211   <eventitem date="2006-03-06" time="4:45 PM"
2212    room="Physics 145" title="Creating Killer Applications">
2213    <short>A talk by Larry Smith</short>
2214    <abstract>
2215    <p>
2216         A discussion of how software creators can identify application opportunities
2217         that offer the promise of great social and commercial significance. Particular
2218         attention will be paid to the challenge of acquiring cross domain knowledge
2219         and setting up effective collaboration.
2220     </p>
2221     </abstract>
2222   </eventitem>
2223
2224
2225   <eventitem date="2006-02-09" time="5:30 PM" room="Bombshelter Pub" title="Pints With Profs">
2226     <short>Come out and meet your professors. Free food provided!</short>
2227     <abstract>
2228     <p>Come out and meet your professors!  This is a great opportunity to
2229     mingle with your professors before midterms or find out who you might
2230     have for future courses.  All are welcome!</p>
2231
2232     <p>Best of all, there will be <strong>free food!</strong></p>
2233
2234     <p>You can pick up invitations for your professors at the Computer Science
2235     Club office in MC 3036.</p>
2236
2237     <p>Pints with Profs will be held this term on Thursday, 9 February 2006
2238     from 5:30 to 8:00 PM in the Bombshelter.</p>
2239     </abstract>
2240   </eventitem>
2241
2242 <!-- Fall 2005 -->
2243
2244   <eventitem date="2005-11-29" time="5:30 PM"
2245    room="TBA" title="Programming Contest">
2246    <short>Come out, program, and win shiny things!</short>
2247    <abstract>
2248    <p>
2249         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. 
2250
2251    </p>
2252
2253    <p>And best of all... free food!!!</p>
2254    </abstract>
2255   </eventitem>
2256
2257
2258   <eventitem date="2005-10-17" time="5:30 PM"
2259    room="Fishbowl" title="Party with Profs!">
2260    <short>Get to know your profs and be the envy of your
2261    friends!</short>
2262    <abstract>
2263    <p>
2264      Come out and meet your professors!!  This is a great opportunity to
2265      meet professors for Undergraduate Research jobs or to find out who
2266      you might have for future courses.  One and all are welcome!
2267    </p>
2268
2269    <p>And best of all... free food!!!</p>
2270    </abstract>
2271   </eventitem>
2272
2273
2274 <eventitem date="2005-10-11" time="4:30 PM" room="MC 2037" title="UNIX 103:  Scripting Unix">
2275  <short>You Too Can Be a Unix Taskmaster</short>
2276  <abstract>
2277   <p>
2278   This is the third in a series of seminars that cover the use of the
2279   UNIX Operating System. UNIX is used in a variety of applications, both
2280   in academia and industry. We will provide you with hands-on experience
2281   with the Math Faculty's UNIX environment in this tutorial.
2282   </p><p>
2283   Topics that will be discussed include:
2284   <ul>
2285   <li>Shell scripting</li>
2286   <li>Searching through text files</li>
2287   <li>Batch editing text files</li>
2288   </ul>
2289   </p><p>
2290   If you do not have a Math computer account, don't panic; one will be lent to
2291   you for the duration of this class.
2292   </p>
2293  </abstract>
2294 </eventitem>
2295
2296
2297 <eventitem date="2005-10-06" time="4:30 PM" room="MC3D 2037" title="UNIX 102">
2298  <short>Fun with Unix</short>
2299  <abstract>
2300  <p>
2301  This is the second in a series of seminars that cover the use of the
2302  Unix Operating System. Unix is used in a variety of
2303  applications, both in academia and industry. We will provide you with hands-on
2304  experience with the Math Faculty's Unix environment in this tutorial.
2305  </p>
2306  <p>
2307  Topics that will be discussed include:
2308  <ul>
2309  <li>Interacting with Bourne and C shells</li>
2310  <li>Editing text using the vi text editor</li>
2311  <li>Editing text using the Emacs display editor</li>
2312  <li>Multi-tasking and the screen multiplexer</li>
2313  </ul>
2314  </p>
2315  <p>
2316  If you do not have a Math computer account, don't panic; one will be lent to
2317  you for the duration of this class.
2318  </p>
2319  </abstract>
2320 </eventitem>
2321
2322 <eventitem date="2005-10-04" time="4:30 PM" room="MC 2037" title="UNIX 101">
2323  <short>First UNIX tutorial</short>
2324  <abstract>
2325   <p>
2326   The CSC UNIX tutorials are intended to help first year CS and other
2327   interested learn UNIX and the CS UNIX environment.
2328   </p>
2329   <p>
2330   This is the first in a series of two or three tutorials. It will cover basic shell
2331   use, and simple text editors.
2332   </p>
2333  </abstract>
2334 </eventitem>
2335
2336
2337 <!-- Summer 2005 -->
2338 <eventitem date="2005-06-02" time="3:30 PM" room="DC 1302" title="Programming and Verifying the Interactive Web">
2339  <short>Shriram Krishnamurthi will be talking about continuations in Web Programming</short>
2340 <abstract>
2341 <p>
2342 Server-side Web applications have grown increasingly common, sometimes
2343 even replacing brick and mortar as the principal interface of
2344 corporations.  Correspondingly, Web browsers grow ever more powerful,
2345 empowering users to attach bookmarks, switch between pages, clone
2346 windows, and so forth.  As a result, Web interactions are not
2347 straight-line dialogs but complex nets of interaction steps.
2348 </p>
2349 <p>
2350 In practice, programmers are unaware of or are unable to handle these
2351 nets of interaction, making the Web interfaces of even major
2352 organizations buggy and thus unreliable.  Even when programmers do
2353 address these constraints, the resulting programs have a seemingly
2354 mangled structure, making them difficult to develop and hard to
2355 maintain.
2356 </p>
2357 <p>
2358 In this talk, I will describe these interactions and then show how
2359 programming language ideas can shed light on the resulting problems
2360 and present solutions at various levels.  I will also describe some
2361 challenges these programs pose to computer-aided verification, and
2362 present solutions to these problems.
2363 </p>
2364 </abstract>
2365 </eventitem>
2366 <eventitem date="2005-06-07" time="4:00 PM" room="MC 4042" title="UW's CS curriculum: past, present, and future">
2367 <short>Come out to here Prabhakar Ragde talk about our UW's CS curriculum</short>
2368 <abstract>
2369 <p>
2370 I'll survey the evolution of our computer science curriculum over the
2371 past thirty-five years to try to convey the reasons (not always entirely
2372 rational) behind our current mix of courses and their division into core
2373 and optional. After some remarks about constraints and opportunities in
2374 the near future, I'll open the floor to discussion, and hope to hear
2375 some candid comments about the state of CS at UW and how it might be
2376 improved.
2377 </p>
2378 <p>
2379 About the speaker:
2380 </p>
2381 <p>
2382 Prabhakar Ragde is a Professor in the School of Computer Science at UW.
2383 He was Associate Chair for Curricula during the period that saw the
2384 creation of the Bioinformatics and Software Engineering programs, the
2385 creation of the BCS degree, and the strengthening of the BMath/CS degree.
2386 </p>
2387 </abstract>
2388 </eventitem>
2389
2390 <!-- Winter 2005 -->
2391 <eventitem date="2005-03-15" time="4:30 PM" room="MC 4060" title="Oh No! More Lemmings Day!">
2392  <short>Come out for some retro Amiga-style Lemmings gaming action!</short>
2393  <abstract>
2394  <p>
2395  Does being in CS make you feel like a lemming?  Is linear algebra driving you
2396  into walls?  Do you pace back and forth, constantly, regardless of whatever's
2397  in your path?  Then you should come out to CSC Lemmings Day.  This time, we're
2398  playing the pseudo-sequel:  Oh No! More Lemmings!
2399  </p>
2400  <ul>
2401   <li>Old-skool retro gaming, Amiga-style (2 mice, 2 players!)</li>
2402   <li>Projector screen: the pixels are man-sized!</li>
2403   <li>Live-Action Lemmings (the rules are better this time)</li>
2404   <li>Lemmings look-alike contest</li>
2405   <li>Enjoy classic Lemmings tunes</li>
2406  </ul>
2407  </abstract>
2408 </eventitem>
2409
2410 <eventitem date="2005-02-01" time="4:30 PM" room="MC 2037" title="UNIX 102">
2411  <short>Fun with Unix</short>
2412  <abstract>
2413  <p>
2414  This is the second in a series of seminars that cover the use of the
2415  Unix Operating System. Unix is used in a variety of
2416  applications, both in academia and industry. We will provide you with hands-on
2417  experience with the Math Faculty's Unix environment in this tutorial.
2418  </p>
2419  <p>
2420  Topics that will be discussed include:
2421  <ul>
2422  <li>Interacting with Bourne and C shells</li>
2423  <li>Editing text using the vi text editor</li>
2424  <li>Editing text using the Emacs display editor</li>
2425  <li>Multi-tasking and the screen multiplexer</li>
2426  </ul>
2427  </p>
2428  <p>
2429  If you do not have a Math computer account, don't panic; one will be lent to
2430  you for the duration of this class.
2431  </p>
2432  </abstract>
2433 </eventitem>
2434
2435
2436 <eventitem date="2005-01-25" time="4:30 PM" room="MC 2037" title="UNIX 101">
2437  <short>First UNIX tutorial</short>
2438  <abstract>
2439   <p>
2440   The CSC UNIX tutorials are intended to help first year CS and other
2441   interested learn UNIX and the CS UNIX environment.
2442   </p>
2443   <p>
2444   This is the first in a series of two or three tutorials. It will cover basic shell
2445   use, and simple text editors.
2446   </p>
2447  </abstract>
2448 </eventitem>
2449
2450
2451 <eventitem date="2005-01-13" time="4:30 PM" room="The Comfy Lounge" title="CSC
2452 Elections">
2453  <short>Come out and vote for the Winter 2005 executive!</short>
2454  <abstract>
2455   <p>
2456   The Computer Science Club will be holding its elections for the Winter 2005
2457   term on Thursday, January 13.  The elections will be held at 4:30 PM in the
2458   Comfy Lounge, on the 3rd floor of the MC. Please remember to come out and
2459   vote!
2460   </p>
2461   <p>
2462   We are accepting nominations for the following positions: President,
2463   Vice-President, Treasurer, and Secretary. The nomination period continues
2464   until 4:30 PM on Wednesday, January 12. If you are interested in running for
2465   a position, or would like to nominate someone else, please email
2466   cro@csclub.uwaterloo.ca before the deadline. 
2467   </p>
2468  </abstract>
2469 </eventitem>
2470
2471
2472 <!-- Fall 2004 -->
2473
2474 <eventitem date="2004-12-08" time="4:30 PM" room="Mongolian Grill"
2475 title="CTRL-D">
2476  <short> This semesters CTRL-D (or the club that really likes
2477 dinner) is going to be at Mongolian grill. Be there or be square</short>
2478  <abstract>
2479         <p>
2480 Come to the end of term CTRL-D (club that really likes dinner) meeting.
2481 Remember : food is good 
2482 </p>
2483  </abstract>
2484 </eventitem>
2485
2486
2487 <eventitem date="2004-12-01" time="2:30 PM" room="MC 4058" title="Knitting needles, hairpins and other tangled objects">
2488  <short>In this talk, I'll study linkages (objects built from sticks that are connected with flexible joints), and explain some 
2489 interesting examples that can or cannot be straightened out</short>
2490  <abstract>
2491         <p>
2492  In this talk, I'll study linkages (objects built from sticks that are connected with flexible joints), and explain some 
2493 interesting examples that can or cannot be straightened out</p>
2494
2495  </abstract>
2496 </eventitem>
2497
2498
2499 <eventitem date="2004-11-24" time="4:30 PM" room="MC 2066" title="Eclipse">
2500  <short>How I Stopped Worrying and Learned to Love the IDE</short>
2501  <abstract>
2502   <p>
2503         How I stopped worrying and Learned to Love the IDE
2504   </p>
2505   <p>
2506         Audience: anyone who as ever used the Java programming language to do anything. Especially if you don't like 
2507 the IDEs you've seen so far or still use (g)Vi(m) or (X)Emacs. 
2508   </p>
2509
2510   <p>
2511         I'll go through some of the coolest features of the best IDE (which stands for "IDEs Don't Eat" or 
2512 "Integrated Development Environment") I've seen. For the first year and seasoned almost-grad alike!
2513   </p>
2514
2515  </abstract>
2516 </eventitem>
2517
2518
2519 <eventitem date="2004-11-18" time="5:00 PM" room="MC 2066" title="GracefulTavi">
2520  <short>Wiki software in PHP+MySQL</short>
2521  <abstract>
2522   <p>
2523    GracefulTavi is an open source wiki programmed by Net Integration
2524    Technologies Inc. It is used internally by more than 25 people, and is
2525    the primary internal wiki for NITI's R&amp;D and QA.
2526   </p>
2527   <p>
2528    I'll start with a very brief introduction to wikis in general, then
2529    show off our special features: super-condensed formatting syntax,
2530    hierarchy management, version control, highlighted diffs, SchedUlator,
2531    the Table of Contents generator. As part of this, we'll explain the
2532    simple plugin architecture and show people how to write a basic wiki
2533    plugin.
2534   </p>
2535
2536   <p>
2537    As well, I will show some of the "waterloo specific" macros that have
2538    been coded, and explain future plans for GracefulTavi.
2539   </p>
2540
2541   <p>
2542    If time permits, I will explain how gracefulTavi can be easily used
2543    for a personal calendar and notepad system on your laptop.
2544   </p>
2545  </abstract>
2546 </eventitem>
2547
2548
2549
2550 <eventitem date="2004-11-12" time="2:30 PM" room="MC 4063" title="Lemmings Day!">
2551  <short>Everyone else is doing it!</short>
2552  <abstract>
2553   <p>
2554         Does being in CS make you feel like a lemming? Is linear algebra driving you into walls? Do you pace back and forth , constantly ,
2555 regardless of whatever's in your path? Then you should come out to CSC Lemmings Day!
2556   </p><p>
2557   <ul>
2558   <li>Play some old-skool Lemmings, Amiga-style</li>
2559   <li>Live-action lemmings</li>
2560   <li>Lemmings look-alike contest</li>
2561   <li>Enjoy classic Lemmings tunes</li>
2562   </ul>
2563   </p><p>
2564         Everyone else is doing it!
2565   </p>
2566  </abstract>
2567 </eventitem>
2568
2569
2570 <eventitem date="2004-10-23" time="11:00 PM" room="MC 2037" title="CSC Programming Contest">
2571         <short>CSC Programming Contest</short>
2572         <abstract>
2573         <p>
2574         The Computer Science Club will be hosting a programming competition.
2575         You have the entire afternoon to design and implement an AI for a simple
2576         game. The competition will run until 5pm.
2577         </p>
2578         </abstract>
2579 </eventitem>
2580
2581
2582 <eventitem date="2004-10-18" time="4:30 PM" room="MC 2037" title="UNIX 103:  Scripting Unix">
2583  <short>You Too Can Be a Unix Taskmaster</short>
2584  <abstract>
2585   <p>
2586   This is the third in a series of seminars that cover the use of the
2587   UNIX Operating System. UNIX is used in a variety of applications, both
2588   in academia and industry. We will provide you with hands-on experience
2589   with the Math Faculty's UNIX environment in this tutorial.
2590   </p><p>
2591   Topics that will be discussed include:
2592   <ul>
2593   <li>Shell scripting</li>
2594   <li>Searching through text files</li>
2595   <li>Batch editing text files</li>
2596   </ul>
2597   </p><p>
2598   If you do not have a Math computer account, don't panic; one will be lent to
2599   you for the duration of this class.
2600   </p>
2601  </abstract>
2602 </eventitem>
2603
2604 <eventitem date="2004-10-04" time="4:30 PM" room="MC 2037" title="UNIX 102">
2605  <short>Fun with Unix</short>
2606  <abstract>
2607  <p>
2608  This is the second in a series of seminars that cover the use of the
2609  Unix Operating System. Unix is used in a variety of
2610  applications, both in academia and industry. We will provide you with hands-on
2611  experience with the Math Faculty's Unix environment in this tutorial.
2612  </p>
2613  <p>
2614  Topics that will be discussed include:
2615  <ul>
2616  <li>Interacting with Bourne and C shells</li>
2617  <li>Editing text using the vi text editor</li>
2618  <li>Editing text using the Emacs display editor</li>
2619  <li>Multi-tasking and the screen multiplexer</li>
2620  </ul>
2621  </p>
2622  <p>
2623  If you do not have a Math computer account, don't panic; one will be lent to
2624  you for the duration of this class.
2625  </p>
2626  </abstract>
2627 </eventitem>
2628
2629 <!-- Spring 2004 -->
2630
2631 <eventitem date="2004-09-27" time="4:30 PM" room="MC 2037" title="UNIX 101">
2632  <short>First UNIX tutorial</short>
2633  <abstract>
2634   <p>
2635   The CSC UNIX tutorials are intended to help first year CS and other
2636   interested learn UNIX and the CS UNIX environment.
2637   </p>
2638   <p>
2639   This is the first in a series of three tutorials. It will cover basic shell
2640   use, and simple text editors.
2641   </p>
2642  </abstract>
2643 </eventitem>
2644 <eventitem date="2004-09-17" time="4:00 PM" room="The Comfy Lounge" title="CSC
2645 Elections">
2646  <short>Come out and vote for the Fall 2004 executive!</short>
2647  <abstract>
2648   <p>
2649   The Computer Science Club will be holding its elections for the Fall 2004
2650   term on Friday, September 17. The elections will be held at 4:00 PM in the
2651   Comfy Lounge, on the 3rd floor of the MC. Please remember to come out and
2652   vote!
2653   </p>
2654   <p>
2655   We are accepting nominations for the following positions: President,
2656   Vice-President, Treasurer, and Secretary. The nomination period continues
2657   until 4:30 PM on Thursday, September 16. If you are interested in running
2658   for a position, or would like to nominate someone else, please email
2659   cro@csclub.uwaterloo.ca before the deadline. 
2660   </p>
2661  </abstract>
2662 </eventitem>
2663
2664 <eventitem date="2004-07-27" time="4:30 PM" room="MC 2065"
2665 title="Game Complexity Theorists Ponder, by Jonathan Buss">
2666 <short>Attention AI buffs: Game Complexity presentation</short>
2667 <abstract>
2668 <p>
2669 Why are some games hard to play well?  The study of computational
2670 complexity gives one answer: the games encode long computations.</p>
2671
2672 <p>Any computation can be interpreted as an abstract game.  Playing the
2673 game perfectly requires performing the computation.  Remarkably, some
2674 natural games can encode these abstract games and thus simulate
2675 general computations.  The more complex the game, the more complex the
2676 computations it can encode; games that can encode intractable problems
2677 are themselves intractable.</p>
2678
2679 <p>
2680 I will describe how games can encode computations, and discuss some
2681 examples of both provably hard games (checkers, chess, go, etc.) and
2682 games that are believed to be hard (hex, jigsaw puzzles, etc.).
2683 </p>
2684 </abstract>
2685 </eventitem>  
2686
2687 <eventitem date="2004-07-17" time="11:30 AM" room="RCH 308"
2688    title="Case Modding Workshop!">
2689    <short>Come and learn how to make your computer 1337!</short>
2690    <abstract>
2691     <p>
2692 Are you bored of beige?<br />
2693 Tired of an overheating computer?<br />
2694 Is your computer's noise level on par with a jet engine?
2695     </p>
2696     <p>
2697 Got a nifty modded case?<br />
2698 Want one?
2699     </p>
2700     <p>
2701 The Computer Science Club will be holding a Case Modding Workshop
2702 to help answer these questions.
2703     </p>
2704     <p>
2705 There will be demonstrations on how to make a case window, how
2706 to paint your case, managing cables and keeping your computer
2707 quiet and cool.
2708     </p>
2709     <p>
2710 The event is FREE and there will be FREE PIZZA.  All are welcome!
2711     </p>
2712     <p>
2713 To help you on your way to getting a wicked computer case, we have a limited
2714 number of "Case Modding Starters Kits" available.  They come with an LED fan,
2715 a fan grill, a sheet of Plexan, thumbscrews, wire ties, and more!  They're
2716 only $10 and will be on sale at the event.  Here's a <a
2717 href="redkit.jpg">picture</a>.
2718     </p>
2719     <p>
2720 If you already have a modded case, we encourage you to bring it out
2721 and show it off!  There will be a prize for the best case!!
2722     </p>
2723     <p>
2724 We hope to see you there!
2725     </p>
2726     <p>
2727 This event is sponsored by Bigfoot Computers.
2728     </p>
2729    </abstract>
2730   </eventitem>
2731
2732   <eventitem date="2004-06-17" time="4:00 PM" room="MC 2066"
2733    title="``Optical Snow'': Motion parallax and heading computation in densely cluttered scenes. -or- Why Computer Vision needs the Fourier Transform!">
2734    <short>A talk by Richard Mann; School of Computer Science</short>
2735    <abstract>
2736     <p>
2737 When an observer moves through a 3D scene, nearby surfaces move faster in the
2738 image than do distant surfaces.  This effect, called motion parallax, provides
2739 an observer with information both about their own motion relative the scene,
2740 and about the spatial layout and depth of surfaces in the scene.
2741     </p>
2742     <p>
2743 Classical methods for measuring image motion by computer have concentrated on
2744 the cases of optical flow in which the motion field is continuous, or layered
2745 motion in which the motion field is piecewise continuous.  Here we introduce a
2746 third natural category which we call ``optical snow''.  Optical snow arises in
2747 many natural situations such as camera motion in a highly cluttered 3-D scene,
2748 or a passive observer watching a snowfall.  Optical snow yields dense motion
2749 parallax with depth discontinuities occurring near all image points.  As such,
2750 constraints on smoothness or even smoothness in layers do not apply.
2751     </p>
2752     <p>
2753 We present a Fourier analysis of optical snow.  In particular we show that,
2754 while such scenes appear complex in the time domain, there is a simple
2755 structure in the frequency domain, and this may be used to determine the
2756 direction of motion and the range of depths of objects in the scenes.  Finally
2757 we show how Fourier analysis of two or more image regions may be combined to
2758 estimate heading direction.
2759     </p>
2760     <p>
2761 This talk will present current research at the undergraduate level.  All are
2762 welcome to attend.
2763     </p>
2764    </abstract>
2765   </eventitem>
2766   
2767
2768   <eventitem date="2004-05-26" time="5:30 PM"
2769    room="DC 1350" title="Computing's Next Great Empires: The True Future of Software">
2770    <short>A talk by Larry Smith</short>
2771    <abstract>
2772    <p>
2773      Larry will challenge conventional assumptions about the directions of           
2774      computing and software. The role of AI, expert systems, communications          
2775      software and business applications will be presented both from a                
2776      functional and commercial point of view.  The great gaps in the                 
2777      marketplace will be highlighted, together with an indication of how             
2778      these vacant fields will become home to new empires.                            
2779     </p>
2780     </abstract>
2781   </eventitem>
2782   <eventitem date="2004-05-12" time="4:30 PM"
2783    room="The Comfy Lounge" title="CSC Elections">
2784    <short>Come out and vote for the Spring 2004 executive!</short>
2785    <abstract>
2786    <p>
2787      The Computer Science Club will be holding its elections for the Spring
2788      2004 term on Wednesday, May 12.  The elections will be held at 4:30 PM in
2789      the Comfy Lounge, on the 3rd floor of the MC.  Please remember to come out
2790      and vote!
2791    </p>
2792    <p>
2793      We are accepting nominations for the following positions: President,
2794      Vice-President, Treasurer, and Secretary.  The nomination period continues
2795      until 4:30 PM on Tuesday, May 11.  If you are interested in running
2796      for a position, or would like to nominate someone else, please email
2797      cro@csclub.uwaterloo.ca before the deadline.
2798    </p>
2799    </abstract>
2800   </eventitem>
2801
2802 <!-- Winter 2004 -->
2803
2804   <eventitem date="2004-03-29" time="6:00 PM"
2805    room="MC 4058" title="LaTeXing your work report">
2806    <short>A talk by Simon Law</short>
2807    <abstract>
2808    <p>
2809      The work report is a familiar chore for any co-op student. Not only is
2810      there a report to write, but to add insult to injury, your report is
2811      returned if you do not follow your departmental guidelines.
2812    </p>
2813
2814    <p>
2815      Fear no more! In this talk, you will learn how to use LaTeX and a
2816      specially developed class to automatically format your work reports.
2817      This talk is especially useful to Mathematics, Computer Science,
2818      Electrical &amp; Computer Engineering, and Software Engineeering co-op
2819      students about to go on work term.
2820    </p>
2821    </abstract>
2822   </eventitem>
2823
2824   <eventitem date="2004-03-30" time="5:30 PM"
2825    room="The Grad House" title="Pints with Profs!">
2826    <short>Get to know your profs and be the envy of your
2827    friends!</short>
2828    <abstract>
2829    <p>
2830      Come out and meet your professors!!  This is a great opportunity to
2831      meet professors for Undergraduate Research jobs or to find out who
2832      you might have for future courses.  One and all are welcome!
2833    </p>
2834
2835    <p>And best of all... free food!!!</p>
2836    </abstract>
2837   </eventitem>
2838
2839   <eventitem date="2004-03-23" time="6:00 PM"
2840    room="MC4058" title="Extending LaTeX with packages">
2841    <short>A talk by Simon Law</short>
2842    <abstract>
2843    <p>
2844      LaTeX is a document processing system.  What this means is you describe
2845      the structure of your document, and LaTeX typesets it appealingly.
2846      However, LaTeX was developed in the late-80s and is now showing its age.
2847    </p>
2848
2849    <p>
2850      How does it compete against modern systems?  By being easily extensible,
2851      of course.  This talk will describe the fundamentals of typesetting in
2852      LaTeX, and will then show you how to extend it with freely available
2853      packages.  You will learn how to teach yourself LaTeX and how to find
2854      extensions that do what you want.
2855    </p>
2856
2857    <p>
2858      As well, there will be a short introduction on creating your own
2859      packages, for your own personal use.
2860    </p>
2861    </abstract>
2862   </eventitem>
2863
2864   <eventitem date="2004-03-16" time="6:00 PM"
2865    room="MC4058" title="Distributed programming for CS and Engineering
2866    students">
2867    <short>A talk by Simon Law</short>
2868    <abstract>
2869    <p>
2870      If you've ever worked with other group members, you know how difficult
2871      it is to code simultaneously.  You might be working on one part of your
2872      assignment, and you need to send your source code to everyone else.  Or
2873      you might be fixing a bug in someone else's part, and need to merge in
2874      the change.  What a mess!
2875    </p>
2876
2877    <p>
2878      This talk will explain some Best Practices for developing code in a
2879      distributed fashion.  Whether you're working side-by-side in the lab, or
2880      developing from home, these methods can apply to your team.  You will
2881      learn how to apply these techniques in the Unix environment using GNU
2882      Make, CVS, GNU diff and patch.
2883    </p>
2884    </abstract>
2885   </eventitem>
2886
2887   <eventitem date="2004-03-15" time="5:30 PM"
2888    room="MC4040" title="SPARC Architecture">
2889    <short>A talk by James Morrison</short>
2890    <abstract>
2891    <p>
2892      Making a compiler?  Bored?  Think CISC sucks and RISC rules?
2893    </p>
2894
2895    <p>
2896      This talk will run through the SPARC v8, IEEE-P1754, architecture.
2897      Including all the fun that can be had with register windows and the
2898      SPARC instruction set including the basic instructions, floating
2899      point instructions, and vector instructions.
2900    </p>
2901    </abstract>
2902   </eventitem>
2903
2904   <eventitem date="2004-03-09" time="6:00 PM"
2905    room="MC4062" title="Managing your home directory using CVS">
2906    <short>A talk by Simon Law</short>
2907    <abstract>
2908    <p>
2909      If you have used Unix for a while, you know that you've created
2910      configuration files, or dotfiles.  Each program seems to want its own
2911      particular settings, and you want to customize your environment.  In a
2912      power-user's directory, you could have hundreds of these files.
2913    </p>
2914
2915    <p>
2916      Isn't it annoying to migrate your configuration if you login to another
2917      machine?  What if you build a new computer?  Or perhaps you made a
2918      mistake to one of your configuration files, and want to undo it?
2919    </p>
2920
2921    <p>
2922      In this talk, I will show you how to manage your home directory using
2923      CVS, the Concurrent Versions System.  You can manage your files, revert
2924      to old versions in the past, and even send them over the network to
2925      another machine.  I'll also discuss how to keep your configuration files
2926      portable, so they'll work even on different Unices, with different
2927      software installed.
2928    </p>
2929    </abstract>
2930   </eventitem>
2931
2932   <eventitem date="2004-03-02" time="6:00 PM"
2933    room="MC4042" title="Graphing webs-of-trust">
2934    <short>A talk by Simon Law</short>
2935    <abstract>
2936    <p>
2937      In today's world, people have hundreds of connexions.  And you can
2938      express these connexions with a graph.  For instance, you may wish to
2939      represent the network of your friends.
2940    </p>
2941
2942    <p>
2943      Originally, webs-of-trust were directed acyclic graphs of people who had
2944      identified each other.  This way, if there was a path between you and
2945      the person who want to identify, then you could assume that each person
2946      along that path had verified the next person's identity.
2947    </p>
2948
2949    <p>
2950      I will show you how to generate your own web-of-trust graph using Free
2951      Software.  Of course, you can also use this knowledge to graph anything
2952      you like.
2953    </p>
2954    </abstract>
2955   </eventitem>
2956
2957   <eventitem date="2004-02-18" time="7:00 PM"
2958    room="DC2305" title="KW Perl Mongers">
2959    <short>Perl Modules: A look under the hood</short>
2960    <abstract>
2961
2962    <p>In Perl, a module is the basic unit of code-reuse.  The talk will be
2963    mostly a look into GD::Text::Arc, a module written to draw TrueType text
2964    around the edge of a circle.  The talk will consider:</p>
2965
2966    <ul>
2967    <li>using and writing object-oriented perl code</li>
2968    <li>the Virtue of Laziness: or, reusing other peoples' code.</li>
2969    <li>writing tests while coding</li>
2970    <li>beer coasters</li>
2971    </ul>
2972
2973    </abstract>
2974   </eventitem>
2975
2976   <eventitem date="2004-02-05" time="3:30 PM"
2977    room="MC4041" title="Constitutional Change">
2978    <short>Vote to change the CSC Constitution</short>
2979    <abstract>
2980
2981    <p>During the General Meeting on 19 January 2004, a proposed constitution
2982    change was passed around.  This change is in response to a change in the
2983    MathSoc Clubs Policy (Policy 4, Section 3, Sub-section f).</p>
2984
2985    <p>This general meeting is called to vote on this proposed change.  We must
2986    have quorum of 15 Full Members vote on this change.  The following text was
2987    presented at the CSC Winter 2004 Elections.</p>
2988
2989 <pre>We propose to make a Constitutional change on this day, 19 January 2004.
2990 The proposed change is to section 3.1 of the constitution which
2991 currently reads:
2992
2993     In compliance with MathSoc regulations and in recognition of the
2994     club being primarily targeted at undergraduate students, full
2995     membership is open to all undergraduate students in the Faculty of
2996     Mathematics and restricted to the same.
2997
2998 Since MathSoc has changed its requirements for club membership, we
2999 propose that it be changed to:
3000
3001     In compliance with MathSoc regulations and in recognition of the
3002     club being primarily targeted at undergraduate students, full
3003     membership is open to all Social Members of the Mathematics Society
3004     and restricted to the same.</pre>
3005    </abstract>
3006   </eventitem>
3007
3008   <eventitem date="2004-01-12" time="3:00 PM"
3009    room="DC1301" title="InstallFest">
3010    <short>See <a href="http://uw-dig.uwaterloo.ca/installfest/">http://uw-dig.uwaterloo.ca/installfest/</a></short>
3011    <abstract>
3012
3013    <p>An Installfest is an opportunity to install software on your computer.
3014    People come with computers. Other people come with experience. The people
3015    get together and (when all goes well) everybody leaves satisfied.</p>
3016
3017    <p>You are invited to our first installfest of the year. Come to get some
3018    software or to learn more about Open Source Software and why it is relevant
3019    to your life. The event is free, but you may want to bring blank CDs and/or
3020    money to purchase some open source action for your computer at home.</p>
3021
3022    <p>See the <a href="http://uw-dig.uwaterloo.ca/installfest/">UW-DIG
3023    website</a> for more details.</p>
3024
3025    </abstract>
3026   </eventitem>
3027
3028 <!-- Fall 2003 -->
3029
3030   <eventitem date="2003-12-01" time="7:00 PM"
3031    room="RCH 101" title="Jon 'maddog' Hall: Free and Open Source: Its uses in Business and Education">
3032    <short> Free and Open Source software has been around for a long
3033    time, even longer then shrink-wrapped code.</short>
3034    <abstract>
3035  <p>Free and Open Source software has been around for a long time, even   
3036 longer then shrink-wrapped code.  It has a long and noble history in the annals
3037 of education.  Even more than ever, due to the drop of hardware prices and the
3038 increase of worldwide communications, Free and Open Source can open new   
3039 avenues of teaching and doing research, not only in computer science, but in
3040 other university fields as well.</p>
3041  <p>Learn how Linux as an operating system can
3042 run on anything from a PDA to a supercomputer, and how Linux is reducing the
3043 cost of computing dramatically as the fastest growing operating system in the
3044 world.  Learn how other Free and Open Source projects, such as office suites,
3045 audio and video editing and playing software, relational databases, etc. are
3046 created and are freely available.</p>
3047
3048 <p><a href="http://www.csclub.uwaterloo.ca/~cpbell/">Map and directions</a></p>
3049  <h3>Speaker's Biography</h3>
3050  <p>Jon "maddog" Hall is the Executive Director of <a href="http://www.li.org/">Linux International</a>,
3051 a non-profit association of computer vendors who wish to support and promote
3052 the Linux Operating System.  During his career which spans over thirty years,
3053 Mr. Hall has been a programmer, systems designer, systems administrator,
3054 product manager, technical marketing manager and educator.  He has
3055 worked for such companies as Western Electric Corporation, Aetna Life and
3056 Casualty, Bell Laboratories, Digital Equipment Corporation, VA Linux Systems,
3057 and is currently funded by SGI.</p>
3058
3059 <p>He has taught at Hartford State Technical College, Merrimack College and
3060 Daniel Webster College.  He still likes talking to students over pizza and beer
3061 (the pizza can be optional).</p>
3062
3063 <p>Mr. Hall is the author of numerous magazine and newspaper articles, many
3064 presentations and one book, "Linux for Dummies".</p>
3065
3066 <p>Mr. Hall serves on the boards of several companies, and several non-profit
3067 organizations, including the USENIX Association.</p>
3068
3069 <p>Mr. Hall has traveled the world speaking on the benefits of Open Source
3070 Software, and received his BS in Commerce and Engineering from Drexel
3071 University, and his MSCS from RPI in Troy, New York.</p>
3072
3073 <p>In his spare time maddog is working on his retirement project:</p>
3074
3075 <center>maddog's monastery for microcomputing and microbrewing</center>
3076
3077    </abstract>
3078   </eventitem>
3079
3080   <eventitem date="2003-11-05" time="4:30 PM - 8:30 PM"
3081    room="Grad House Pub (Green Room)" title="CS Pints With Profs">
3082    <short>Come have a pint with your favourite CS profs!</short>
3083    <abstract>
3084    <p>Come meet CS profs in a relaxed atmosphere this Wednesday at
3085    the Grad House (by South Campus Hall). This is your chance to meet those CS profs
3086    you enjoyed in lectures in person, have a chat with them
3087    and find out what they're doing outside the lecture halls.</p>
3088
3089    <p>We'll be providing free food, including hamburgers and nachos,
3090    and the Grad House offers a great selection of drinks.</p>
3091
3092    <p>If you'd like to invite a particular prof, stop by on the third
3093    floor of the MC (outside of the Comfy) to pick up an invitation.</p>
3094
3095    <p>Persons of all ages are welcome!</p>
3096    </abstract>
3097   </eventitem>
3098
3099
3100   <eventitem date="2003-10-21" time="4:30 PM - 5:30 PM" room="MC2065"
3101    title=".NET &amp; Linux: When Worlds Collide">
3102   <short>A talk by James Perry</short>
3103   <abstract>
3104
3105   <p>.NET is Microsoft's new development platform, including amongst
3106   other things a language called C# and a class library for various
3107   operating system services. .NET aims to be portable, although it is
3108   currently mostly only used on Windows systems.</p>
3109
3110   <p>With the full backing of Microsoft, it seems unlikely that .NET
3111   will disappear any time soon. There are several efforts underway to
3112   bring .NET to the GNU/Linux platform. Hosted by the Computer Science
3113   Club, this talk will discuss a number of the issues surrounding .NET
3114   and Linux.</p>
3115
3116   </abstract>
3117   </eventitem>
3118
3119   <eventitem date="2003-10-22" time="4:30 PM - 5:30 PM" room="MC4061"
3120    title="Real-Time Graphics Compilers">
3121   <short>Sh is a GPU metaprogramming language developed at the UW
3122   Computer Graphics Lab</short>
3123   <abstract>
3124
3125   <p>Sh is a GPU metaprogramming language developed at the University of
3126   Waterloo Computer Graphics Lab. It allows graphics programmers to
3127   write programs which run directly on the GPU (Graphics Processing
3128   Unit) using familiar C++ syntax. Furthermore, it allows
3129   metaprogramming of such programs, that is, writing programs which
3130   generate other programs, in an easy and natural manner.</p>
3131
3132   <p>This talk will give a brief overview of how Sh works, the design of
3133   its intermediate representation and the (still somewhat simplistic)
3134   optimizer that the current reference implementation has and problems
3135   with applying traditional compiler optimizations.</p>
3136
3137   <p>Stefanus Du Toit is an undergraduate student at the University of
3138   Waterloo.  He is also a Research Assistant for Michael McCool from the
3139   University of Waterloo Graphics Lab. Over the Summer of 2003 Stefanus
3140   reimplemented the Sh reference implementation and designed and
3141   implemented the current Sh optimizer.</p>
3142   </abstract>
3143   </eventitem>
3144
3145   <eventitem date="2003-10-17" time="3:00 PM" room="MC3001 (Comfy)"
3146    title="Poster Team Meeting">
3147   <short>More free pizza from the Poster Team</short>
3148   <abstract>
3149   <p>Are you interested in getting involved in the Computer Science
3150   Club?</p>
3151
3152   <p>Come on out to the second meeting of our Poster Team, a bunch of
3153   students helping out with promotion for our events. The agenda for
3154   this meeting will include painting posters, designing event
3155   invitations, and organizing poster runs. Once again, we will be
3156   serving free pizza!</p>
3157
3158   <p>See you there!</p>
3159   </abstract>
3160   </eventitem>
3161
3162   <eventitem date="2003-10-16" time="4:00 PM - 5:30 PM" room="MC2037"
3163    title="UNIX 103: Development Tools">
3164   <short>GCC, GDB, Make</short>
3165   <abstract>
3166   <p>This tutorial will provide you with a practical introduction to GNU 
3167   development tools on Unix such as the gcc compiler, the gdb debugger
3168   and the GNU make build tool.</p>
3169
3170   <p>This talk is geared primarily at those mostly unfamiliar with these
3171   tools.  Amongst other things we will introduce:</p>
3172
3173   <ul>
3174   <li>gcc options, version differences, and peculiarities</li>
3175   <li>using gdb to debug segfaults, set breakpoints and find out what's
3176     wrong</li>
3177   <li>tiny Makefiles that will compile all of your 2nd and 3rd year CS
3178     projects.</li>
3179   </ul>
3180
3181   <p>If you're in second year CS and unfamiliar with UNIX development it
3182   is highly recommended you go to this talk. All are welcome, including
3183   non-math students.</p>
3184
3185   <p>Arrive early!</p>
3186   </abstract>
3187   </eventitem>
3188
3189   <eventitem date="2003-10-02" time="4:00 PM - 5:30 PM" room="MC2037"
3190    title="UNIX 101: Text Editors">
3191   <short>vi vs. emacs: The Ultimate Showdown</short>
3192   <abstract>
3193 <p>
3194 Have you ever wondered how those cryptic UNIX text editors work? Have you
3195 ever woken up at night with a cold sweat wondering "Is it  CTRL-A, or CTRL-X
3196 CTRL-A?" Do you just hate pico with a passion?</p>
3197
3198 <p>Then come to this tutorial and learn how to use vi and emacs!</p>
3199
3200 <p>Basic UNIX commands will also be covered. This tutorial will be especially
3201 useful for first and second year students.</p>
3202
3203   </abstract>
3204   </eventitem>
3205
3206   <eventitem date="2003-10-06" time="4:00 PM" room="MC3001 (Comfy)"
3207    title="Poster Team Meeting">
3208   <short>Join the Poster Team and get Free Pizza!</short>
3209   <abstract>
3210     <ul>
3211     <li>Do you like computer science?</li>
3212     <li>Do you like posters?</li>
3213     <li>Do you like free pizza?</li>
3214     </ul>
3215     <p>If the answer to one of these questions is yes, then come
3216 out to the first meeting of the Computer Science Club Poster Team! The
3217 CSC is looking for interested students to help out with promotion and
3218 publicity for this term's events. We promise good times and free
3219 pizza!</p>
3220   </abstract>
3221   </eventitem>
3222
3223   <eventitem date="2003-09-17" time="4:30 PM" room="MC3001 (Comfy)"
3224    title="CSC Elections">
3225   <short>CSC Fall 2003 Elections</short>
3226   <abstract>
3227    <p>Elections will be held on Wednesday, September 17, 2003 at 4:30 PM in the
3228
3229    Comfy Lounge, MC3001.</p>
3230
3231    <p>I invite you to nominate yourself or others for executive positions,
3232    starting immediately. Simply e-mail me at cro@csclub.uwaterloo.ca 
3233    with the name of the person who is to be nominated and the position
3234    they're nominated for.</p>
3235
3236    <p>Nominees must be full-time undergraduate students in Math. Sorry!</p>
3237
3238    <p>Positions open for elections are:</p>
3239
3240    <ul><li>President: Organises the club, appoints committees, keeps everyone busy.
3241    If you have lots of ideas about the club in general and like bossing
3242    people around, go for it!</li>
3243
3244    <li>Vice President: Organises events, acts as the president if he's not
3245    available. If you have lots of ideas for events, and spare time, go
3246    for it!</li>
3247
3248    <li>Treasurer: Keeps track of the club's finances. Gets to sign cheques
3249    and stuff. If you enjoy dealing with money and have ideas on how to
3250    spend it, go for it!</li>
3251
3252    <li>Secretary: Takes care of minutes and outside correspondence. If you
3253    enjoy writing things down and want to use our nifty new letterhead
3254    style, go for it!</li></ul>
3255
3256    <p>Nominations will be accepted until Tuesday, September 16 at 4:30 PM.</p>
3257
3258    <p>Additionally, a Sysadmin will be appointed after the elections. If you
3259    like working with Unix systems and have experience setting up and
3260    maintaining them, go for it!</p>
3261
3262    <p>I hope that lots of people will show up; hopefully we'll have a great
3263    term with plenty of events. We always need other volunteers, so if you
3264    want to get involved just talk to the new exec after the
3265    meeting. Librarians, webmasters, poster runners, etc. are always
3266    sought after!</p>
3267
3268    <p>There will also be free pop.</p>
3269
3270    <p>Memberships can be purchased at the elections or at least half an hour
3271    prior to at the CSC. Only undergrad math members can vote, but anyone can
3272    become a member.</p>
3273
3274   </abstract>
3275   </eventitem>
3276 <!-- Spring 2003 -->
3277
3278   <eventitem date="2003-07-31" time="4:30 PM" room="MC4064"
3279    title="LaTeX and Work Reports">
3280   <short>Writing beautiful work reports</short>
3281   <abstract> 
3282
3283   <p>The work report is a familiar chore for any co-op student.  Not only is
3284   there a report to write, but to add insult to injury, your report is
3285   returned if you do not follow your departmental guidelines.</p>
3286
3287   <p>Fear no more!  In this talk, you will learn how to use LaTeX and a
3288   specially developed class to automatically format your work reports.
3289   This talk is especially useful to Mathematics, Computer Science,
3290   Electrical &amp; Computer Engineering, and Software Engineeering co-op
3291   students about to go on work term.</p>
3292
3293   <p><a
3294   href="http://www.eng.uwaterloo.ca/~sfllaw/programs/uw-wkrpt/">http://www.eng.uwaterloo.ca/~sfllaw/programs/uw-wkrpt/</a></p>
3295
3296   </abstract>
3297   </eventitem>
3298
3299   <eventitem date="2003-07-24" time="4:30 PM" room="MC2037"
3300    title="vi: the visual editor">
3301   <short>It's not 6.</short>
3302   <abstract> 
3303
3304   <p>In 1976, a University of California Berkeley student by the name of
3305   Bill Joy got sick of his text editor, ex.  So he hacked it such that
3306   he could read his document as he wrote it.  The result was "vi", which
3307   stands for VIsual editor.   Today, it is shipped with every modern
3308   Unix system, due to its global influence.</p>
3309
3310   <p>In this talk, you will learn  how to use vi to edit documents
3311   quickly and efficiently.  At the end, you should be able to:</p>
3312
3313   <ul>
3314   <li>Navigate and search through documents</li>
3315   <li>Cut, copy, and paste across documents</li>
3316   <li>Search and replace regular expressions</li>
3317   </ul>
3318
3319   <p>If you do not have a Math computer account, don't panic; one will be lent
3320   to you for the duration of this class.</p>  
3321
3322   </abstract>
3323   </eventitem>
3324
3325   <eventitem date="2003-07-24" time="3:00 PM" room="CSC Office" title="July 
3326   Exec Meeting">
3327   <short> See Abstract for minutes </short>
3328   <abstract>
3329   <pre>
3330 --paying Simon for Sugar
3331 -Unanimous yea.
3332 -ACTION ITEM: Mark
3333         Expense this to MathSoc in lieu of foreign speaker.
3334
3335 --We currently have (including CD-R and pop-income not 
3336 currently in safe) $972.85
3337 -We have $359.02 on budget that we can expense to MathSoc.
3338
3339 --We got MEF money for books and video card. Funding for 
3340 wireless microphone is dependent on whether MFCF is 
3341 willing to host it.
3342 -Funding for casters was denied.
3343 -Shopping for the Video card.
3344 -Expecting it after August (Stefanus shopping for it.)
3345 -Will have to hear back regarding the microphone, best to 
3346 delay that now, discuss it with MEF.
3347         -Better to do it this term, so it doesn't get lost.
3348         -Let MFCF know about this concern.
3349 -Regarding books, can be done anytime before September.
3350
3351 --Events feedback
3352         -Generally, Jim Eliot talk when really well.
3353                 -Apparently he was generally offensive.
3354         -When was the LaTeX talk? End of the month.
3355         -Kegger at Jim's place on the 16th.
3356
3357 --Getting people in on the 6th, 7th, 8th for csc commercials
3358 filmed by Jason
3359         -Hang out in here, and he'll make a CSC commercial.
3360         -Co-ordinate when everyone should be in here, so we can email Jason.
3361
3362 --CEO progress
3363         -CEO needs it's database changed to use ISBN as a primary key.
3364         -Needs functionality to take out/return books.
3365
3366 --Mark just entered financial stuff into GNUcash
3367
3368 --Choose CRO for next term.
3369 -Stefanus has expressed desire not to be CRO.
3370 -Gary Simmons was suggested (and he accepted)
3371 -Unanimous yea
3372
3373 --Mike Biggs has to get here naked.
3374         -Four unanimous votes.
3375         -Nakedness only applies to getting here, not being here.
3376
3377
3378 From last meeting:
3379 ACTION ITEM: Biggs and Cass
3380 -get labelmaker tape, masking tape
3381 whiteboard makers, coloured paper, CD sleeves
3382 -keep receipts for CSC office expenses.
3383
3384 How is the progress on allowing executives and voters to be non-math
3385 members?
3386 -The vote is coming up Monday.
3387 -Proposal: Anyone who is a paying member can be a member
3388         -So you can either do two things:
3389         Pay MathSoc fees, or
3390         Get your faculty society to recognize CSC as a club.
3391
3392 Stefanus wanted to mention that we should talk to Yolanda, 
3393 Craig or Louie about a EYT event for frosh week.
3394 -Organized by Meg.
3395 -Sugar Mountain trying to hook all the Frosh
3396 ACTION ITEM: Jim
3397 -Email Meg
3398
3399 Reminder for Next Year's executive.
3400 -September 16th @ 5:00pm, get a table for Clubs day, and 17th 
3401 and 18th, maintain the booth (full day events).
3402 -Update pamphlets.
3403 ACTION ITEM: Gary
3404 -There should be executive before then 
3405
3406 Note: There needs to be a private section in the CSC Procedures Manual.
3407 (Only accessible by shell)
3408 ACTION ITEM: Simon
3409 -Do it.
3410
3411 ACTION ITEM: Mike
3412 -Talk to Plantops about:
3413 -Locks on doors
3414 -Mounting corkboard.
3415 -Talk about CSC Sign
3416   </pre>
3417   </abstract>
3418
3419   </eventitem>
3420   <eventitem date="2003-06-27" time="2:30 PM" room="DC1302"
3421    title="Friday Flicks">
3422   <short> SIGGRAPH Electronic Theatre Showing </short>
3423   <abstract>
3424   <p>
3425    SIGGRAPH is the ACM's Special Interest Group for Graphics and
3426    simultaneously the world's largest graphics conference and
3427    exhibition, where the cutting edge of graphics research is presented
3428    every year.
3429    </p><p>
3430     With support from UW's Computer Graphics Lab, the CSC invites you to
3431     capture a glimpse of SIGGRAPH 2002. We will be presenting the
3432     Electronic Theatre showings from 2002, demonstrating the best of the
3433     animated, CG-produced movies presented at SIGGRAPH.
3434     </p><p> Don't miss this free showing!</p>
3435   </abstract>
3436   </eventitem>
3437   <eventitem date="2003-07-08" time="4:00 PM" room="MC2065"
3438    title="Mainframes and Linux">
3439   <short>A talk by Jim Elliott. Jim is responsible for IBM's in Open Source
3440   activities and IBM's mainframe operating systems for Canada and the 
3441   Carribbean.</short>
3442   <abstract>
3443   <p>
3444   Linux and Open Source have become a significant reality in the
3445   working world of Information Technology. An indirect result has been a
3446   "rebirth" of the mainframe as a strategic platform for enterprise
3447   computing. In this session Jim Elliott, IBM's Linux Advocate, will provide
3448   an overview of these technologies and an inside look at IBM's participation
3449   in the community. Jim will examine Linux usage on the desktop, embedded
3450   systems and servers, a reality check on the common misconceptions that
3451   surround Linux and Open Source, and an overview of the history and current
3452   design of IBM's mainframe servers.</p>
3453   <p>
3454   Jim Elliott is the Linux Advocate for IBM Canada. He is responsible
3455   for IBM's participation in Linux and Open Source activities and IBM's
3456   mainframe operating systems in Canada and the Caribbean. Jim is a popular
3457   speaker on Linux and Open Source at conferences and user groups across the
3458   Americas and Europe and has spoken to over 300 organizations over the past
3459   three years. Over his 30 years with IBM he has been the co-author of over
3460   15 IBM publications and he also coordinated the launch of Linux on IBM
3461   mainframes in the Americas. In his spare time, Jim is addicted to reading
3462   historical mystery novels and travel to their locales.
3463   </p>
3464   <p><a href="http://www.vm.ibm.com/devpages/jelliott/events.html">Slides</a>
3465   </p>
3466   </abstract>
3467   </eventitem>
3468   <eventitem date="2003-07-04" time="3:30 PM" room="University of Guelph"
3469    title="Guelph Trip">
3470   <short>Come Visit the University of Guelph's Computer Science Club</short>
3471   <abstract><p>
3472    The University of Waterloo Computer Science Club is going to visit the
3473    University of Guelph Computer Science Club.  There will be a talk given
3474    as well as dinner with a fun social atmosphere.</p><p>Drivers Wanted</p>
3475    <p>Cancelled -- sorry Guelph cancelled on us.</p>
3476   </abstract>
3477   </eventitem>
3478   <eventitem date="2003-07-17" time="4:30 PM" room="MC4064"
3479    title="Sh">
3480   <short>Metaprogramming your way to stunning effects.</short>
3481   <abstract>
3482   <p>
3483   Modern graphics processors allow developers to upload small "shader
3484   programs" to the GPU, which can be executed per-vertex or even
3485   per-pixel during the rendering. Such shaders allow stunning effects to
3486   be performed in real-time, but unfortunately aren't very easy to
3487   program since one generally has to write them at the assembly level.
3488   </p><p>
3489   Recently a few high-level languages for shader programming have become
3490   available. Sh, a result of research at UW, is one such language. It
3491   allows programming powerful shaders in simple and intuitive ways. Sh
3492   is particularly interesting because of the way it is
3493   implemented. Instead of coming up with a language grammar and writing
3494   a full-fledged compiler, Sh is implemented as a C++ library, and
3495   shader programs are effectively written in C++. The actual compilation
3496   then takes place in a manner similar to JIT (Just-in-time)
3497   compilers. This has many advantages over the traditional approach,
3498   including C++'s familiar syntax for users, and much less work for the
3499   Sh implementers.
3500   </p><p>
3501   In this talk I will give an overview of GPUs and the Sh language as
3502   well as some interesting details on how Sh was implemented.
3503   </p><p> <!-- Is there a bio tag -->
3504   Stefanus Du Toit is a research assistant at the University of
3505   Waterloo. He has implemented the current version of Sh from scratch
3506   and is actively developing it under supervision of Michael McCool, the
3507   original designer of the language.
3508   </p>
3509   </abstract>
3510   </eventitem>
3511   <eventitem date="2003-06-19" time="4:30 PM" room="MC2037"
3512    title="vi: the visual editor">
3513   <short>It's not 6.</short>
3514   <abstract> 
3515
3516   <p>In 1976, a University of California Berkeley student by the name of
3517   Bill Joy got sick of his text editor, ex.  So he hacked it such that
3518   he could read his document as he wrote it.  The result was "vi", which
3519   stands for VIsual editor.   Today, it is shipped with every modern
3520   Unix system, due to its global influence.</p>
3521
3522   <p>In this talk, you will learn  how to use vi to edit documents
3523   quickly and efficiently.  At the end, you should be able to:</p>
3524
3525   <ul>
3526   <li>Navigate and search through documents</li>
3527   <li>Cut, copy, and paste across documents</li>
3528   <li>Search and replace regular expressions</li>
3529   </ul>
3530
3531   <p>If you do not have a Math computer account, don't panic; one will be lent
3532   to you for the duration of this class.</p>  
3533
3534   </abstract>