Warning: foreach() argument must be of type array|object, bool given in /var/www/html/web/app/themes/studypress-core-theme/template-parts/header/mobile-offcanvas.php on line 20

Problem 5

Use XDR and htonl to encode a 1000 -element array of integers. Measure and compare the performance of each. How do these compare to a simple loop that reads and writes a 1000-element array of integers? Perform the experiment on a computer for which the native byte order is the same as the network byte order, as well as on a computer for which the native byte order and the network byte order are different.

Problem 6

Write your own implementation of htonl. Using both your own htonl and (if little-endian hardware is available) the standard library version, run appropriate experiments to determine how much longer it takes to byte-swap integers versus merely copying them.

Problem 12

The presentation formatting process is sometimes regarded as an autonomous protocol layer, separate from the application. If this is so, why might including data compression in the presentation layer be a bad idea?

Problem 14

Using the programming language of your choice that supports user-defined automatic type conversions, define a type netint and supply conversions that enable assignments and equality comparisons between ints and netints. Can a generalization of this approach solve the problem of network argument marshalling?

Problem 16

Let \(p \leq 1\) be the fraction of machines in a network that are big-endian; the remaining \(1-p\) fraction are little-endian. Suppose we choose two machines at random and send an int from one to the other. Give the average number of byte-order conversions needed for both big-endian network byte order and receiver-makes-right, for \(p=0.1, p=0.5\), and \(p=0.9\). Hint: The probability that both endpoints are big-endian is \(p^{2} ;\) the probability that the two endpoints use different byte orders is \(2 p(1-p)\).

Problem 18

Suppose a file contains the letters \(a, b, c\), and \(d\). Nominally, we require 2 bits per letter to store such a file. (a) Assume the letter \(a\) occurs \(50 \%\) of the time, \(b\) occurs \(30 \%\) of the time, and \(c\) and \(d\) each occur \(10 \%\) of the time. Give an encoding of each letter as a bit string that provides optimal compression. Hint: Use a single bit for \(a\). (b) What is the percentage of compression you achieve above? (This is the average of the compression percentages achieved for each letter, weighted by the letter's frequency.) (c) Repeat this, assuming \(a\) and \(b\) each occur \(40 \%\) of the time, coccurs \(15 \%\) of the time, and \(d\) occurs \(5 \%\) of the time.

Problem 19

Suppose we have a compression function \(c\), which takes a bit string \(s\) to a compressed string \(c(s)\). (a) Show that for any integer \(N\) there must be a string \(s\) of length \(N\) for which length \((c(s)) \geq N\); that is, no effective compression is done. (b) Compress some already compressed files (try compressing with the same utility several times in sequence). What happens to the file size? (c) Given a compression function \(c\) as in (a), give a function \(c^{\prime}\) such that for all bit strings \(s\), length \(\left(c^{\prime}(s)\right) \leq \min (\) length \((c(s))\), length \((s))+1\); that is, in the worst case, compression with \(c^{\prime}\) expands the size by only 1 bit.

Problem 21

Write a program to construct a dictionary of all "words," defined to be runs of consecutive nonwhitespace, in a given text file. We might then compress the file (ignoring the loss of whitespace information) by representing each word as an index in the dictionary. Retrieve the file rfc791.txt containing [Pos81], and run your program on it. Give the size of the compressed file assuming first that each word is encoded with 12 bits (this should be sufficient), and then that the 128 most common words are encoded with 8 bits and the rest with 13 bits. Assume that the dictionary itself can be stored by using, for each word, length(word) + 1 bytes.

Problem 29

Suppose you want to implement fast-forward and reverse for MPEG streams. What problems do you run into if you limit your mechanism to displaying I frames only? If you don't, then to display a given frame in the fast-forward sequence, what is the largest number of frames in the original sequence you may have to decode?

Problem 32

Suppose we have a video of two white points moving toward each other at a uniform rate against a black background. We encode it via MPEG. In one I frame the two points are 100 pixels apart; in the next I frame they have merged. The final point of merger happens to lie at the center of a \(16 \times 16\) macroblock. (a) Describe how you might optimally encode the Y component of the intervening B (or P) frames. (b) Now suppose the points are in color, and that the color changes slowly as the points move. Describe what the encoding of the U and V values might look like.

Access millions of textbook solutions in one place

  • Access over 3 million high quality textbook solutions
  • Access our popular flashcard, quiz, mock-exam and notes features
  • Access our smart AI features to upgrade your learning
Get Vaia Premium now
Access millions of textbook solutions in one place

Recommended explanations on Computer Science Textbooks