Wed Dec 1 15:24:17 EST 2004
This is a rough summary of the topics that we have covered in class. It doesn't include material in problem sets or labs. You are responsible for important ideas and facts in those as well, though not for detailed trivia like how to write syntactically correct HTML or Javascript or how RSA really works.
Throughout, the emphasis is meant to be on understanding, which is usually tested through problems that require you to think and reason about something new or unfamiliar that is based on material covered. Often that reasoning is quantitative; the theory is that if you understand the material, you will be able to do the right computation to demonstrate your understanding. Sometimes the reasoning requires recognizing that some unfamiliar system or artifact is analogous to one seen in class. Sometimes it's just applying common sense and some of what you've learned.
Broadly, these are the kinds of topics that I hope you understand well enough to answer questions about:
Here's the outline:
HARDWARE prox cards and RFID systems logical/functional organization of a computer physical structure major pieces: cpu, memory, disks, peripheral devices, etc. acronyms and numbers: MHz, GHz, MB, RAM, ROM, Kbps prefixes: pico, nano, micro, milli, kilo, mega, giga, tera, peta, ... CPU operation arithmetic, memory access, decision making, control different processors intel vs mac vs palm pilot vs ... instructions; toy machine branching & conditional instructions fetch / decode / execute cycle instructions in same memory as data computer architecture caching in CPU and elsewhere von Neumann model of computer Turing equivalence of computers integrated circuit fabrication Moore's law exponential growth bits, bytes, representation of information analog versus digital binary numbers and arithmetic hexadecimal notation powers of two and powers of ten meaning of bits depends on context numbers of various sizes characters in various scripts machine instructions and addresses ascii and unicode color encoding and representation other kinds of computers SOFTWARE algorithms: defined operations, defined steps, terminates linear-time algorithms searching, selecting, summarizing binary search; divide and conquer; log n algorithms sorting quadratic (n^2), quicksort (n log n) complexity of algorithms (log n, n, n log n, n^2, n^3, ..., 2^n) what these complexity formulas mean towers of hanoi, traveling salesman problem, hard problems, P vs NP evolution of programming languages machine and assembly language high level languages: Fortran, C, C++, Java, Javascript, ... languages vs programming languages compilers, compilation executable files; interpretation and simulation Javascript variables and expressions assignment statements, alert, prompt, etc. if-else while loop functions how it works, but NOT detailed syntax operating systems history what they do: manage memory, run programs, file system applications vs operating systems system interface: system calls, APIs file systems directories/folders and files logical structure vs physical implementation file system implementation blocks, allocation table, free list finding files file open, save, delete, etc. what's remembered where for how long network file systems other file systems drivers bootstrapping Unix / Linux open source software programming in the real world bugs COMMUNICATIONS history ethernet, broadcast media Internet structure names, addresses, routing, protocols domain names, DNS caching IP addresses dotted decimal notation IP protocol unreliable datagrams packets TCP protocol reliable streams higher-level protocols: SSH, SMTP, HTTP layering, encapsulation bandwidth communications technologies Web url, http, html, browsers forms and cgi programs risks cookies, spam viruses, spyware active content, Javascript, Java, ActiveX attacks on clients, servers, networks denial of service defenses cryptography history secret key crypto: DES, AES public key crypto, digital signatures how browsers & servers do key exchange intellectual property patents & copyright DMCA compression lossless, lossy JPEG, MPEG, MP3 error detection & correction checksums, parity peer to peer networks wireless systems cell phones; other radio devices search engines