HariLogicSeldon / CS61c

All Coursework from my CS61c (Great Ideas in Computer Architecture / Machine Structures) Course at UC Berkeley

Geek Repo:Geek Repo

Github PK Tool:Github PK Tool

CS61c - Great Ideas in Computer Architecture / Machine Structures

This repository contains all of my coursework from the CS61c Course at UC Berkeley. I completed the course in the Summer of 2015. The projects were completed primarily in C and MIPS, and we used Logisim (a circuit design application) for the CPU design project.

Course Website: http://www-inst.eecs.berkeley.edu/~cs61c/su15/

Projects Completed:

(1) Beargit - A simple implementation of git, with the only supported commands being init, add, rm, comit, branch, checkout, status, and log (written in C, with starting code being provided to us) -- http://www-inst.eecs.berkeley.edu/~cs61c/su15/projs/01/

(2) MIPS Assembler / Linker - A two-part project that involved (a)writing an assembler that translates a subset of the MIPS instructure set to machine code and (b) implementing a linker that processes the machine code and generates an executable file --

Project 2.1: http://www-inst.eecs.berkeley.edu/~cs61c/su15/projs/02/

Project 2.2: http://www-inst.eecs.berkeley.edu/~cs61c/su15/projs/03/

(3) ALU / Regfile and CPU Design - A two-part project where we used the Logisim application to implement a simple 32-bit two-cycle processor; the first part involved implementing the Regfile and ALU (which take in the MIPS instruction opcodes and register numbers to execute calculations) and the second part involved completing the pipelined processor (dealing with jumps, stalling the pipelines when necessary, etc.) --

Project 3.1: http://www-inst.eecs.berkeley.edu/~cs61c/su15/projs/04/

Project 3.2: http://www-inst.eecs.berkeley.edu/~cs61c/su15/projs/05/

(4) Performance Optimization / Convolutional Neural Networks - An application of performance optimizations techniques learn in class to speed up the proces of image classification using a CNN (focus was specifically on using unrolling, SIMD instructions, OpenMP parallelization, and other optimizations to improve the speed of the program) -- http://www-inst.eecs.berkeley.edu/~cs61c/su15/projs/06/

About

All Coursework from my CS61c (Great Ideas in Computer Architecture / Machine Structures) Course at UC Berkeley


Languages

Language:C 53.2%Language:Assembly 20.0%Language:Python 8.9%Language:JavaScript 5.9%Language:Java 5.1%Language:HTML 3.6%Language:Makefile 2.2%Language:Shell 1.0%Language:C++ 0.0%