- Fix typo in LaTeX talk
[mspang/www.git] / events.xml
1 <eventdefs>
2
3   <!-- Winter 2003 -->
4
5   <eventitem date="2003-02-04" time="4:30 PM" room="MC2037"
6    title="Unix 101 Tutorial">
7   <short>Learn Unix and be the envy of your friends!</short>
8   <abstract> 
9
10   <p>This is the first in a series of seminars that cover the use of the
11   UNIX Operating System.  UNIX is used in a variety of applications, both
12   in academia and industy. We will provide you with hands-on experience
13   with the Math Faculty's UNIX environment in this seminar.</p> 
14
15   <p>Topics that will be discussed include:</p>
16
17   <ul>
18   <li> Navigating the UNIX environment</li>
19   <li> Using common UNIX commands</li>
20   <li>Using the PICO text editor</li>
21   <li>Reading electronic mail and news with PINE</li>
22   </ul>
23
24   <p>If you do not have a Math computer account, don't panic; one will be lent
25   to you for the duration of this class.</p>  
26
27   </abstract>
28   </eventitem>
29
30   <eventitem date="2003-02-11" time="4:30 PM" room="MC2037"
31    title="Unix 102 Tutorial">
32   <short>Learn more Unix and be the envy of your friends!</short>
33   <abstract> 
34
35   <p>Abstract to come soon.</p>
36
37   </abstract>
38   </eventitem>
39
40   <eventitem date="2003-02-18" time="4:30 PM" room="MC2037"
41    title="Unix 103 Tutorial">
42   <short>Learn more Unix and be the envy of your friends!</short>
43   <abstract> 
44
45   <p>Abstract to come soon. </p>
46
47   </abstract>
48   </eventitem>
49
50   <eventitem date="2003-01-13" time="6:00 PM" room="MC3001"
51     title="W03 Elections">
52     <short>Come out and vote for the new exec!</short>
53    <abstract>
54
55 <p>This term's elections will take place on Monday, January 13 at 6:00 PM in the
56 MC "comfy lounge" (MC3001). Nominations are open from now on (Thursday,
57 January 2) until 4:30 PM of the day before elections (Sunday, January 12).
58 In order to nominate someone you can either e-mail me directly, by depositing
59 a form with the required information in the CSC mailbox in the Mathsoc office
60 or by writing the nomination and clearly marking it as such on the large
61 whiteboard in the CSC office. E-mail is probably the best choice.
62 Please include the name of the person to be nominated as well as the position
63 you wish to nominate them for.</p>
64
65 <p>Candidates must be full members of the club. This means they must have paid
66 their membership for the given term and (due to recent changes in the
67 constitution) must be full-time undergraduate math students.
68 The same requirements hold for those voting. Please bring your Watcard to
69 the elections so that I can verify this. I will have a list of members with
70 me also.</p>
71
72 <p>The positions open are:</p>
73
74 <p><b>President</b> -- appoints all commitees of the club, calls and presides at all
75 meetings of the club and audits the club's financial records. Really, this
76 is the person in charge.</p>
77
78 <p><b>Vice President</b> -- assumes President's duties in case he/she is absent,
79 plans and coordinates events with the programmes committee and assumes any
80 other duties delegated by the President.
81 This is a really fun job if you enjoy coordinating events!</p>
82
83 <p><b>Secretary</b> -- keeps minutes of the meetings and cares for any correspondence.
84 A fairly light job, good choice if you just want to see what being an exec
85 is all about.</p>
86
87 <p><b>Treasurer</b> -- maintains all the finances of the club.
88 If you like money and keeping records, this is the job for you!</p>
89
90 <p>Additionally a Systems Administrator will be picked by the new executive.</p>
91
92 <p>Last term was a great term for the CSC -- many events, some office renovations
93 and a much improved image were all part of it. I hope to see the next term's
94 exec continue this. If you're interested in seeing this happen, do consider
95 going for a position, or helping out as office staff or on one of the
96 committees.</p>
97
98 <p>Anyways, hopefully I'll see many of you at the elections.
99 Remember: Monday, January 13, 6:00 PM, MC3001/Comfy Lounge.</p>
100
101 <p>If you have any further questions don't hesitate to contact the CRO,
102       Stefanus Du Toit <a href="mailto:sjdutoit@uwaterloo.ca">by e-mail</a>.</p>
103     </abstract>
104   </eventitem>
105
106   <eventitem date="2003-01-23" time="6:30 PM" room="MC1085"
107     title="Regular Expressions">
108     <short>Find your perfect match</short>
109     <abstract>
110
111     <p>Stephen Kleene developed regular expressions to describe what he
112     called <q>the algebra of regular sets.</q>  Since he was a pioneering
113     theorist in computer science, Kleene's regular expressions soon made
114     it into searching algorithms and from there to everyday tools.</p>
115
116     <p>Regular expressions can be powerful tools to manipulate text.
117     You will be introduced to them in this talk.  As well, we will go
118     further than the rigid mathematical definition of regular
119     expressions, and delve into POSIX regular expressions which are
120     typically available in most Unix tools.</p>
121
122     </abstract>
123   </eventitem>
124
125   <eventitem date="2003-01-30" time="6:30 PM" room="MC1085"
126     title="sed &amp; awk">
127     <short>Unix text editing</short>
128     <abstract>
129
130     <p><i>sed</i> is the Unix stream editor.  A powerful way to
131     automatically edit a large batch of text.  <i>awk</i> is a
132     programming language that allows you to manipulate structured data
133     into formatted reports.</p>
134
135     <p>Both of these tools come from early Unix, and both are still
136     useful today.  Although modern programming languages such as Perl,
137     Python, and Ruby have largely replaced the humble <i>sed</i> and
138     <i>awk</i>, they still have their place in every Unix user's
139     toolkit.</p>
140
141     </abstract>
142   </eventitem>
143
144   <eventitem date="2003-02-06" time="6:30 PM" room="MC1085"
145     title="LaTeX: A Document Processor">
146     <short>Typesetting beautiful text</short>
147     <abstract>
148
149     <p>Unix was one of the first electronic typesetting platforms.  The
150     innovative AT&amp;T <i>troff</i> system allowed researches at Bell
151     Labs to generate high quality camera-ready proofs for their papers.
152     Later, Donald Knuth invented a typesetting system called
153     T<small>E</small>X, which was far superior to other typesetting
154     systems in the 1980s.  However, it was still a typesetting language,
155     where one had to specify exactly how text was to be set.</p>
156
157     <p>L<sup><small>A</small></sup>T<small>E</small>X is a macro package
158     for the T<small>E</small>X system that allows an author to describe
159     his document's function, thereby typesetting the text in an
160     attractive and correct way.  In addition, one can define semantic
161     tags to a document, in order to describe the meaning of the
162     document; rather than the layout.</p>
163
164     </abstract>
165   </eventitem>
166
167   <eventitem date="2003-02-13" time="6:30 PM" room="MC1085"
168     title="LaTeX: Reports">
169     <short>Writing reports that look good.</short>
170     <abstract>
171
172     <p>Work term reports, papers, and other technical documents can be
173     typeset in L<sup><small>A</small></sup>T<small>E</small>X to great
174     effect.  In this session, I will provide examples on how to typeset
175     tables, figures, and references.  You will also learn how to make
176     tables of contents, bibliographics, and how to create footnotes.</p>
177
178     <p> I will also examine various packages of 
179     L<sup><small>A</small></sup>T<small>E</small>X that can help you 
180     meet requirements set by users of inferior typesetting systems.  
181     These include double-spacing, hyphenation and specific margin 
182     sizes.</p>
183
184     </abstract>
185   </eventitem>
186
187   <eventitem date="2003-02-20" time="6:30 PM" room="MC1085"
188     title="LaTeX: Beautiful Mathematics">
189     <short>LaTeX =&gt; fun</short>
190     <abstract>
191
192     <p>It is widely acknowledged that the best system by which to
193     typeset beautiful mathematics is through the T<small>E</small>
194     typesetting system, written by Donald Knuth in the early 1980s.</p>
195
196     <p>In this talk, I will demonstrate
197     L<sup><small>A</small></sup>T<small>E</small>X and how to typeset
198     elegant mathematical expressions.</p>
199
200     </abstract>
201   </eventitem>
202
203   <eventitem date="2003-02-27" time="6:30 PM" room="MC1085"
204     title="The GNU General Public License">
205     <short>The teeth of Free Software</short>
206     <abstract>
207
208     <div style="font-style: italic"><blockquote>
209       The licenses for most software are designed to take away your
210       freedom to share and change it. By contrast, the GNU General
211       Public License is intended to guarantee your freedom to share and
212       change free software---to make sure the software is free for all
213       its users.
214       <br />
215       <div style="text-align:right">--- Excerpt from the GNU GPL</div>
216     </blockquote></div>
217     
218     <p> The GNU General Public License is one of the most influencial
219     software licenses in this day.  Written by Richard Stallman for the
220     GNU Project, it is used by software developers around the world to
221     protect their work.</p>
222
223     <p>Unfortunately, software developers do not read licenses
224     thoroughly, nor well.  In this talk, we will read the entire GNU GPL
225     and explain the implications of its passages.  Along the way, we
226     will debunk some myths and clarify common misunderstandings.</p>
227
228     <p>After this session, you ought to understand what the GNU GPL
229     means, how to use it, and when you cannot use it.  This session
230     should also give you some insight into the social implications of
231     this work.</p>
232
233     </abstract>
234   </eventitem>
235
236   <eventitem date="2003-03-13" time="6:30 PM" room="MC1085"
237     title="XML">
238     <short>Give your documents more markup</short>
239     <abstract>
240
241     <p>XML is the <q>eXtensible Markup Language,</q> a standard
242     maintained by the World Wide Web Consortium.  A descendant of IBM's
243     SGML.  It is a metalanguage which can be used to define markup
244     languages for semantically describing a document.</p>
245
246     <p>This talk will describe how to generate correct XML documents,
247     and auxillary technologies that work with XML.</p>
248
249     </abstract>
250   </eventitem>
251
252   <eventitem date="2003-03-20" time="6:30 PM" room="MC1085"
253     title="XSLT">
254     <short>Transforming your documents</short>
255     <abstract>
256
257     <p>XSLT is the <q>eXtended Stylesheet Language Transformations,</q>
258     a language for transforming XML documents into other XML
259     documents.</p>
260
261     <p>XSLT is used to manipulate XML documents into other forms: a sort
262     of glue between data formats.  It can turn an XML document into an
263     XHTML document, or even an HTML document.  With a little bit of
264     hackery, it can even be convinced to spit out non-XML conforming
265     documents.</p>
266
267     </abstract>
268   </eventitem>
269
270   <eventitem date="2003-03-27" time="6:30 PM" room="MC1085"
271     title="SSH and Networks">
272     <short>Once more into the breach</short>
273     <abstract>
274
275     <p>The Secure Shell (SSH) has now replaced traditional remote login
276     tools such as <i>rsh</i>, <i>rlogin</i>, <i>rexec</i> and
277     <i>telnet</i>.  It is used to provide secure, authenticated,
278     encrypted communications between remote systems.  However, the SSH
279     protocol provides for much more than this.</p>
280
281     <p>In this talk, we will discuss using SSH to its full extent.  Topics
282     to be covered include:</p>
283     <ul>
284       <li>Remote logins</li>
285       <li>Remote execution</li>
286       <li>Password-free authentication</li>
287       <li>X11 forwarding</li>
288       <li>TCP forwarding</li>
289       <li>SOCKS tunnelling</li>
290     </ul>
291
292     </abstract>
293   </eventitem>
294
295   <!-- Fall 1994 -->
296         <eventitem
297          date="1994-09-13" time="9:00 PM"
298          room="Princess Cinema"
299          title="Movie Outing: Brainstorm">
300                 <short>
301                         No description available.
302                 </short>
303                 <abstract>
304                         <p>
305                         The first of this term's CSC social events, we will be going to see
306                         the movie ``Brainstorm'' at the Princess Cinema. This outing is
307                         intended primarily for the new first-year students.
308                         </p>
309                         <p>
310                         The Princess Cinema is Waterloo's repertoire theatre. This month
311                         and next, they are featuring a ``Cyber Film Festival''. Upcoming
312                         films include:
313                         </p>
314                         <ul>
315                                 <li>Brazil</li>
316                                 <li>Bladerunner (director's cut)</li>
317                                 <li>2001: A Space Odyssey</li>
318                                 <li>Naked Lunch</li>
319                         </ul>
320                         <p>
321                         Admission is $4.25 for a Princess member, $7.50 for a non-member.
322                         Membership to the Princess is $7.00 per year. 
323                         </p>
324                 </abstract>
325         </eventitem>
326         <eventitem
327          date="1994-09-16" time="4:30 PM"
328          room="MC 4040"
329          title="CSC Elections">
330                 <short>No description available</short>
331                 <abstract>No abstract available</abstract>
332         </eventitem>
333         <eventitem
334          date="1994-09-19" time="4:30 PM"
335          room="MC 3022"
336          title="UNIX I Tutorial">
337                 <short>No description available</short>
338                 <abstract>No abstract available</abstract>
339         </eventitem>
340         <eventitem
341          date="1994-09-21" time="6:30 PM"
342          room="DC 1302"
343          title="SIGGRAPH Video Night">
344                 <short>No description available</short>
345                 <abstract>No abstract available</abstract>
346         </eventitem>
347         <eventitem
348          date="1994-09-22" time="4:30 PM"
349          room="MC 3022"
350          title="UNIX I Tutorial">
351                 <short>No description available</short>
352                 <abstract>No abstract available</abstract>
353         </eventitem>
354         <eventitem
355          date="1994-09-26" time="4:30 PM"
356          room="MC 3022"
357          title="UNIX II Tutorial">
358                 <short>No description available</short>
359                 <abstract>No abstract available</abstract>
360         </eventitem>
361         <eventitem
362          date="1994-10-13" time="5:00 PM"
363          room="DC 1302"
364          title="Prograph: Picture the Future">
365                 <short>No description available</short>
366                 <abstract>
367                         <p>
368                         What is the next step in the evolution of computer languages?
369                         Intelligent agents? Distributed objects? or visual languages?
370                         </p>
371                         <p>
372                         Visual languages overcome many of the drawbacks and limitations
373                         of the textual languages that software development is based on
374                         today. Do you think about programming in a linear fashion? Or do
375                         you draw a mental picture of your algorithm and then linearize it
376                         for the benefit of your compiler? Wouldn't it be nice if you could
377                         code the same way you think?
378                         </p>
379                         <p>
380                         Visual C++ and Visual BASIC aren't visual languages, but Prograph
381                         is. Prograph is a commercially available, visual, object-oriented,
382                         data-flow language. It is well suited to graphical user interface
383                         development, but is as powerful for general-purpose programming as
384                         any textual language.
385                         </p>
386                         <p>
387                         The talk will comprise a discussion of the problems of textual
388                         languages that visual languages solve, a live demonstration of
389                         Prograph, and some of my observations of the applications of
390                         Prograph to software development.
391                         </p>
392                 </abstract>
393         </eventitem>
394         <eventitem
395          date="1994-10-15" time="10:00 AM"
396          room="MC 3022"
397          title="ACM-Style Programming Contest">
398                 <short>No description available</short>
399                 <abstract>
400                         <h3>Big Money and Prizes!</h3>
401                         <p>
402                         So you think you're a pretty good programmer? Pit your skills
403                         against others on campus in this triannual event! Contestants will
404                         have three hours to solve five programming problems in either C or
405                         Pascal.
406                         </p>
407                         <p>
408                         Last fall's winners went on to the International Finals and came
409                         first overall! You could be there, too!
410                         </p>
411                 </abstract>
412         </eventitem>
413         <eventitem
414          date="1994-10-20" time="4:30 PM"
415          room="MC 3009"
416          title="Exploring the Internet">
417                 <short>No description available</short>
418                 <abstract>
419                         <h3>Need something to do between assignments/beers?</h3>
420                         <p>
421                          Did you know that your undergrad account at Waterloo gives you
422                          access tothe world's largest computer network? With thousands
423                          of discussion groups, gigabytes of files to download, multimedia
424                          information browsers, even on-line entertainment?
425                         </p>
426                         <p>
427                         The resources available on the Internet are vast and wondrous, but
428                         the tools for navigating it are sometimes confusing and arcane. In
429                         this hands-on tutorial you will get the chance to get your feet wet
430                         with the world's most mind-bogglingly big computer network, the
431                         protocols and programs used, and how to use them responsibly and
432                         effectively. 
433                         </p>
434                 </abstract>
435         </eventitem>
436         <eventitem
437          date="1994-11-02" time="4:30 PM"
438          room="MC 2038"
439          title="Game Theory">
440                 <short>No description available</short>
441                 <abstract>
442                         <h3>From the Minimax Theorem, through Alpha-Beta, and beyond...</h3>
443                         <p>
444                          This will be a descussion of the pitfalls of using mathematics and
445                          algorithms to play classical board games. Thorough descriptions
446                          shall be presented of the simple techniques used as the building
447                          blocks that make all modern computer game players. I will use
448                          tic-tac-toe as a control for my arguements. Other games such as
449                          Chess, Othello and Go shall be the be a greater measure of progress;
450                          and more importantly the targets of our dreams.
451                          </p>
452                         <p>
453                          To enhance the discussion of the future, Barney Pell's Metagamer
454                          shall be introduced. His work in define classes of games is
455                          important in identifying the features necessary for analysis. 
456                          </p>
457                 </abstract>
458         </eventitem>
459
460   <!-- Fall 1999 -->
461
462   <eventitem date="1999-10-18" time="2:30 PM" room="DC1304"
463   title="Living Laboratories: The Future Computing Environments at
464   Georgia Tech">
465     <short>By Blair MacIntyre and Elizabeth Mynatt</short>
466     <abstract>
467       <p>by   Blair MacIntyre and Elizabeth Mynatt</p>
468       <p>The Future Computing Environments (FCE) Group at Georgia Tech
469         is a collection of faculty and students that share a desire to
470         understand the partnership between humans and technology that
471         arises as computation and sensing become ubiquitous.  With
472         expertise covering the breadth of Computer Science, but
473         focusing on HCI, Computational Perception, and Machine
474         Learning, the individual research agendas of the FCE faculty
475         are grounded in a number of shared "living laboratories" where
476         their research is applied to everyday life in the classroom
477         (Classroom 2000), the home (the Aware Home), the office
478         (Augmented Offices), and on one's person.  Professors
479         MacIntyre and Mynatt will discuss a variety of these projects,
480         with an emphasis on the HCI and Computer Science aspects of
481         the FCE work.
482       </p>
483       <p>
484         In addition to their affiliation with the FCE group,
485         Professors Mynatt and MacIntyre are both members of the
486         Graphics, Visualization and Usability Center (GVU) at Georgia
487         Tech.  This interdisciplinary center brings together research
488         in computer science, psychology, industrial engineering,
489         architecture and media design by examining the role of
490         computation in our everyday lives.  During the talk, they will
491         touch on some of the research and educational opportunities
492         available at both GVU and the College of Computing.
493       </p>
494     </abstract>
495   </eventitem>
496
497   <eventitem date="1999-10-19" time="4:30 PM" room="DC1304"
498   title="GDB, Purify Tutorial">
499     <short>No description available.</short>
500     <abstract>
501       <p>
502        Debugging can be the most difficult and time consuming part of
503        any program's life-cycle. Far from an exact science, it's more
504        of an art ... and close to some kind of dark magic. Cryptic
505        error messages, lousy error checking, and icky things like
506        implicit casts can make it nearly impossible toknow what's
507        going on inside your program.
508       </p>
509       <p>
510          Several tools are available to help automate your
511          debuggin. GDB and Purify are among the most powerful
512          debugging tools available in a UNIX environment. GDB is an
513          interactive debugger, allowing you to `step' through
514          aprogram, examine function calls, variable contents, stack
515          traces and let you look at the state of a program after it
516          crashes. Purify is a commercial program designed to help find
517          and remove memory leaks from programs written inlanguages
518          without automatic garbage collection.
519       </p>
520       <p>
521         This talk will cover how to compile your C and C++ programs
522         for use with GDB and Purify, as well as how to use the
523         available X interfaces. If a purify license is available on
524         undergrad at the time of the talk, we will cover how to use it
525         during runtime.
526       </p>
527     </abstract>
528   </eventitem>
529
530   <eventitem date="1999-12-01" time="4:30 PM" room="MC2066"
531     title="Homebrew Processors and Integrated Systems in FPGAs">
532     <short>By Jan Gray</short>
533     <abstract>
534       <p>by Jan Gray</p>
535       
536       <p> With the advent of large inexpensive field-programmable gate
537       arrays and tools it is now practical for anyone to design and
538       build custom processors and systems-on-a-chip. Jan will discuss
539       designing with FPGAs, and present the design and implementation
540       of xr16, yet another FPGA-based RISC computer system with
541       integrated peripherals.</p>
542
543       <p> Jan is a past CSC pres., B.Math. CS/EEE '87, and wrote
544       compilers, tools, and middleware at Microsoft from 1987-1998. He
545       built the first 32-bit FPGA CPU and system-on-a-chip in
546       1995. </p>
547     </abstract>
548   </eventitem>
549
550   <eventitem date="1999-12-01" time="7:00 PM" room="Golf's Steakhouse"
551     title="Ctrl-D">
552     <short>End-of-term dinner</short> 
553     <abstract>
554       No abstract available.
555     </abstract>
556   </eventitem>
557
558   <eventitem date="1999-12-02" time="1:30 PM" room="DC1302"
559     title="Calculational Mathematics">
560     <short>By Edgar Dijkstra</short>
561     <abstract>
562       <p> By Edgar Dijkstra</p>
563
564       <p> This  talk will use  partial orders, lattice theory,  and, if
565       time permits,  the Galois  connection as carriers  to illustrate
566       the use of  calculi in mathematics. We hope  to show the brevity
567       of  many calculations  (in order  tofight the  superstition that
568       formal  proofs  are  necessarily  unpractically long),  and  the
569       strong   heuristic  guidance   that  is   available   for  their
570       design. </p>
571
572       <p> Dijkstra is known for early graph-theoretical algorithms,
573       the first implementation of ALGOL 60, the first operating system
574       composed of explicitly synchronized processes, the invention of
575       guarded commands and of predicate transformers as a means for
576       defining semantics, and programming methodology in the broadest
577       sense of the word. </p>
578
579       <p> His current research interests focus on the formal
580       derivation of proofs and programs, and the streamlining of the
581       mathematical argument in general.</p>
582      
583       <p> Dijkstra held the Schlumberger Centennial Chair in Computer
584       Sciences at The University of Texas at Austin until retiring in
585       October. </p>
586
587     </abstract>
588   </eventitem>
589
590   <eventitem date="1999-12-03" time="10:00 AM" room="Siegfried Hall,
591   St Jerome's" title="Proofs and Programs">
592     <short>By Edsger Dijkstra</short>
593     <abstract>
594       <p> This talk will show the use of programs for the proving of
595       theorems. Its purpose is to show how our experience gained in
596       the derivations of programs might be transferred to the
597       derivation of proofs in general. The examples will go beyond the
598       (traditional) existence theorems. </p>
599
600       <p> Dijkstra is known for early graph-theoretical algorithms,
601       the first implementation of ALGOL 60, the first operating system
602       composed of explicitly synchronized processes, the invention of
603       guarded commands and of predicate transformers as a means for
604       defining semantics, and programming methodology in the broadest
605       sense of the word. </p>
606
607       <p> His current research interests focus on the formal
608       derivation of proofs and programs, and the streamlining of the
609       mathematical argument in general.</p>
610      
611       <p> Dijkstra held the Schlumberger Centennial Chair in Computer
612       Sciences at The University of Texas at Austin until retiring in
613       October. </p>
614
615     </abstract>
616   </eventitem>
617
618   <eventitem date="1999-12-03" time="3:00 PM" room="DC1351"
619     title="Open Q&amp;A session">
620     <short>By Edsger Dijkstra</short>
621     <abstract>No description available.</abstract>
622   </eventitem>
623
624   <!-- Winter 2000 -->
625
626   <eventitem date="2000-03-24" time="4:30 PM" room="DC1304"
627   title="Enterprise Java APIs and Implementing a Web Portal">
628     <short>No description available.</short>
629     <abstract>
630       <h3>by Floyd Marinescu
631       </h3>
632       
633       <p>
634         The first talk will be an introduction to the Enterprise Java
635         API's: Servlets, JSP, EJB, and how to use them to build
636         eCommerce sites.
637       </p>
638
639       <p>
640         The second talk will be about how these technologies were used
641         to implement a real world portal.  The talk will include an
642         overview of the design patterns used and will feature
643         architectural information about the yet to be release portal
644         (which I am one of the developers) called theserverside.com.
645       </p>
646     </abstract>
647   </eventitem>
648
649   <eventitem date="2000-03-30" time="4:30 PM" room="DC1304"
650     title="Enterprise Java APIs and Implementing a Web Portal (1)">
651     <short>No description available.</short>
652     <abstract>
653       <p>Real World J2EE - Design Patterns and architecture behind the
654         yet to be released J2EE portal: theserverside.com</p>
655
656       <p>This talk will feature an exclusive look at the architecture
657         behind the new J2EE portal: theserverside.com.  Join Floyd
658         Marinescu in a walk-through ofthe back-end of the portal,
659         while learning about J2EE and its real world patterns,
660         applications, problems and benefits.</p>
661     </abstract>
662   </eventitem>
663
664   <!-- Spring 2000 -->
665
666   <eventitem date="2000-07-20" time="7:00 PM" room="Ali Babas Steak
667   House, 130 King Street S, Waterloo" title="Ctrl-D">
668     <short>End-of-term dinner</short>
669     <abstract>No abstract available.</abstract>
670   </eventitem>
671
672   <!-- Fall 2000 -->
673
674   <eventitem date="2000-09-14" time="6:00 PM" room="DC1302"
675     title="CSC Elections">
676     <short>Fall 2000 Elections for the CSC.</short>
677     <abstract>
678       <p>
679         Would you like to get involved in the CSC? Would you like to have a
680         say in what the CSC does this term?  Come out to the CSC Elections!
681         In addition to electing the executive for the Fall term, we will be
682         appointing office staff and other positions.  Look for details in
683         uw.csc.
684       </p>
685
686       <p>Nominations for all positions are being taken in the CSC office, MC
687         3036.</p>
688     </abstract>
689   </eventitem>
690
691   <eventitem date="2000-09-14" time="7:00 PM" room="DC1302"
692     title="SIGGraph Video Night">
693     <short> SIGGraph Video Night Featuring some truly awesome computer
694     animations from Siggraph '99. </short>
695     <abstract>
696       <p> Interested in Computer Graphics?
697       </p>
698       
699       <p> Enjoy watching state-of-the-art Animation?
700       </p>
701       
702       <p> Looking for a cheap place to take a date?
703       </p>
704       
705       <p> SIGGraph Video Night -
706         Featuring some truly awesome computer animations from Siggraph '99.
707       </p>
708
709       <p>Come out for the Computer Science Club general elections at 6:00
710         pm, right before SIGGraph!</p>
711       </abstract>
712   </eventitem>
713
714  <eventitem date="2000-09-25" time="2:30 PM" room="DC1302"
715     title="Realising the Next Generation Internet">
716     <short>By Frank Clegg of Microsoft Canada</short>
717     <abstract>
718 <h3>Vitals</h3>
719 <dl>
720 <dt>By</dt>
721 <dd>Frank Clegg</dd>
722 <dd>President, Microsoft Canada</dd>
723 <dt>Date</dt>
724
725 <dd>Monday, September 25, 2000</dd>
726 <dt>Time</dt>
727 <dd>14:30 - 16:00</dd>
728 <dt>Place</dt>
729 <dd>DC 1302</dd>
730 <dd>(Davis Centre, Room 1302, University of Waterloo)</dd>
731
732 <dt>Cost</dt>
733 <dd>$0.00</dd>
734 <dt>Pre-registration</dt>
735 <dd>Recommended</dd>
736 <dd><a HREF="http://infranet.uwaterloo.ca:81/infranet/semform.htm">http://infranet.uwaterloo.ca:81/infranet/semform.htm</a></dd>
737 <dd>(519) 888-4004</dd>
738
739 </dl>
740
741 <h3>Abstract</h3>
742 <p>The Internet and the Web have revolutionized our communications, our access
743 to information and our business methods. However, there is still much room 
744 for improvement. Frank Clegg will discuss Microsoft's vision for what is 
745 beyond browsing and the dotcom. Microsoft .NET (pronounced "dot-net") is a 
746 new platform, user experience and set of advanced software services planned 
747 to make all devices work together and connect seamlessly. With this next 
748 generation of software, Microsoft's goal is to make Internet-based 
749 computing and communications easier to use, more personalized, and more 
750 productive for businesses and consumers. In his new position of president 
751 of Microsoft Canada Co., Frank Clegg will be responsible for leading the 
752 organization toward the delivery of Microsoft .NET. He will speak about 
753 this new platform and the next generation Internet, how software developers 
754 and businesses will be able to take advantage of it, and what the .NET 
755 experience will look like for consumers and business users.</p>
756
757 <h3>The Speaker</h3>
758 <p>Frank Clegg was appointed president of Microsoft Canada Co. this month. 
759 Prior to his new position, Mr. Clegg was vice-president, Central Region, 
760 Microsoft Corp. from 1996 to 2000. In this capacity, he was responsible for 
761 sales, support and marketing activities in 15 U.S. states. Mr. Clegg joined 
762 Microsoft Corp. in 1991 and headed the Canadian subsidiary until 1996. 
763 During that time, Mr. Clegg was instrumental in introducing several key 
764 initiatives to improve company efficiency, growth and market share. Mr. 
765 Clegg graduated from the University of Waterloo in 1977 with a B. Math.</p>
766
767 <h3>For More Information</h3>
768 <address>
769 Shirley Fenton<br />
770 The infraNET Project<br />
771 University of Waterloo<br />
772 519-888-4567 ext. 5611<br />
773 <a HREF="http://infranet.uwaterloo.ca/">http://infranet.uwaterloo.ca/</a>
774 </address>
775       </abstract>
776   </eventitem>
777
778
779  <!-- Winter 2001 -->
780
781  <eventitem date="2001-01-15" time="4:30 PM" room="MC3036"
782     title="Executive elections">
783   <short>Winter 2001 CSC Elections.</short>
784   <abstract>
785       <p>Would you like to get involved in the CSC? Would you like to
786         have a say in what the CSC does this term? Come out to the CSC
787         Elections! In addition to electing the executive for the
788         Winter term, we will be appointing office staff and other
789         positions. Look for details in uw.csc.
790       </p>
791       <p>
792         Nominations for all positions are being taken in the CSC
793         office, MC 3036.
794       </p>
795     </abstract>
796  </eventitem>
797   <eventitem date="2001-01-22" time="3:30 PM" room="MC3036"
798     title="Meeting #2">
799     <short>Second CSC meeting for Winter 2001.</short>
800     <abstract>
801       <h3>Proposed agenda</h3>
802       <dl>
803         <dt>Book purchases</dt>
804         <dd>
805           <p>They haven't been done in 2 terms.
806             We have an old list of books to buy.
807             Any suggestions from uw.csc are welcome.</p>
808         </dd>
809         <dt>CD Burner</dt>
810         
811         <dd>
812           <p>For doing linux burns. It was allocated money on the budget
813             request - about $300. We should be able to get a decent 12x
814             burner with that (8x rewrite).</p>
815           <p>The obvious things to sell are Linux Distros and BSD variants.
816             Are there any other software that we can legally burn and sell
817             to students?</p>
818         </dd>
819         <dt>Unix talks</dt>
820         <dd>
821           <p>Just a talk of the topics to be covered, when, where, whatnot.
822             Mike was right on this one, this should have been done earlier
823      in the term.  Oh well, maybe we can fix this for next fall term.</p>
824           
825         </dd>
826         <dt>Game Contest</dt>
827         <dd>
828           <p>We already put a bit of work into planning the Othello contest
829             before I read Mike's post. I still think it's viable. I've got
830             at least 2 people interested in writing entries for it. This
831             will be talked about more on monday. Hopefully, Rory and I will
832             be able to present a basic outline of how the contest is going
833             to be run at that time.</p>
834         </dd>
835         <dt>Peri's closet cleaning</dt>
836         <dd>
837           
838           <p>Current sysadmin (jmbeverl) and I (kvijayan) and
839             President (geduggan) had a nice conversation about this 2
840             days ago, having to do with completely erasing all of
841             peri, installing a clean stable potato debian on it, and
842             priming it for being a gradual replacement to calum. We'll
843             probably discuss how much we want to get done on this
844             front on Monday.</p>
845         </dd>
846       </dl>
847       
848       <p>Any <a HREF="nntp://news.math.uwaterloo.ca/uw.csc/8305">comments</a> from <a HREF="news:uw.csc">the newsgroup</a> are welcome.</p>
849     </abstract>
850   </eventitem>
851
852   <eventitem date="2001-01-27" time="10:30 AM" room="MC3006"
853     title="ACM-Style programming contest">
854     <short>Practice for the ACM international programming
855     contest</short>
856     <abstract>
857 <p>Our ACM-Style practice  contests involve answering five questions in three
858 hours.   Solutions are written  in Pascal, C  or C++.   Seven years in  a row,
859 Waterloo's teams  have been in  the top ten  at the world  finals.
860 For more information, see
861 <a HREF="http://plg.uwaterloo.ca/~acm00/">the contest web page</a>.</p>
862
863 <h3>Easy Question:</h3>
864 <p>A palindrome is a sequence of letters that reads the same backwards and
865 forwards, such as ``Madam, I'm Adam'' (note that case doesn't matter and
866 only letters are important). Your task is to find the longest palindrome in
867 a line of text (if there is a tie, print the leftmost one).</p>
868 <pre>
869 Input:                              Output:
870
871 asfgjh12dsfgg kj0ab12321BA wdDwkj   abBA
872 abcbabCdcbaqwerewq                  abCdcba
873 </pre>
874
875 <h3>Hard Question:</h3>
876 <p>An anagram is a word formed by reordering the letters of another word.
877 Find all sets of anagrams that exist within a large dictionary.  The
878 input will be a sorted list of words (up to 4000 words), one per line.
879 Output each set of anagrams on a separate line.  Each set should be
880 in alphabetical order, and all lines of sets should be in alphabetical
881 order.  A word with no anagrams is a set of anagrams itself, and should
882 be displayed with no modifications.</p>
883
884 <pre>
885 Input:      Output:
886
887 post        post pots stop
888 pots        start
889 start
890 stop
891 </pre>
892     </abstract>
893   </eventitem>
894
895   <eventitem date="2001-01-29" time="02:39 PM" room="MC3036"
896     title="Meeting #3">
897     <short>No description available.</short>
898     <abstract>No abstract available.</abstract>
899   </eventitem>
900
901   <eventitem date="2001-02-05" time="03:30 PM" room="MC3036"
902     title="Meeting #4">
903     <short>No description available.</short>
904     <abstract>No abstract available.</abstract>
905   </eventitem>
906
907   <eventitem date="2001-02-12" time="03:30 PM" room="MC3036"
908     title="Meeting #5">
909     <short>No description available.</short>
910     <abstract>No abstract available.</abstract>
911   </eventitem>
912
913   <!-- Spring 2001 -->
914
915   <eventitem date="2001-06-02" time="10:30 AM" room="MC3006"
916     title="ACM-Style programming contest">
917     <short>Practice for the ACM international programming
918     contest</short>
919     <abstract>
920 <p>Our ACM-Style practice  contests involve answering five questions in three
921 hours.   Solutions are written  in Pascal, C  or C++.   Seven years in  a row,
922 Waterloo's teams  have been in  the top ten  at the world  finals.
923 For more information, see
924 <a HREF="http://plg.uwaterloo.ca/~acm00/">the contest web page</a>.</p>
925
926 <h3>Easy Question:</h3>
927 <p>A palindrome is a sequence of letters that reads the same backwards and
928 forwards, such as ``Madam, I'm Adam'' (note that case doesn't matter and
929 only letters are important). Your task is to find the longest palindrome in
930 a line of text (if there is a tie, print the leftmost one).</p>
931 <pre>
932 Input:                              Output:
933
934 asfgjh12dsfgg kj0ab12321BA wdDwkj   abBA
935 abcbabCdcbaqwerewq                  abCdcba
936 </pre>
937
938 <h3>Hard Question:</h3>
939 <p>An anagram is a word formed by reordering the letters of another word.
940 Find all sets of anagrams that exist within a large dictionary.  The
941 input will be a sorted list of words (up to 4000 words), one per line.
942 Output each set of anagrams on a separate line.  Each set should be
943 in alphabetical order, and all lines of sets should be in alphabetical
944 order.  A word with no anagrams is a set of anagrams itself, and should
945 be displayed with no modifications.</p>
946
947 <pre>
948 Input:      Output:
949
950 post        post pots stop
951 pots        start
952 start
953 stop
954 </pre>
955     </abstract>
956   </eventitem>
957
958
959  <!-- Winter 2002 -->
960
961  <eventitem date="2002-01-26" time="2:00 PM"
962   room="Comfy Lounge MC3001" 
963   title="An Introduction to GNU Hurd">
964   <short>Bored of GNU/Linux? Try this experimental operating
965   system!</short>
966   <abstract>
967 <p>GNU Hurd is an operating system kernel based on the microkernel
968 architecture design. It was the original GNU kernel, predating Linux,
969 and is still being actively developed by many volunteers.</p>
970 <p>The Toronto-area Hurd Users Group, in co-operation with the Computer
971 Science Club, is hosting an afternoon to show the Hurd to anyone
972 interested. Jeff Bailey, a Hurd developer, will give a presentation on
973 the Hurd, followed by a GnuPG/PGP keysigning party. To finish it off,
974 James Morrison, also a Hurd developer, will be hosting a Debian
975 GNU/Hurd installation session.</p>
976 <p>All interested are invited to attend. Bring your GnuPG/PGP fingerprint
977 and mail your key to sjdutoit@uwaterloo.ca with the subject
978 ``keysigning'' (see separate announcement).</p>
979 <p>Questions? Suggestions? Contact <a
980 href="ja2morri@uwaterloo.ca">James Morrison</a>.</p>
981   </abstract>
982  </eventitem>
983  <eventitem date="2002-01-26" time="2:30 PM"
984   room="Comfy Lounge MC3001" 
985   title="GnuPG/PGP Keysigning Party">
986   <short>Get more signatures on your key!</short>
987   <abstract>
988   <p>
989    GnuPG and PGP provide public-key based encryption for e-mail and
990    other electronic communication. In addition to preventing others
991    from reading your private e-mail, this allows you to verify that an
992    e-mail or file was indeed written by its perceived author.
993   </p>
994   <p>
995    In order to make sure a GnuPG/PGP key belongs to the respective
996    person, the key must be signed by someone who has checked the
997    user's key fingerprint and verified the user's identification.
998   </p>
999   <p>
1000    A keysigning party is an ideal occasion to have your key signed by
1001    many people, thus strengthening the authority of your key. Everyone
1002    showing up exchanges key signatures after verifying ID and
1003    fingerprints. The Computer Science Club will be hosting such a
1004    keysigning party together with the Hurd presentation by THUG (see
1005    separate announcement). See
1006    <a href="http://www.student.math.uwaterloo.ca/~sjdutoit/"> the
1007    keysigning party homepage</a> for more information.
1008   </p>
1009   <p>
1010    Before attending it is important that you mail your key to
1011    sjdutoit@uwaterloo.ca with the subject ``keysigning.'' Also make
1012    sure to bring photo ID and a copy of your GnuPG/PGP fingerprint on
1013    a sheet of paper to the event.
1014   </p>
1015   </abstract>
1016  </eventitem>
1017  <eventitem date="2002-01-31" time="6:00 PM" room="MC2037"
1018   title="UNIX 101: First Steps With UNIX">
1019   <abstract>
1020     This is the first in a series of seminars that cover the use of
1021     the UNIX Operating System. UNIX is used in a variety of
1022     applications, both in academia and industy. We will be covering
1023     the basics of the UNIX environment, as well as the use of PINE, an
1024     electronic mail and news reader.
1025   </abstract>
1026  </eventitem>
1027  <eventitem date="2002-02-13" time="4:00 PM" room="MC4060"
1028   title="DVD-Video Under Linux">
1029   <short>Billy Biggs will be holding a talk on DVD technology
1030   (in particular, CSS and playback issues) under Linux, giving some
1031   technical details as well as an overview of the current status of
1032   Free Software efforts. All are welcome.</short>
1033   <abstract>
1034    <p>DVD copy protection: Content Scrambling System (CSS)</p>
1035    <ul>
1036     <li>A technical introduction to CSS and an overview of the ongoing
1037     legal battle to allow distribution of non-commercial DVD
1038     players</li>
1039     <li>The current Linux software efforts and open issues</li>
1040     <li>How applications and Linux distributions are handling the
1041     legal issues involved</li>
1042    </ul>
1043    <p>DVD-Video specifics: Menus and navigation</p>
1044    <ul>
1045     <li>An overview of the DVD-Video standard</li>
1046     <li>Reverse engineering efforts and their implementation status</li>
1047     <li>Progress of integration into Linux media players</li>
1048    </ul>
1049   </abstract>
1050  </eventitem>
1051  <eventitem date="2002-02-07" time="6:00 PM" room="MC2037"
1052   title="Unix 102: Fun With UNIX">
1053   <short>This the second in a series of UNIX tutorials. Simon Law and
1054   James Perry will be presenting some more advanced UNIX
1055   techniques. All are welcome. Accounts will be provided for those
1056   needing them.</short>
1057   <abstract>
1058    <p>
1059     This is the second in a series of seminars that cover the use of
1060     the UNIX Operating System. UNIX is used in a variety of
1061     applications, both in academia and industry. We will provide you
1062     with hands-on experience with the Math Faculty's UNIX environment
1063     in this tutorial.
1064    </p>
1065    <p>Topics that will be discussed include:</p>
1066    <ul>
1067     <li>Interacting with Bourne and C shells</li>
1068     <li>Editing text using the vi text editor</li>
1069     <li>Editing text using the Emacs display editor</li>
1070     <li>Multi-tasking and the screen multiplexer</li>
1071    </ul>
1072    <p>
1073      If you do not have a Math computer account, don't panic; one will
1074      be lent to you for the duration of this class.
1075    </p>
1076   </abstract>
1077  </eventitem>
1078  <eventitem date="2002-03-01" time="5:00 PM" room="MC4060"
1079   title="Computer Go, The Ultimate">
1080   <short>Thomas Wolf from Brock University will be holding a talk on
1081   the asian game of Go. All are welcome.</short>
1082   <abstract>
1083    <p>
1084     The asian game go is unique in a number of ways. It is the oldest
1085     board game known. It is a strategy game with very simple
1086     rules. Computer programs are very weak despite huge efforts and
1087     prizes of US$ &gt; 1.5M for a program beating professional
1088     players. The talk will quickly explain the rules of go, compare go
1089     and chess, mention various attempts to program go and describe our
1090     own efforts in this field. Students will have an opportunity to
1091     solve computer generated go problems. Prizes will be available.
1092    </p>
1093   </abstract>
1094  </eventitem>
1095
1096   <!-- Spring 2002 -->
1097
1098   <eventitem date="2002-05-11" time="7:00 PM" room="MC3036" title="S02
1099     elections">
1100     <short>Come and vote for this term's exec</short>
1101     <abstract>
1102       <p>
1103         Vote for the exec this term. Meet at the CSC office.
1104       </p>
1105     </abstract>
1106   </eventitem>
1107
1108
1109   <!-- Fall 2002 -->
1110
1111   <eventitem date="2002-09-16" time="5:30 PM" room="Comfy lounge"
1112   title="F02 elections">
1113     <short>Come and vote for this term's exec</short>
1114     <abstract>
1115       <p>
1116         Vote for the exec this term. Meet at the comfy
1117         lounge. There will be an opportunity to obtain or renew
1118         memberships. This term's CRO is Siyan Li
1119         (s8li@csclub.uwaterloo.ca).
1120       </p>
1121     </abstract>
1122   </eventitem>
1123
1124   <eventitem date="2002-09-30" time="6:30 PM" room="Comfy lounge, MC3001"
1125   title="Business Meeting">
1126     <short>Vote on a constitutional change.</short>
1127     <abstract>
1128       <p>
1129          The executive has unanimously decided to try to change our
1130 constitution to comply with MathSoc policy.  The clause we are trying
1131 to change is the membership clause.  The following is the proposed new
1132 reading of the clause.
1133       </p>
1134       <p><i>
1135         In compliance with MathSoc regulations and in recognition of
1136 the club being primarily targeted at undergraduate students, full
1137 membership is open to all undergraduate students in the Faculty of
1138 Mathematics and restricted to the same.</i>
1139       </p>
1140
1141       <p>
1142         The proposed change is illustrated <a
1143         href="http://www.csclub.uwaterloo.ca/docs/constitution-change-20020920.html">on
1144         a web page</a>.
1145       </p>
1146
1147       <p>
1148         There will be a business meeting on 30 Sept 2002 at 18:30 in
1149         the comfy lounge, MC 3001. Please come and vote
1150       </p>
1151     </abstract>
1152   </eventitem>
1153
1154   <eventitem date="2002-09-26" time="5:30 PM" room="MC3006"
1155   title="UNIX 101">
1156     <short>First Steps with UNIX</short>
1157     <abstract>
1158       <p>
1159            Get to know UNIX and be the envy of your friends!
1160       </p>
1161       <p>
1162         This is the first in a series of seminars that cover the use
1163         of the UNIX Operating System.  UNIX is used in a variety of
1164         applications, both in academia and industy. We will provide
1165         you with hands-on experience with the Math Faculty's UNIX
1166         environment in this seminar.
1167       </p>
1168       <p>
1169         Topics that will be discussed include:
1170       </p>
1171       <ul>
1172         <li>Navigating the UNIX environment</li>
1173         <li>Using common UNIX commands</li>
1174         <li>Using the PICO text editor</li>
1175         <li>Reading electronic mail and news with PINE</li>
1176       </ul>
1177       <p>
1178     If you do not have a Math computer account, don't panic; one will be 
1179 lent to you for the duration of this class.
1180       </p>
1181     </abstract>
1182   </eventitem>
1183
1184   <eventitem date="2002-10-01" time="6:30 PM-9:30 PM" room="The Bomber"
1185   title="Pints with the Profs">
1186     <short>Get to know your profs and be the envy of your friends!</short>
1187     <abstract>
1188     <p>Come out and meet your professors.  This is a great opportunity to
1189 meet professors for Undergraduate Research jobs or to find out who you might
1190 have for future courses.</p>
1191
1192     <p>Profs who have confirmed their attendance are:</p>
1193     <ul>
1194       <li>Troy Vasiga, School of Computer Science</li>
1195       <li>J.P. Pretti, St. Jerome's and School of Computer Science</li>
1196       <li>Michael McCool, School of Computer Science, CGL</li>
1197       <li>Martin Karsten, School of Computer Science, BBCR</li>
1198       <li>Gisli Hjaltason, School of Computer Science, DB</li>
1199     </ul>
1200
1201     <p>There will also be...</p>
1202     <ul>
1203       <li>Free Food</li>
1204       <li>Free Food</li>
1205       <li>Free Food</li>
1206     </ul>
1207     </abstract>
1208   </eventitem>
1209
1210   <eventitem date="2002-10-03" time="5:30 PM" room="MC3006"
1211   title="UNIX 102">
1212     <short>Talking to your UNIX can be fun and profitable.</short>
1213     <abstract>
1214 <p>This is the second in a series of seminars that cover the use of
1215 the UNIX Operating System. UNIX is used in a variety of applications,
1216 both in academia and industry. We will provide you with hands-on
1217 experience with the Math Faculty's UNIX environment in this
1218 tutorial.</p>
1219
1220 <p>Topics that will be discussed include:</p>
1221 <ul><li>Interacting with Bourne and C shells</li>
1222 <li>Editing text using the vi text editor</li>
1223 <li>Editing text using the Emacs display editor</li>
1224 <li>Multi-tasking and the screen multiplexer</li>
1225 </ul>
1226
1227 <p>If you do not have a Math computer account, don't panic; one will be
1228 lent to you for the duration of this class.</p>
1229
1230 </abstract>
1231   </eventitem>
1232
1233   <eventitem date="2002-10-08" time="4:30PM" room="MC4045"
1234   title="Video cards, Linux display drivers and the Kernel Graphics Interface (KGI)">
1235     <short>A talk by Filip Spacek, KGI developer</short>
1236     <abstract>
1237     Linux has proven itself as a reliable operating system but arguably,
1238     it still lacks in support of high performance graphics
1239     acceleration. This talk will describe basic components of a PC video
1240     card and the design and limitations the current Linux display driver
1241     architecture.  Finally a an overview of a new architecture, the Kernel
1242     Graphics Interface (KGI), will be given.  KGI attempts to solve the
1243     shortcomings of the current design, and provide a lightweight and
1244     portable interface to the display subsystem.
1245     </abstract>
1246   </eventitem>
1247
1248   <eventitem date="2002-10-10" time="5:30pm" room="MC3006"
1249   title="UNIX 103">
1250     <short></short>
1251     <abstract>No abstract available yet.</abstract>
1252   </eventitem>
1253
1254   <eventitem date="2002-11-05" time="4:30 PM" room="MC 2065"
1255   title="The Evil Side of C++">
1256     <short>Abusing template metaprogramming in C++; aka. writing a
1257     Mandelbrot generator that runs at compile time</short>
1258     <abstract>
1259       <p>Templates are a useful feature in C++ when it comes to writing
1260     type-independent data structures and algorithms. Relatively soon
1261     after their appearance it was realised that they could be used to
1262     do much more than this. Essentially it is possible to write
1263     certain programs in C++ that execute <i>completely at compile
1264     time</i> rather than run time. Combined with constant-expression
1265     optimisation this is an interesting twist on regular C++
1266     programming.</p>
1267     <p>This talk will give a short overview of the features of
1268     templates and then go on to describe how to &quot;abuse&quot;
1269     templates to perform complex computations at compile time. The
1270     speaker will present three programs of increasing complexity which
1271     execute at compile time. First a factorial listing program, then a
1272     prime listing program will be presented. Finally the talk will
1273     conclude with the presentation of a <b>Mandelbrot generator running
1274     at compile time</b>.</p>
1275
1276     <p>If you are interested in programming for the fun of it, the C++
1277     language or silly tricks to do with languages, this talk is for
1278     you. No C++ knowledge should be necessary to enjoy this talk, but
1279     programming experience will make it more worthwile for you.</p>
1280
1281     </abstract> </eventitem>
1282
1283   <eventitem date="2002-11-02" time="11:00AM-3:00PM"
1284     room="MC3002 (Math Coffee and Donut Store)"
1285     title="GNU/Linux InstallFest with KW-LUG and UW-DIG">
1286     <short>Bring over your computer and we'll help you install GNU/Linux</short>
1287     <abstract>
1288       <p>The <a href="http://www.csclub.uwaterloo.ca/">CSC</a>, the <a
1289       href="http://www.kwlug.org/">KW-Linux User Group</a>, and the <a
1290       href="http://uw-dig.uwaterloo.ca/">UW Debian Interest Group</a>
1291       are jointly hosting a GNU/Linux InstallFest.  GNU/Linux is a
1292       powerful, free operating system for your computer.  It is mostly
1293       written by talented volunteers who like to share their efforts
1294       and help each other.</p>
1295
1296       <p>Perhaps you have are you interested in installing GNU/Linux.
1297       If so, bring your computer, monitor and keyboard; and we will
1298       help you install GNU/Linux on your machine.  You can also find
1299       knowledgable people who can answer your questions about
1300       GNU/Linux.</p>
1301
1302       <hr />
1303
1304       <h3>Frequently Asked Questions</h3>
1305
1306 <p><b>Q: </b>What is GNU/Linux?<br />
1307 <b>A: </b>GNU/Linux is a free operating system for your computer.  It is mostly
1308    written by talented volunteers who like to share their efforts.
1309 </p>
1310
1311 <p><b>Q: </b>Free?<br />
1312 <b>A: </b>GNU/Linux is available for zero-cost.  As well, it allows you such
1313    freedom to share it with your friends, or to modify the software to
1314    your own needs and share that with your friends.  It's very friendly.
1315 </p>
1316
1317 <p><b>Q: </b>What is an InstallFest?<br />
1318 <b>A: </b>An InstallFest is a meeting where volunteers help people install
1319    GNU/Linux on their computers.  It's also a place to meet users, and
1320    talk to them about running GNU/Linux.
1321 </p>
1322
1323 <p><b>Q: </b>What kind of computer do I need to use GNU/Linux?<br />
1324 <b>A: </b>Almost any recent computer will do.  If you have an old machine
1325    kicking around, you can install GNU/Linux on it as well.  If it is
1326    at least 5 years old, it should be good enough.
1327 </p>
1328
1329 <p><b>Q: </b>Can I have Windows and GNU/Linux on the same computer?<br />
1330 <b>A: </b>If you can run Windows now, and you have an extra gigabyte (GB) of
1331    disk space to spare; then it should be possible.
1332 </p>
1333
1334 <p><b>Q: </b>What should I bring if I want to install GNU/Linux?<br />
1335 <b>A: </b>You will want to bring:</p>
1336 <ol>
1337 <li>Computer</li>
1338 <li>Monitor and monitor cable</li>
1339 <li>Power cords</li>
1340 <li>Keyboard and mouse</li>
1341 </ol>
1342
1343     </abstract>
1344   </eventitem>
1345
1346   <eventitem date="2002-11-07" time="5:30pm" room="MC4063"
1347   title="The GNU General Public License">
1348     <short>The teeth of Free Software</short>
1349     <abstract>
1350 <p>
1351 <blockquote>
1352 <i>
1353 The licenses for most software are designed to take away your freedom
1354 to share and change it. By contrast, the GNU General Public License
1355 is intended to guarantee your freedom to share and change free
1356 software---to make sure the software is free for all its users.
1357 </i><br/>--- Excerpt from the GNU GPL
1358 </blockquote>
1359 </p>
1360 <p>The GNU General Public License is one of the most influencial
1361 software licenses in this day.  Written by Richard Stallman for the
1362 GNU Project, it is used by software developers around the world to
1363 protect their work.
1364 </p>
1365 <p>
1366 Unfortunately, software developers do not read licenses thoroughly, nor
1367 well.  In this talk, we will read the entire GNU GPL and explain the
1368 implications of its passages.  Along the way, we will debunk some myths
1369 and clarify common misunderstandings.
1370 </p>
1371 <p>
1372 After this session, you ought to understand what the GNU GPL means, how
1373 to use it, and when you cannot use it.  This session should also give
1374 you some insight into the social implications of this work.
1375 </p>
1376     </abstract>
1377   </eventitem>
1378
1379   <eventitem date="2002-11-19" time="4:30pm" room="MC4058"
1380    title="Metaprogramming GPUs">
1381    <short>A talk by Michael McCool of the Computer Graphics Lab.</short>
1382    <abstract>
1383 <p>
1384 Modern graphics accelerators, or "GPUs", have embedded high-performance 
1385 programmable components in the form of vertex and fragment shading units. 
1386 Recently, these units have evolved from 8-bit computations to floating-point,
1387 and other operations provide array gather, scatter, and summation.
1388 These capabilities make GPUs akin to array processors of the 
1389 past, but with a difference: every PC now has one!  I am interested 
1390 in finding the best way to exploit this computational capacity for not
1391 only graphics but for general-purpose computation.
1392 </p><p>
1393 Current APIs permit specification of the programs for GPUs
1394 using an assembly-language level interface.  Compilers for high-level 
1395 shading languages are available, such as NVIDIA's Cg, and OpenGL 2.0 and 
1396 DirectX will also include standardized shading languages.  This talk will 
1397 review these.  However, compilers for these languages read in an external 
1398 string specification, which can be inconvenient.   
1399 </p><p>
1400 However, it is possible, using standard C++, to define a high-level
1401 shading language directly in the API.  Such a language can be nearly
1402 indistinguishable from a special-purpose programming language, yet  
1403 permits more direct interaction with the specification of textures 
1404 (arrays) and parameters, simplifies implementation, and enables
1405 on-the-fly generation, manipulation, and specialization of shader programs.
1406 A shading language built into the API also permits the lifting of
1407 C++ host language type, modularity, and scoping constructs into the shading
1408 language without any additional implementation effort.   Such an
1409 embedded language could be used to program other embedded processors
1410 (such as DSP chips in sound cards) or even to generate machine language
1411 on the fly for the host CPU.
1412 </p>
1413     </abstract>
1414   </eventitem>
1415
1416   <eventitem date="2002-11-16" time="1:30pm" room="York University"
1417   title="Trip to York University">
1418     <short>Going to visit the York University Computer Club</short>
1419     <abstract><p>YUCC and the UW CSC have having a join meeting at York 
1420 University.  Dave Makalsky, the President of YUCC, will be giving a talk on 
1421 Design-by-constract and Eiffel.  Stefanus Du Toit, Vice-President of the UW 
1422 CSC, will be giving a talk on the evil depths of the black art known as C++.
1423 </p><p>Schedule</p>
1424 <ul><li>1:30pm: Leave UW</li>
1425 <li>3:00pm: Arrive at York University.</li>
1426 <li>3:30pm: The Evil side of C++</li>
1427 <li>4:30pm: Design-by-Contract and Eiffel</li>
1428 <li>6:00pm: Dinner</li>
1429 <li>9:00pm: Arrive back at UW</li>
1430 </ul>
1431 </abstract>
1432   </eventitem>
1433
1434   <eventitem date="2002-11-21" time="6:00pm" room="MC2066"
1435   title="Perl 6">
1436     <short>A talk by Simon Law</short>
1437     <abstract>
1438       <p>
1439         Perl, the Practical Extraction and Reporting Language can only
1440         be described as an eclectic language, invented and refined by
1441         a deranged system administrator, who was trained as a
1442         linguist.  This man, however, has declared:
1443       </p>
1444       <blockquote>
1445         <i>
1446           Perl 5 was my rewrite of Perl.
1447           I want Perl 6 to be the community's rewrite of Perl and of the
1448           community.
1449         </i><br/>--- Larry Wall
1450       </blockquote>
1451       <p>
1452         Whenever a language is designed by a committee, it is common
1453         wisdom to avoid it.  Not so with Perl, for it cannot get
1454         worse.  However strange these Perl people seem, Perl 6 is a
1455         good thing coming.  In this talk, I will demonstrate some Perl
1456         5 programs, and talk about their Perl 6 counterparts, to show
1457         you that Perl 6 will be cleaner, friendlier, and prettier.
1458       </p>
1459     </abstract>
1460   </eventitem>
1461
1462   <eventitem date="2002-11-21" time="4:30pm" room="MC2066"
1463    title="Samba and You">
1464     <short>A talk by Dan Brovkovich, Mathsoc's Computing Director</short>
1465     <abstract><p>
1466 Samba is a free implementation of the Server Message Block (SMB)
1467 protocol. It also implements the Common Internet File System (CIFS)
1468 protocol, used by Microsoft Windows 95/98/ME/2000/XP to share files and
1469 printers. </p><p>
1470 SMB was originally developed in the early to mid-80's by IBM and was
1471 further improved by Microsoft, Intel, SCO, Network Appliances, Digital
1472 and many others over a period of 15 years. It has now morphed into CIFS,
1473 a form strongly influenced by Microsoft. </p><p>
1474 Samba is considered to be one of the key projects for the acceptance of
1475 GNU/Linux and other Free operating systems (e.g. FreeBSD) in the
1476 corporate world: a traditional Windows NT/2000 stronghold. </p><p>
1477 We will talk about interfacing Samba servers and desktops with the
1478 Windows world.  From a simple GNU/Linux desktop in your home to the
1479 corporate server that provides collaborative file/printer sharing,
1480 logons and home directories to hundreds of users a day. </p>
1481     </abstract>
1482   </eventitem>
1483
1484   <eventitem date="2002-10-26" time="1:30PM" room="MC2066"
1485   title="GNU/Linux on HPPA">
1486     <short>Carlos O'Donnell talks about &quot;the last of the legacy processors to fall before the barbarian horde&quot;</short>
1487     <abstract>
1488 <p>This whirlwind talk is aimed at providing an overview of the
1489 GNU/Linux port for the HP PARISC processor. The talk will focus on
1490 the &quot;intricacies&quot; of the processor, and in particular the
1491 implementations of the Linux kernel and GNU Libc. After the talk
1492 you should be acutely aware of how little code needs to be written
1493 to support a new architecture! Carlos has been working on the port
1494 for two years, and enjoying the fruits of his labour on a 46-node
1495 PARISC cluster.</p>
1496
1497 <hr />
1498 <p>
1499 Carlos is currently in his 5th year of study at the University
1500 of Western Ontario. This is his last year in a concurrent
1501 Computer Engineering and Computer Science degree. His research
1502 interest range from distributed and parallel systems to low
1503 level optimized hardware design. He likes playing guitar and
1504 just bought a Cort NTL-20, jumbo body, solid spurce top with
1505 a mahogany back. Carlos hacks on the PARISC Linux kernel, GNU libc,
1506 GNU Debugger, GNU Binutils and various Debian packages.
1507 </p>
1508
1509
1510 </abstract>
1511   </eventitem>
1512
1513   <eventitem date="2002-10-26" time="3:00PM" room="MC2066"
1514   title="The Hurd Interfaces">
1515     <short>Marcus Brinkmann, a GNU Hurd developer, talks about the Hurd server interfaces, at the heart of a GNU/Hurd system</short>
1516     <abstract>
1517 <p>The Hurd server interfaces are at the heart of the Hurd system.  They
1518  define the remote procedure calls (RPCs) that are used by the servers, the
1519  GNU C library and the utility programs to communicate with the Hurd system
1520  and to implement the POSIX personality of the Hurd as well as other
1521  features.</p>
1522
1523 <p>This talk is a walk through the Hurd RPCs, and will give an overview of how
1524  they are used to implement the system.  Individual RPCs will be used to
1525  illustrate important or exciting features of the Hurd system in general,
1526  and it will be shown how those features are accessible to the user at the
1527  command line, too.</p>
1528
1529  <hr />
1530
1531  <p>Marcus Brinkmann is a math student at the Ruhr-Universitaet Bochum in
1532  Germany.  He is one of maintainers of the GNU Hurd project and the
1533  initiator of the Debian GNU/Hurd binary distribution.  He designed and
1534  implemented the console subsystem of the Hurd, wrote the FAT filesystem
1535  server, and fixed a lot of bugs, thus increasing the stability and
1536  usability of the system.</p>
1537
1538     </abstract>
1539   </eventitem>
1540
1541   <eventitem date="2002-10-26" time="4:30PM" room="MC2066"
1542   title="A GNU Approach to Virtual Memory Management in a Multiserver Operating System">
1543     <short>Neal Walfield, a GNU Hurd developer, talks about a possible Virtual Memory Management subsystem for the GNU Hurd</short>
1544     <abstract>
1545 <p>Virtual memory management is one of the cornerstones of multiuser
1546 operating systems.  Most systems available today place all of the
1547 policy in a monolithic virtual memory manager, VMM, isolated from the
1548 rest of the system.  Although secure and lightweight, users have no
1549 way to communicate their anticipated memory needs and usage to the
1550 system pager.  As a result, the VMM can only implement a global paging
1551 policy (typically, an approximation of LRU) which may be good on
1552 average but is best for nobody.</p>
1553
1554 <p>With the port of Hurd to the L4 microkernel, this situation is being
1555 readdressed.  Due to its more distributed nature, a centralized
1556 resource manager is not only more difficult to implement efficiently
1557 but also contrary to the philosophy of the rest of the system.  We are
1558 currently exploring a model whereby each program is fully self-paged
1559 and all compete for memory from a physical memory server.  This talk
1560 will first discuss how paging currently works in Mach and other
1561 systems.  An argument for an external paging policy will then be
1562 presented followed by the requirements of such a design and the design
1563 itself.</p>
1564
1565 <hr />
1566
1567 <p>Neal Walfield, a GNU Hurd developer, is from the University of Massachusetts
1568 Lowell.  Neal spent the summer of 2002 at University of Karlsruhe working
1569 on porting the GNU Hurd to L4.</p>
1570
1571     </abstract>
1572   </eventitem>
1573
1574   <eventitem date="2002-10-17" time="5:30PM" room="MC2065"
1575   title="Debian in the Enterprise">
1576     <short>A talk by Simon Law</short>
1577     <abstract>
1578 <p>The Debian Project produces a &quot;Universal Operating System&quot; that is
1579 comprised entirely of Free Software.  This talk focuses on using Debian
1580 GNU/Linux in an enterprise environment.  This includes:</p>
1581 <ul>
1582   <li>Where Debian can be deployed</li>
1583   <li>Strategic advantages of Debian</li>
1584   <li>Ways for business to give back to Debian</li>
1585 </ul>
1586    </abstract>
1587   </eventitem>
1588
1589   <eventitem date="2002-11-12" time="4:30PM" room="MC4058"
1590   title="Automatic Memory Management and Garbage Collection">
1591     <short>A talk by James A. Morrison</short>
1592     <abstract>
1593 <p>
1594   Do you ever wonder what java is doing while you wait?  Have you ever used
1595 Modula-3?  Do you wonder how lazily you can Mark and Sweep?  Would you like to
1596 know how to Stop-and-Copy?
1597 </p><p>
1598  Come out to this talk and learn these things and more.  No prior knowledge of
1599 Garbage Collection or memory management is needed.
1600 </p>
1601    </abstract>
1602   </eventitem>
1603
1604 </eventdefs>
1605