mirror of
https://github.com/soconnor0919/eceg431.git
synced 2025-12-11 06:34:43 -05:00
50 lines
1.7 KiB
Plaintext
50 lines
1.7 KiB
Plaintext
// This file is part of www.nand2tetris.org
|
|
// and the book "The Elements of Computing Systems"
|
|
// by Nisan and Schocken, MIT Press.
|
|
// File name: projects/12/Math.jack
|
|
/**
|
|
* A library of commonly used mathematical functions.
|
|
* All functions runs in O(n), where n is the number of bits used
|
|
* for representing a two's complement integer value (16 in the Hack computer).
|
|
* Note: Jack compilers implement multiplication and division
|
|
* using calls to OS functions in this class.
|
|
*/
|
|
class Math {
|
|
static int n; // Number of bits used for representing a two's complement integer
|
|
static Array powersOfTwo; // Stores 2^0, 2^1, 2^2,..., 2^(n-1)
|
|
|
|
// Initializes the Math library.
|
|
function void init() {
|
|
}
|
|
|
|
/** Returns the product of x and y.
|
|
* When a Jack compiler detects the multiplication operator '*'
|
|
* in an expression, it handles it by invoking this method.
|
|
* Thus, in Jack, x * y and Math.multiply(x,y) return the same value. */
|
|
function int multiply(int x, int y) {
|
|
}
|
|
|
|
/** Returns the integer part of x / y.
|
|
* When a Jack compiler detects the division operator '/'
|
|
* an an expression, it handles it by invoking this method.
|
|
* Thus, x/y and Math.divide(x,y) return the same value. */
|
|
function int divide(int x, int y) {
|
|
}
|
|
|
|
/** Returns the integer part of the square root of x. */
|
|
function int sqrt(int x) {
|
|
}
|
|
|
|
/** Returns the greater value. */
|
|
function int max(int a, int b) {
|
|
}
|
|
|
|
/** Returns the smaller value. */
|
|
function int min(int a, int b) {
|
|
}
|
|
|
|
/** Returns the absolute value of x. */
|
|
function int abs(int x) {
|
|
}
|
|
}
|