Week 02 Laboratory Exercises
Objectives
- to practice using C's bitwise operations
- to understand how integer values are represented
- to practice manipulating dynamic memory
- to explore working with binary-coded decimal values
- to explore arbitrary precision integer arithmetic
Preparation
Before the lab you should re-read the relevant lecture slides and their accompanying examples.
Getting Started
Create a new directory for this lab called lab02
,
change to this directory, and fetch the provided code for this week
by running these commands:
mkdir lab02 cd lab02 1521 fetch lab02
Or, if you're not working on CSE, you can download the provided code as a zip file or a tar file.
Exercise — in pairs:
Convert 16 Binary Digits to A Signed Number
Download sixteen_in.c here, or copy it to your CSE account using the following command:
cp -n /web/cs1521/19T3/activities/sixteen_in/files/sixteen_in.c .
Your task is to add code to this function in sixteen_in.c:
//
// given a string of binary digits ('1' and '0')
// return the corresponding signed 16 bit integer
//
int16_t sixteen_in(char *bits) {
// PUT YOUR CODE HERE
return 0;
}
Add code to the function sixteen_in
so that, given a
sixteen-character string containing an ASCII positional
representation of a binary number, it returns the corresponding
signed integer. For example:
./sixteen_in 0000000000000000 0 ./sixteen_in 1111111111111111 -1 ./sixteen_in 0011001100110011 13107 ./sixteen_in 1111000011110000 -3856
When you think your program is working, you can use
autotest
to run some simple automated tests:
1521 autotest sixteen_in
When you are finished working on this exercise, you and your lab
partner must both submit your work by running give
:
give cs1521 lab02_sixteen_in sixteen_in.c
Note, even though this is a pair exercise, you both must run
give
from your own account before
Wednesday 01 January 00:00
to obtain the marks for this lab exercise.
Exercise — in pairs:
Convert a 16-bit Signed Number to Binary Digits
Download sixteen_out.c here, or copy it to your CSE account using the following command:
cp -n /web/cs1521/19T3/activities/sixteen_out/files/sixteen_out.c .
Your task is to add code to this function in sixteen_out.c:
// given a signed 16 bit integer
// return a null-terminated string of 16 binary digits ('1' and '0')
// storage for string is allocated using malloc
char *sixteen_out(int16_t value) {
// PUT YOUR CODE HERE
}
Add code to the function sixteen_out
so that, given a
16-bit signed integer it returns a string containing sixteen binary
digits ('0'
or '1'
). For example:
./sixteen_out 0 0000000000000000 ./sixteen_out -1 1111111111111111 ./sixteen_out 13107 0011001100110011 ./sixteen_out -3856 1111000011110000
When you think your program is working, you can use
autotest
to run some simple automated tests:
1521 autotest sixteen_out
When you are finished working on this exercise, you and your lab
partner must both submit your work by running give
:
give cs1521 lab02_sixteen_out sixteen_out.c
Note, even though this is a pair exercise, you both must run
give
from your own account before
Wednesday 01 January 00:00
to obtain the marks for this lab exercise.
Exercise — in pairs:
Convert a 2 digit BCD Value to an Integer
Download bcd.c here, or copy it to your CSE account using the following command:
cp -n /web/cs1521/19T3/activities/bcd/files/bcd.c .
Your task is to add code to this function in bcd.c:
// given a BCD encoded value between 0 .. 99
// return corresponding integer
int bcd(int bcd_value) {
// PUT YOUR CODE HERE
return 0;
}
Add code to the function bcd
so that, given a 2 digit
Binary-Coded Decimal
(BCD) value, it returns the corresponding integer.
In binary-coded decimal format, each byte holds 1 decimal value (0 to 9), so each byte contains 1 decimal digit. For example:
./bcd 7 7 ./bcd 258 # 258 == 0x0102 12 ./bcd 1026 # 1026 == 0x0402 42
When you think your program is working, you can use
autotest
to run some simple automated tests:
1521 autotest bcd
When you are finished working on this exercise, you and your lab
partner must both submit your work by running give
:
give cs1521 lab02_bcd bcd.c
Note, even though this is a pair exercise, you both must run
give
from your own account before
Wednesday 01 January 00:00
to obtain the marks for this lab exercise.
Exercise — in pairs:
Convert an 8 digit Packed BCD Value to an Integer
Download packed_bcd.c here, or copy it to your CSE account using the following command:
cp -n /web/cs1521/19T3/activities/packed_bcd/files/packed_bcd.c .
Your task is to add code to this function in packed_bcd.c:
// given a packed BCD encoded value between 0 .. 99999999
// return the corresponding integer
uint32_t packed_bcd(uint32_t packed_bcd_value) {
// PUT YOUR CODE HERE
return 0;
}
Add code to the function packed_bcd
so that, given an
eight-digit
packed binary-coded decimal
value, it returns the corresponding integer.
In packed binary-coded decimal format, each 4 bits holds 1 decimal value (0 to 9), so each byte contains 2 decimal digits. For example:
./packed_bcd 66 # ... == 0x42 42 ./packed_bcd 39321 # ... == 0x9999 9999 ./packed_bcd 1111638594 # ... == 0x42424242 42424242
When you think your program is working, you can use
autotest
to run some simple automated tests:
1521 autotest packed_bcd
When you are finished working on this exercise, you and your lab
partner must both submit your work by running give
:
give cs1521 lab02_packed_bcd packed_bcd.c
Note, even though this is a pair exercise, you both must run
give
from your own account before
Wednesday 01 January 00:00
to obtain the marks for this lab exercise.
Exercise — in pairs:
Add 2 Arbitrary Length BCD Values
Download bcd_add.c here, or copy it to your CSE account using the following command:
cp -n /web/cs1521/19T3/activities/bcd_add/files/bcd_add.c .
Your task is to add code to this function in bcd_add.c:
big_bcd_t *bcd_add(big_bcd_t *x, big_bcd_t *y) {
// PUT YOUR CODE HERE
}
Add code to the function bcd_add
so that, given 2
arbitrary length
binary-coded decimal
numbers, it returns their sum. For example:
./bcd_add 123456789123456789 123456789123456789 246913578246913578 ./bcd_add 999999999999999999 1 1000000000000000000 ./bcd_add 777777777777777777777777777777777777 888888888888888888888888888888888888 1666666666666666666666666666666666665 ./bcd_add 987654321987654321987654321 98765987659876598765 987654420753641981864253086
When you think your program is working, you can use
autotest
to run some simple automated tests:
1521 autotest bcd_add
When you are finished working on this exercise, you and your lab
partner must both submit your work by running give
:
give cs1521 lab02_bcd_add bcd_add.c
Note, even though this is a pair exercise, you both must run
give
from your own account before
Wednesday 01 January 00:00
to obtain the marks for this lab exercise.
Challenge Exercise — individual:
Subtract, Multiply and Divide 2 Arbitrary Length BCD Values
Download bcd_arithmetic.c here, or copy it to your CSE account using the following command:
cp -n /web/cs1521/19T3/activities/bcd_arithmetic/files/bcd_arithmetic.c .
Add code to the functions
bcd_add
, bcd_subtract
,
bcd_multiply
, and bcd_divide
so that,
given two arbitrary-length
binary-coded decimal
(BCD) numbers, they return the result of the
corresponding arithmetic operation. For example:
./bcd_arithmetic 1123456789123456789 - 1123456789123456788 1 ./bcd_arithmetic 123456789123456789 '*' 123456789123456789 15241578780673678515622620750190521 ./bcd_arithmetic 15241578780673678515622620750190521 / 123456789123456789 123456789123456789 ./bcd_arithmetic 123456789 '*' 987654321 + 987654321 / 1234 121932631113435637 ./bcd_arithmetic 14 / 5 2
When you think your program is working, you can use
autotest
to run some simple automated tests:
1521 autotest bcd_arithmetic
When you are finished working on this exercise, you must submit your
work by running give
:
give cs1521 lab02_bcd_arithmetic bcd_arithmetic.c
You must run give
before Wednesday 01 January 00:00 to obtain the
marks for this lab exercise. Note that this is an individual
exercise, the work you submit with give
must be
entirely your own.
Submission
give
.
You can run give
multiple times. Only your last
submission will be marked.
Don't submit any exercises you haven't attempted.
If you are working at home, you may find it more convenient to upload your work via give's web interface.
Remember you have until Wednesday 01 January 00:00 to submit your work.
You cannot obtain marks by e-mailing your code to tutors or lecturers.
You check the files you have submitted here.
Automarking will be run by the lecturer several days after the
submission deadline, using test cases different to those
autotest
runs for you. (Hint: do your own testing as
well as runningautotest
.)
After automarking is run by the lecturer you can view your results here. The resulting mark will also be available via give's web interface.
Lab Marks
When all components of a lab are automarked you should be able to view the the marks via give's web interface or by running this command on a CSE machine:
1521 classrun -sturec