Processing math: 100%

The goal of this assignment is to deepen your understanding of loops and conditionals.

  1. Boolean and integer variables. Write a program Ordered.java that takes three integer command-line arguments, x, y, and z. Define a boolean variable whose value is true if the three values are either in strictly ascending order (x < y < z) or in strictly descending order (x > y > z), and false otherwise.
    % java Ordered 10 17 49
    true
    
    % java Ordered 49 17 10
    true
    
    % java Ordered 10 49 17
    false
    
    Do not use a conditional or loop (such as an if, while, or for statement) on this question.
  2. Type conversion and conditionals. Several different formats are used to represent color. For example, the primary format for LCD displays, digital cameras, and web pages—known as the RGB format—specifies the level of red (R), green (G), and blue (B) on an integer scale from 0 to 255. The primary format for publishing books and magazines—known as the CMYK format—specifies the level of cyan (C), magenta (M), yellow (Y), and black (K) on a real scale from 0.0 to 1.0.

    Write a program RGBtoCMYK.java that converts from RGB format to CMYK format. Your program should take three integer command-line arugments red, green, and blue; print the RGB values; then print the equivalent CMYK values using these mathematical formulas:

    white=max{red255,green255,blue255}cyan=(whitered255)÷whitemagenta=(whitegreen255)÷whiteyellow=(whiteblue255)÷whiteblack=1white

    Hint. Math.max(x, y) returns the maximum of x and y.

    % java RGBtoCMYK 75 0 130    // indigo
    red     = 75
    green   = 0
    blue    = 130
    cyan    = 0.423076923076923
    magenta = 1.0
    yellow  = 0.0
    black   = 0.4901960784313726
    
    % java RGBtoCMYK 255 143 0   // Princeton orange
    red     = 255
    green   = 143
    blue    = 0
    cyan    = 0.0
    magenta = 0.4392156862745098
    yellow  = 1.0
    black   = 0.0
    

    If the red, green, and blue values are each 0, the resulting color is black. Here is what your program should do:

    % java RGBtoCMYK 0 0 0       // black
    red     = 0
    green   = 0
    blue    = 0
    cyan    = 0.0
    magenta = 0.0
    yellow  = 0.0
    black   = 1.0
    
  3. Checkerboard. Write a program Checkerboard.java that takes an integer command-line argument n, and uses a nested for loop to print an n-by-n checkerboard pattern like the one below: a total of n 2 asterisks, where each row has 2n characters (alternating between asterisks and spaces).
    % java Checkerboard 4             % java Checkerboard 5
    * * * *                           * * * * *
     * * * *                           * * * * *
    * * * *                           * * * * *
     * * * *                           * * * * *
                                      * * * * *
    
  4. A drone's flight. A drone begins flying aimlessly, starting at Nassau Hall. At each time step, the drone flies one meter in a random direction, either north, east, south, or west, with probability 25%. How far will the drone be from Nassau Hall after n steps? This process is known as a two-dimensional random walk.
    1. Write a program RandomWalker.java that takes an integer command-line argument n and simulates the motion of a random walk for n steps. Print the location at each step (including the starting point), treating the starting point as the origin (0, 0). Also, print the square of the final Euclidean distance from the origin.
      % java RandomWalker 10         % java RandomWalker 20
      (0, 0)                        (0, 0)
      (0, -1)                       (0, 1)
      (0, 0)                        (-1, 1)
      (0, 1)                        (-1, 2)
      (0, 2)                        (0, 2)
      (-1, 2)                       (1, 2)
      (-2, 2)                       (1, 3)
      (-2, 1)                       (0, 3)
      (-1, 1)                       (-1, 3)
      (-2, 1)                       (-2, 3)
      (-3, 1)                       (-3, 3)
      squared distance = 10         (-3, 2)
                                    (-4, 2)
                                    (-4, 1)
                                    (-3, 1)
                                    (-3, 0)
                                    (-4, 0)
                                    (-4, -1)
                                    (-3, -1)
                                    (-3, -2)
                                    (-3, -3)
                                    squared distance = 18
      
      Random walk in the plane
    2. Write a program RandomWalkers.java that takes two integer command-line arguments n and trials. In each of trials independent experiments, simulate a random walk of n steps and compute the squared distance. Output the mean squared distance (the average of the trials squared distances).
      % java RandomWalkers 100 10000         % java RandomWalkers 400 2000
      mean squared distance = 101.446         mean squared distance = 383.12
      
      % java RandomWalkers 100 10000         % java RandomWalkers 800 5000
      mean squared distance = 99.1674         mean squared distance = 811.8264
      
      % java RandomWalkers 200 1000         % java RandomWalkers 1600 100000
      mean squared distance = 195.75          mean squared distance = 1600.13064
      

      As n increases, we expect the random walk to end up farther and farther away from the origin. But how much farther? Use RandomWalkers to formulate a hypothesis as to how the mean squared distance grows as a function of n. Use trials = 100,000 to get a sufficiently accurate estimate.

    This process is a discrete version of a natural phenomenon known as Brownian motion. It serves as a scientific model for an astonishing range of physical processes from the dispersion of ink flowing in water, to the formation of polymer chains in chemistry, to cascades of neurons firing in the brain.

Program style and format. Follow the guidelines in the Assignment FAQ. Is your header complete? Did you comment appropriately? Is your code indented consistently? Did you use descriptive variable names? Did you follow the input and output specifications? Are there any redundant conditions? Did you click the Check All Submitted Files button?

Submission. Submit the files Ordered.java, RGBtoCMYK.java, Checkerboard.java, RandomWalker.java, RandomWalkers.java, and a completed readme.txt file.