- 1 Class Attendance
- 2 Handin
- 3 Course Websites
- 4 CS Online Teaching
- 5 Syllabi
- 6 CS Programs Committee
- 7 Email Lists
- 8 Graduate admissions
- 9 Graduate student probation and dismissals
- 10 CS graduate assistants
- 11 ACM Club
- 12 Transfer credit
- 13 Academic Misconduct
- 14 Assessment
- 15 Programming assessment
- 16 CS 499
- 17 Undergraduate Admissions
- 18 2018-2019 Schedule
- 19 Email Messages
attendance.py is a script that can be used to extract attendance for CS courses that take place in A-017 and A-019. It will count a student as present as long as they logged in within 10 minutes of the start of class and logged out within 10 minutes of the end of class. To get started with attendance.py you can do the following.
mkdir ~/csXYZ cd ~/csXYZ cp ~cs151/attendance/murali/.attendance . attendance.py
Note - for this to work you need to have an ssh key installed. For that you can run
mkdir ~/.ssh cd ~/.ssh ssh-keygen -t ecdsa cp id_ecdsa.pub authorized_keys
Documentation is in man on the system. Read through the following
man handin man handin.config man ccu man igf
You need to have a course that was created for you with class accounts by Steve.
A short howto geared towards students is in the wiki here.
Using Steve's course website system (for faculty) -
cd ~/public_html mkdir csXYZ cd csXYZ cp -R ~sbaker/public_html/cst/* .
Then edit the files in ~/public_html/csXYZ.
- The information about the course will be in ~/public_html/csXYZ/config.json. You edit that file and make changes to individualize it to your course.
- Note that if you have syntax errors in config.json, the webpage won't render properly.
- config.json can have multiline strings, newlines _do not_ need to be escaped (a local modification to the JSON5 interpreter), but may be escaped with a backslash \, like
"courseDesc" : "This is a description\ of the course. Is it not\ wonderful?"
- Note - strings are interpreted with parsedown markdown which seems to follow the syntax of this, see parsedown tests for examples of each supported markdown feature, the file as a whole is JSON5. Note that JSON5 does allow some things that JSON does not.
- The config.json file can have C style multi-line comments as well.
- The config can be validated on the CS server using the command 'json5 -v config.json'. Note that un-escaped newlines in strings will cause it to fail validation.
CS Online Teaching
Proposal for minimum standards and requirements for CS online courses.
- Oversite - Include associate chairperson of CS in the blackboard site and any other systems, as a student.
- Email - Reply to emails within 24 hours during the work week, within 48 hours otherwise.
- Discussion - Use some discussion system where students can post questions, answer each other’s questions, and the instructor can do the same. The standard discussion system used is CS's mattermost server.
- Course management template - Use the CS course management template (blackboard, syllabus, anything else that is included) that the CS faculty have agreed on.
- Lecture content - lecture content (asynchronous videos and/or synchronous) must be at least half as many hours as the total # of lecture-credit-hours (½ of 45, for a 3 credit hour course).
- Assignments - assignments are well documented in text, and proper solutions and hints are demo’ed (either by a video demo, good powerpoint, etc.).
- Final exam - is proctored by the university-standard proctoring service.
- Phone - talk on the phone/skype/etc. with each student at least once.
- Content and assignments - cover the same content and use the same types of assignments as the face-to-face version of the course.
- Regular schedule - decide during the first week of classes what the regular schedule will be for the course and stick with it. Preferred - pick two days per week when assignments can be due, and give at least 48 hours notice before any due date. Preferred - pick a few different times per week to hold live-chat office hours (using some live-text-chat system).
- Absence - notify students and department when you will be absent from the normal course schedule (not available for email, not delivering content on normal schedule, etc.).
- Grading turnaround - items graded within 1 week of due date.
- CS policies - abide by all standard CS course policies
- Abide by university guidelines
The following are suggestions from students
- Keep videos 20 minutes or shorter
- Make sure students have a way to interact with each other and instructor. Make it not for many points.
- Keep regular assignments (daily even) to keep students engaged and working on the course.
- Have enough videos and/or simulation/demos since people are mainly visual learners.
Suggestions from someone who has taught online at other universities
- Consistency - types of assignments, lecture content, off-line information, short web casts are the best
- 8 weeks or 16 or something else - 8 weeks can work, more pressure to stay on track
- Cheating - usual things, also can do live presentations, narrated powerpoints
- Training for faculty - similar to our OICC, not quite as heavyweight, have a peer review / mentor helping with first time doing one, require faculty to use each of the possible options so they know how to do it
- Training for students - yes for how to navigate courses, use the system, etc.
- Standards - actively taking care of the course (answering questions, etc.) at least 4 out of 6 days, peer review is important
- Requiring attendance at live sessions - could offer to let students who do this not be required to do discussion posts, etc.
- Hints/tips - due dates on Sunday/Saturday for flexibility, use group work, ability to get asynchronous help is very important, early assignments to get everyone on track
- Something - having GA/Steve help on checking for cheating, running auto-graders, etc.
The following link is the standard template used for the syllabus for CS courses - https://docs.google.com/document/d/1cqXZZp0JOg0FOlGOBpMhffbDMiWBV-hw6VkV2KnwBO4/edit?usp=sharing
CS Programs Committee
The associate chairperson of CS is normally the chairperson of the CS Programs Committee and takes care of calling meetings, etc. When the associate chairperson is on sabbatical the CS Programs Committee may be convened by the chairperson and asked to choose a chairperson for the duration of the sabbatical.
See Email Lists.
- When the department receives an email “Admission Status Recommendation” email from ISU-GradInfo, the administrative assistant writes to the email listed for the applicant with the “MS Applicant with a Complete Application” message below.
- When the applicant replies with their contact information, current resume, and answers to programming problems, this is forwarded to the associate chairperson. The associate chairperson picks one of the faculty to be responsible for the technical interview and replies to that faculty member and the applicant, and updates a spreadsheet that keeps track of status for each applicant.
- When the CS faculty member reports back after the interview, either Admit, Deny, or Postpone the decision.
- Admit - if you are admitting the student, reply to the original message from ISU-GradInfo with the decision “Admit” and give the name and id # of who their advisor will be (R.B.). Include the associate chairperson on the message.
- Deny - reply to the original message from ISU-GradInfo giving the decision as Deny. Include the associate chairperson on the message.
- Postpone - to give the applicant another chance to do better in the technical interview, reply to the student with the “MS Applicant Decision - Postpone” message below.
- A few times during the semester, write to all applicants in the admissions spreadsheet, and let them know what their status is (some do not know their application is missing something). You can use the “MS Application Status” message below. Applicant status comes to the department automatically once per week. The associate chairperson runs a script to combine this with department status information.
Graduate student probation and dismissals
Graduate students with below 3.0 GPA are put on probation and by default retained. Having below 3.0 GPA for a second semester in a row by default results in a dismissal. Students on the dismissal list can be retained if the department recommends this. First semester students with below 3.0 GPA after the first semester can be dismissed if the department recommends this. Our standard policy has been to dismiss students with below 3.0 GPA who have an F due to cheating or plagiarism. The dean of the graduate school writes with a probation and dismissal list in the week after final grades are due, and the department needs to respond promptly if we want any of the default options changed for any of the students. Plan on checking email and replying to the dean’s message during the week that final grades are due.
CS graduate assistants
Advising current GAs First time GAs should be observed if they are teaching or lecturing. First time GAs should also have their grading checked if they are grading for the first time. GAs should be encouraged to observe each other, and check each other’s grading, and offer advice to each other.
Beginning of semester meeting The faculty member supervising the GAs normally meets with them as a group before or near the beginning of the semester to discuss expectations, answer questions, etc.
Weekly meeting The supervisor of the GAs can hold a brief weekly meeting with the GAs during the first part of the semester to make sure everyone is doing what they’re supposed to and to answer questions. GAs should look at all the information linked off the CS homepage.
Website One of the GAs can be chosen to make sure information on the website is current and get the GA schedule into the calendar that shows on the CS homepage.
Other GA duties Note - https://cs.indstate.edu/wiki/index.php/Unix_Lab_and_Help#Lab_Assistant_Duties
Choosing GAs See https://cs.indstate.edu/wiki/index.php/Graduate_Admissions#Assistantships_and_Funding for deadlines and discussion.
The advisor to the club signs reimbursement forms for the club treasurer (normally for pizza). The advisor should check out the normal Friday noon meeting every once in a while. The advisor might have a meeting with the officers to discuss how things are going, etc. The advisor may choose to have the officers help in running a programming contest or other events during the semester. See also http://cs.indstate.edu/acm/
See Policies. For any cheating or plagiarism, the case should be discussed with the associate chairperson. This should normally done BEFORE discussing with the student or notifying the student there is a problem. The associate chairperson gives advice on how to deal with the situation and is a second opinion to confirm that the activity is indeed cheating/plagiarism.
An exit survey is sent to graduating students. The associate chairperson and administrative assistant use Blue Reports to get a list of students that includes all CS majors (whether it is listed as primary or not), and can check on which are planning to graduate a given term. The exit survey is sent through Qualtrics.
See also CS Program Assessment.
See Policies for details.
point of contact - associate chairperson of CS, department chairperson See https://docs.google.com/document/d/1p-v_b9Nr4bxCXGVX4rk4TJbdaMgFa9qkLutopfKcfmE/edit for what has been traditionally done in this course. It is 1 credit and pass/fail. Normally the following are done - have students prepare resumes, critique the resumes, invite Career Center to come talk to the class about applying for jobs, have each student find one job to apply to, give advice on tailoring their application to that job, have students practice solving problems on hackerrank, have students present solutions to hackerrank problems, have students present one project or program from one of their courses to the class. Generally, the class meets every week for 1 hour for the first 10 weeks or so of the semester.
Point of contact - Regina Atkins, Assoc Dir Admissions This person meets with prospective new undergraduate students and their families. The Office of Admissions arranges for a time you are normally available on Fridays and you are notified when a student schedules a visit. You talk to the student and family about ISU in general, CS at ISU in particular, and answer questions to help them decide where the student should attend college and whether to major in CS and/or something else. See this from summer honors 2017 for an example of the type of advice you might give some of the students/families. See also http://cs.indstate.edu/info/basic.html If there is a date that you cannot handle, you normally ask the other CS faculty if one of them can take the appointment.
point of contact - dept. chairperson, administrative assistant, associate chairperson of CS The 2018-2019 schedule is linked off the CS homepage. Check your classes to make sure it looks okay.
The following are templates for email messages to send for various things.
MS Applicant with a Complete Application
Subject: your application to the CS MS program at Indiana State University
Cheers. I am writing regarding your application to the MS in Computer Science at Indiana State University.
You have submitted the documents required by the university (normally, transcripts demonstrating a four-year university degree or equivalent, and English language proficiency if required).
Your application is now with Computer Science. To move your application forward, we require that you have good basic programming skills and have knowledge of basic data structures and algorithms. If you have completed a degree in computer science you hopefully have these skills already. If you do not have a degree in computer science then you should have done some additional training/study to get these skills.
We evaluate your computer science skills in two stages. First, we want you to solve a few standard programming problems. Second, once you have solved these problems we want you to send us the solutions and we will schedule a Skype interview with you. Please see https://cs.indstate.edu/wiki/index.php/Graduate_Admissions_Interview for information about the interview; that link also contains the programming problems we want you to solve first and a very helpful youtube video giving advice for you at this stage of your application.
When you have solved the programming problems and have studied for the interview, please reply to this message with your solutions to the programming problems attached. If you worked on the problems in your browser you will need to download your solutions to attach them. In order to process your application we ask that you reply to this message within 2 weeks. If you have any questions about the process please be in touch.
Note - to view our curriculum, which courses we offer, and new updates to our program (including a new concentration in data science) please see http://cs.indstate.edu/info/programs.html#grad
Applicant has replied with solutions to programming problems
If applicant replies to the above message without attaching solutions to the programming problems, reply with --
- We don't schedule the interview until we see your solutions to the programming problems and know that you have been studying data structures and algorithms. Since you only get one chance for the interview we want you to have the best chance. Please send the solutions when you have them ready.
When applicant replies with the solutions attached, reply with --
Great, thank you! You will have your Skype interview with one of our computer science faculty. So that we can schedule your interview please reply with dates and blocks of time from the following that would work for you.
- Weekdays 9am - noon
- Weekdays 8pm - 11pm
Note that the Skype interview will require you to share your screen to show your solutions to the programming problems. You will need to be on a reliable internet connection on a desktop or laptop so that you can share your screen. Please make sure to test your Skype account and screen sharing before the interview.
When applicant replies with options for dates/time, reply/forward (with their solutions to the programming problems) and include faculty member who will likely be able to talk on that date asking the faculty member if they can arrange a time to talk. Update admissions spreadsheet to indicate which faculty member is talking to the applicant.
MS Application Status
Subject: Status - Application to CS MS program at Indiana State University
I am writing to let you know the status of your application to the CS MS program at Indiana State University.
For Incomplete Application, use the following. Your application status is: Incomplete Application
See https://cs.indstate.edu/wiki/index.php/Graduate_Admissions#Applying for what this status means. Note that our normal application deadline for the spring is Nov 15 and for the fall is June 15. Our normal deadlines for consideration for department assistantship positions is March 15 for fall intake and Oct 15 for spring intake. For all deadlines, a complete application and everything we have asked for should be in before the deadline.
If you have any questions, feel free to be in touch. If you have a question about what is missing in your application, please first check your online application, and if you are still unsure then write to firstname.lastname@example.org.
For Referred to Department, use the following.
You should have received the message below from computer science administrative assistant Brenda Lower. If you have already submitted the solutions to the programming problems and do not yet have an interview scheduled, please reply to Brenda to let her know. If you have not yet submitted the solutions to programming problems, please send those to Brenda when you have them complete.
Note that our normal application deadline for the spring is Nov 15 and for the fall is June 15. Our normal deadlines for consideration for department assistantship positions is March 15 for fall intake and Oct 15 for spring intake. For all deadlines, a complete application and everything we have asked for should be in before the deadline.
MS New Admits - Welcome, etc.
Subject: Indiana State University Computer Science - Welcome!
Cheers. You are receiving this message because you have been admitted to the CS MS at Indiana State University. Information on signing up for courses is below. See also the three linked webpages which contain answers to many of your questions. Please read them all before replying to ask any questions.
Make sure to start making arrangements for where you will live in Terre Haute. My only recommendation in that regard is to not live in University Apartments unless you will have a roommate - it is pretty expensive. You should add your ISU email address to the cs-chat email list by going to https://cs.indstate.edu/mailman/listinfo/cs-chat/ and using the form to add your @sycamores.indstate.edu email address to the cs-chat email address. Once your ISU email address has been added you can write to email@example.com from your @sycamores.indstate.edu email address for recommendations from other students.
Note also that the registration system opens for registering for courses in early November for the spring classes and early April for the summer and fall classes.
Best regards, signature...
Please begin by reading the following pages completely -
http://cs.indstate.edu/info/graduates-new.html http://cs.indstate.edu/info/programs-grad.html http://cs.indstate.edu/info/advising-grad.html
By default all students are put into the professional concentration. If you want to consider the academic concentration, the main requirement is that you want to work hard to be a good programmer and algorithms designer. If you are not sure, take a course from each concentration the first semester. The advising-grad page linked above has recommendations of which courses to sign up for. All new students take CS 500 (except for those who earned their BS at ISU - ISU BS students are only required to take CS 500 if you choose the professional concentration) regardless of concentration.
Follow the instructions on the graduates-new page linked above to get your ISU id and sign up for courses. Note that you can only sign up for 500 and 600 level courses.
Note that most 500 level courses (except CS 500) have prerequisites, so the system will not let you register. Please go ahead and register for the courses you can, and then write an email to me with your list of courses you would like and which you need a prerequisite override for. Include your id number in the email.
Note that adding/dropping classes on or after the first day of classes results in a fee.
You can write to the firstname.lastname@example.org list from your @sycamores.indstate.edu email address (see link above to add your email address to the cs-chat email list) for advice from current and recent students. Feel free to write back to me with questions as well.
If you still need assistance in ordering an I-20, contact the Center for Global Engagement - https://www.indstate.edu/global
If you have issues setting up your ISU accounts, contact the OIT help desk at 1-812-237-2910 email@example.com
MS Application - Rejection
Subject: your application - Indiana State University Computer Science
Hello. I am writing to inform you of the decision on your application to the MS in Computer Science at Indiana State University. I am sorry to inform you that your application is being declined.
Please note that you are welcome to apply for a future term if you work on your basic programming skills and data structures & algorithms. If you have not done so, you should check the sample questions at the end of the interview evaluation form linked from the Skype Interview section of https://cs.indstate.edu/wiki/index.php/Graduate_Admissions. If you work on solving these questions and would like to know if your solutions are correct please be in touch.
We wish you the best, and feel free to be in touch if you have any remaining questions.