CSCI B441 / ENGR E315 Syllabus
This 3-credit* course provides a strong foundation for modern digital system design using hardware description languages. We start with basics of digital electronics and learn how digital gates are used to build large digital systems. We will practice modern digital system design by using state of the art software tools and implementation of the digital systems on a programmable hardware platform. At the end of the course, students will be familiar with modern approach for designing digital systems, using hardware description languages along with an appropriate methodology.
* 4-credit for CSCI-B441.
2032 Luddy Hall
Lecture: 09:30A-10:45A Tues/Thurs IF 4111
Lab: 01:25P-02:15P Friday IF 4111
Computer Science: CSCI-C 335 Computer Structures
Engineering: ENGR E101 and ENGR E221
Digital Design: An Embedded Systems Approach Using Verilog, Peter J. Ashenden, Elsevier, Morgan Kauffman, ISBN-13: 978-012369527.
Electronic copies are available at the library. Other materials will be provided on the course website.
Over the course of the semester, we will assign multiple programming projects. Full points will requires these projects be submitted to the autograder and be demonstrated on the FPGA to the TA. Initially, they will be due 1 week after they are assigned, but the deadlines will gradually increase to several weeks.
Assignments turned in after the exact time and date on the assignment will receive a zero. We do not generally offer extensions. For example, we do not offer extensions due to crowded computing sites, long queue times or slow response times on the autograder, internet access problems, accidental erasure or loss of files, or outside conflicting commitments.
We will consider extension requests made in person and at least two weeks in advance, for example, for religious holidays or planned medical procedures. Additionally, we will consider requests for extensions due to documented, unanticipated medical or personal emergencies. If you can't see the instructor in advance due to the emergency, then contact them as soon as you possibly can. In all cases, we require written proof of the emergency.
Your final grade is based on scores from programming projects and two exams. The tentative point distribution is included in the following table. It is not likely that this will change, but circumstances might occur which would make changes necessary, at the discretion of the instructor. Once the grades are posted, you will have one week to appeal the grade.
We will grade your programs in an autograder system that is similar to the Linux environment. Your code must be submitted, compile, and run correctly on the autograder before the deadline. We use a web-based autograder for project submissions. For some projects, the autograder will also evaluate the thoroughness of test cases you submit.
Note that for security reasons, the autograder website is only accessible from within the IU network. Therefore, you must either be on campus or connected through a VPN to access the website.
Autograder Link: https://autograder.sice.indiana.edu
We will be using Piazza to host a course forum. You are encouraged to read this regularly and post technical questions as it will be a significant source of help and hints on the projects. We do not answer technical questions via email. In order to save everyone time, we want all students to have the benefit of seeing each question and its answer, so please use the forum. We prohibit posting your own solutions, project code, test cases, or output to the forum.
Piazza Link: https://piazza.com/class/jkih6n5kn6c1xh
Learning difficult or complicated material is often facilitated by discussions between students and we encourage you to form study groups to try to solve difficult problems together.
However, exams and programming projects must be your own work. Do not cheat in any way: do your own work! Doing your own work means that you must turn in your own, original work. It means you do not turn in a solution copied from somebody else or found on the web. In programming projects, working together may extend to figuring out overall strategies for solution but you may not work together or share the actual code that you submit.
If you think you need an accommodation for a disability, please let your instructor know during
the first three weeks of the semester. Some aspects of this course may be modified to facilitate
your participation and progress. As soon as you make us aware of your needs, we can work
with the Office of Disability Services for Students (DSS) help us determine appropriate
academic accommodations. Any information you provide is private and confidential and will be treated as such.
We will post a Canvas announcement in the case of any critical corrections or clarifications. It is your responsibility to ensure you are able to receive Canvas announcements.