CIS 351

Project 1: Build an Adder

Winter 2021

For this project, you will use JLS to implement a signed adder.

You should work in teams of two. This project is a lot of work. Working alone is foolish.

Begin by following this GitHub Classroom link to create the repository for this project. You may want to copy your unsigned adder from the lab into this new repo.

Task

Implement a 16-bit signed adder using any algorithm you wish, provided the circuit has a reasonable running time and size. Faster adders will receive more points. (See Grading section below.) Your adder must report overflow conditions when they occur (with respect to signed inputs). Notice that this circuit must have an input named CarryIn. You will use this input for future projects.

The starter code contains a file named SignedAdder_16bit.jls. You must place your solution in this file. Do not change the names of any of the inputs or outputs. (If you change the filename or the names of any inputs/outputs, the automated tests will not work.))

CarryOut is the carry out from the last full adder. It is also, in effect, the overflow indicator for unsigned inputs. Overflow is the overflow indicator for signed inputs. Remember, CarryOut and Overflow will not necessarily have the same value.

You may use SampleSigned16BitAdderTest.java as a basis for your own tests. Warning! This test file is incomplete. Don't assume that a circuit that passes this sample test will pass all of my tests.

Rules

  1. You are strongly encouraged to work in groups of two. You may work alone only with permission of the instructor.
  2. You may use your unsigned adder from the lab.
  3. The simulator comes with a built-in adder. You may not use the built-in adder.
  4. To build the required circuits, you will probably find it useful to design and build several subcircuits. These subcircuits may have any interface you choose; however, you are responsible for testing them.
  5. You must write all of your own chips. In other words, you may not share "internal" chips with your classmates, or download them off the Internet.
  6. Be sure to test your components thoroughly. Just because it passes the test included here doesn't mean it will pass my test.

Hints and shortcuts

Grading

This assignment will be scored out of 100 points.

Category Rubric Maximum Score
Functionality
Not attempted 0
Substantially complete, but passes no tests 15
Passes a few tests 25
Correctly adds positive integers only 45
Correctly adds positive and negative integers
(but overflow does not work correctly)
55
Passes all tests 65
Date 100% correct
Two days early 12
One day early 11
On time 10
One day late 8
(-2 per day) ...
Five or more days late 0
Date output correct
On time 10
One day late 8
(-2 per day) ...
Five or more days late 0
Speed
≤ 75 9
≤ 125 8
≤ 175 7
≤ 225 6
≤ 275 5
≤ 300 3
> 300 0
Presentation
Size and Speed* 5

*For 5 points, correctly specify the exact number of gates used by your adder (the total number of gates, including all sub-circuits) and the time required by your adder (i.e., the sum of all the gate delays along the critical path).

Penalties

Deliverables

To submit your project:

  1. Add a text box to your jls files that includes the names of all team members.
  2. Your adder should also include a label indicating time and gate count. The time should be the maximum simulation needed for any addition. (I'm looking for an actual number, not a big-O expression.)
  3. When your adder passes the automated tests, and contains the time/size information, push your project with [Grade Me] in the commit message.

Updated Monday, 28 December 2020, 6:03 PM

W3c Validation