Assignment 0. Computer Science 52. Due Friday, September 7, 2018, at 5:00 pm
|
|
- Gladys Warren
- 5 years ago
- Views:
Transcription
1 Computer Science 52 Assignment 0 Due Friday, September 7, 2018, at 5:00 pm This assignment is simply to check out that you have access to and can use the SML system. It is not factored into your course grade, but it is important that you complete it on time so that we can solve any problems that arise. Reading Material for the course is linked from the course web pages. Go to and click on the Resources tab in the blue bar at the top of the page. Find A Brief Introduction to SML, and read Part I. Now is a good time to become familiar with the available texts, which are also linked from the course Resources page. Take a look at the first few chapters of Ullman s book, Section 1.6 of Pucella s notes, the chapter Simple Applicative Programming by Gilmore, and Chapter 2 of Harper. Preparation Be sure you have an account. Most of you will have an account on the Computer Science Department systems from last semester or will have received with a password. See Corey LeBlanc in Edmunds 218 if you still need an account. If you plan on working on your own computer, configure your system SML setup right away. If you plan on working in the lab, go to the lab and login. One of the goals of this class is to make you more comfortable using the command-line in a terminal window. Follow the instructions in A Brief Introduction to SML to create a directory named cs052 for your work in this course. Slightly modified from com/224/
2 computer science 52, assignment 0 2 Template files Nearly every assignment will have a template file to get you started. One purpose of the file is to provide a standard format to ease our task of grading a large number of submissions. Another is to give you some starter code that you will use in the assignment. You will find the template file linked from the course Calendar page, right next to the assignment itself. For this assignment the file is named asgt00-template.sml Copy it to your working directory and name it asgt00.sml Then solve the problems on the assignment and place them in the designated places in the the file. Here is a sample from the template file for this assignment. ( Put your name and the date in the header comment here CS 52, Fall 2018 Assignment 0 ) ( $- ) ( Problem 1 $+00_01 ) ( numlist : int -> int list ) Place your solution to Problem 1 in this area ( Problem 2 $-00_01 $+00_02 ) ( sumlist : int -> int ) ( Problem 3 $-00_02 $+00_03 ) ( sumformula : int -> int ) Comments of the form (... ) are delimiters used by the grading scripts. Do not change or delete them. Place your entire solution to a given problem in the space between the delimiters, as shown above. You may include multiple functions as long as they appear between the problem delimeters. Check files Most assignments will have a check file that you can use to avoid some common errors. Using the check file makes it more likely that your work will successfully pass the grading scripts. For this assignment, copy the file
3 computer science 52, assignment 0 3 asgt00-check.sml from the course Calendar page to your working directory. When you are finished with the assignment, give the command sml asgt00-check.sml in the terminal window (not inside SML!). The check is successful if you see the words Sanity check successfully passed! If you do not see that message, go back and correct your code. Small errors often creep in during the last frenzied minutes when you are finishing an assignment. Remember to run the check file just before submitting your file. Keep in mind that the check file evaluates your code only for simple oversights, not for overall correctness. Submission Once you have completed the solution, made an attempt to understand the problems, and run the check file, submit your asgt00.sml file using the submission link on the course web page. The first time you use submission system you will need to Enroll in the course to be able to submit assignments. The assignment As you work on the assignment below, some of you will want to follow the instructions the instructions in A Brief Introduction to SML with extreme care, and others with a little more experience with Emacs and the command line will skim for the important details. However you do it, at the end of the exercise we want you to be able to create an SML file, correct errors in it, run it, and submit it. Take the time to read each line of your submission carefully and understand the significance of the system s responses. Feel free to ask questions if you find anything confusing or you encounter problems. Also, pay attention to the formatting and comments. Read the course s Style Guide in the document A Brief Introduction to SML, and make sure that your future submissions follow it. Because this is a warm-up assignment, the solutions are provided to you (in blue). All you have to do is to copy them into your file asgt00.sml. A complete solution appears at the end of this assignment. Although you are not expected to understand the solutions completely at this point in the course, take the time to look carefully at them and try to understand the general ideas. We will discuss the details in our first few classes. 1. Write a function numlist with the property that numlist n is a list of integers from n down to 1. numlist : int -> int list
4 computer science 52, assignment 0 4 fun numlist n = if 0 < n then n::(numlist (n-1)) else nil; 2. Write a function sumlist with the property that sumlist n is the sum of the integers from n down to 1. sumlist : int -> int fun sumlist n = if 0 < n then n + sumlist (n-1) else 0; 3. Write a function sumformula with the property that sumformula n gives the same result as sumformula n but uses the mathematical formula n + (n 1) = n(n+1) 2. sumformula : int -> int fun sumformula n = n (n+1) div 2; 4. Write a function samevalues that returns true when given two lists with the same lengths and the same values. Use list recursion even though it would be easier to write simply lista=listb. We ask you to write it in the more complicated way here to illustrate list recursion. samevalues : a list -> a list -> bool fun samevalues nil nil = true samevalues (x::xs) (y::ys) = x=y andalso samevalues xs ys samevalues = false; 5. Verify that the two ways of computing the sum of the first n integers give the same results, at least for the values from 47 down to 1. First create a list of integers from 47 down to 1, and then create two lists by applying the two functions to each element of the list. Then see if the two lists are equal, using samevalues. val baselist = numlist 47; val sivalues = map sumlist baselist; val sfvalues = map sumformula baselist; samevalues sivalues sfvalues;
5 computer science 52, assignment 0 5 Sample execution When you are finished and run your program, you Color coding: You type the material in green. The system responds with the should see something like the following in the terminal window. messages in purple. asgt00 28$ sml Standard ML of New Jersey v [built: Sun Dec 21 16:30: ] - use "asgt00.sml"; [opening asgt00.sml] val numlist = fn : int -> int list val sumlist = fn : int -> int val sumformula = fn : int -> int asgt00.sml:37.40 Warning: calling polyequal val samevalues = fn : a list -> a list -> bool val baselist = [47,46,45,44,43,42,41,40,39,38,37,36,...] val slvalues = [1128,1081,1035,990,946,903,861,820,780,741,703,666,...] val sfvalues = [1128,1081,1035,990,946,903,861,820,780,741,703,666,...] val it = true : bool val it = () : unit - Or, if you run the check file, you will see this. asgt00 29$ sml asgt00-check.sml Standard ML of New Jersey v [built: Sun Dec 21 16:30: ] [opening asgt00-check.sml] [autoloading] [library $SMLNJ-BASIS/basis.cm is stable] [autoloading done] [opening asgt00.sml] val numlist = fn : int -> int list val sumlist = fn : int -> int val sumformula = fn : int -> int asgt00.sml:37.40 Warning: calling polyequal val samevalues = fn : a list -> a list -> bool val baselist = [47,46,45,44,43,42,41,40,39,38,37,36,...] val slvalues = [1128,1081,1035,990,946,903,861,820,780,741,703,666,...] val sfvalues = [1128,1081,1035,990,946,903,861,820,780,741,703,666,...] val it = true : bool val it = () : unit Sanity check successfully passed! asgt00 30$
6 computer science 52, assignment 0 6 The sample program ( YourName TheDate CS 52, Fall 2018 Assignment 0 ) ( $- ) ( Problem 1 $+00_01 ) ( numlist : int -> int list ) fun numlist n = if 0 < n then n::(numlist (n-1)) else nil; ( Problem 2 $-00_01 $+00_02 ) ( sumlist : int -> int ) fun sumlist n = if 0 < n then n + sumlist (n-1) else 0; ( Problem 3 $-00_02 $+00_03 ) ( sumformula : int -> int ) fun sumformula n = n (n+1) div 2; ( Problem 4 $-00_03 $+00_04 ) ( samevalues : a list -> a list -> bool ) fun samevalues nil nil = true samevalues (x::xs) (y::ys) = x=y andalso samevalues xs ys samevalues = false; ( Problem 5 $-00_04 $+00_05 ) ( Verification that the two computations give equal values ) ( Create a list of integers from 47 down to 1, and create two lists by applying the two functions to each element of the list. Then see if the two lists are equal. ) val baselist = numlist 47; val slvalues = map sumlist baselist; val sfvalues = map sumformula baselist; samevalues slvalues sfvalues; ( $-00_05 )
A Second Look At ML. Chapter Seven Modern Programming Languages, 2nd ed. 1
A Second Look At ML Chapter Seven Modern Programming Languages, 2nd ed. 1 Outline Patterns Local variable definitions A sorting example Chapter Seven Modern Programming Languages, 2nd ed. 2 Two Patterns
More informationA quick introduction to SML
A quick introduction to SML CMSC 15300 April 9, 2004 1 Introduction Standard ML (SML) is a functional language (or higherorder language) and we will use it in this course to illustrate some of the important
More informationCSC324- TUTORIAL 5. Shems Saleh* *Some slides inspired by/based on Afsaneh Fazly s slides
CSC324- TUTORIAL 5 ML Shems Saleh* *Some slides inspired by/based on Afsaneh Fazly s slides Assignment 1 2 More questions were added Questions regarding the assignment? Starting ML Who am I? Shems Saleh
More informationProcessadors de Llenguatge II. Functional Paradigm. Pratt A.7 Robert Harper s SML tutorial (Sec II)
Processadors de Llenguatge II Functional Paradigm Pratt A.7 Robert Harper s SML tutorial (Sec II) Rafael Ramirez Dep Tecnologia Universitat Pompeu Fabra Paradigm Shift Imperative Paradigm State Machine
More informationPatterns The Essence of Functional Programming
Patterns The Essence of Functional Programming Up to now we have defined functions in a very traditional way: function name + variable name parameters Read Chap 7 In functional programming we can exploit
More informationAll the operations used in the expression are over integers. a takes a pair as argument. (a pair is also a tuple, or more specifically, a 2-tuple)
Weekly exercises in INF3110 week 41 6-10.10.2008 Exercise 1 Exercise 6.1 in Mitchell's book a) fun a(x,y) = x+2*y; val a = fn : int * int -> int All the operations used in the expression are over integers.
More informationHandout 2 August 25, 2008
CS 502: Compiling and Programming Systems Handout 2 August 25, 2008 Project The project you will implement will be a subset of Standard ML called Mini-ML. While Mini- ML shares strong syntactic and semantic
More informationCSE341, Fall 2011, Midterm Examination October 31, 2011
CSE341, Fall 2011, Midterm Examination October 31, 2011 Please do not turn the page until the bell rings. Rules: The exam is closed-book, closed-note, except for one side of one 8.5x11in piece of paper.
More informationPart I: Written Problems
CSci 4223 Homework 1 DUE: Friday, February 1, 11:59 pm Instructions. Your task is to answer three written problems, and to write eleven SML functions related to calendar dates, as well as test cases for
More informationThis assignment has four parts. You should write your solution to each part in a separate file:
Data Structures and Functional Programming Problem Set 1 CS 3110, Fall 013 Due at 11:59 PM, Thursday, September 5 Version: 3 Last Modified: Wednesday, August 8 This assignment has four parts. You should
More informationCase by Case. Chapter 3
Chapter 3 Case by Case In the previous chapter, we used the conditional expression if... then... else to define functions whose results depend on their arguments. For some of them we had to nest the conditional
More informationCS52 - Assignment 8. Due Friday 4/15 at 5:00pm.
CS52 - Assignment 8 Due Friday 4/15 at 5:00pm https://xkcd.com/859/ This assignment is about scanning, parsing, and evaluating. It is a sneak peak into how programming languages are designed, compiled,
More informationPROGRAMMING IN HASKELL. CS Chapter 6 - Recursive Functions
PROGRAMMING IN HASKELL CS-205 - Chapter 6 - Recursive Functions 0 Introduction As we have seen, many functions can naturally be defined in terms of other functions. factorial :: Int Int factorial n product
More informationIntroduction to SML Getting Started
Introduction to SML Getting Started Michael R. Hansen mrh@imm.dtu.dk Informatics and Mathematical Modelling Technical University of Denmark c Michael R. Hansen, Fall 2004 p.1/15 Background Standard Meta
More informationCS52 - Assignment 7. Due Friday 11/13 at 5:00pm. https://xkcd.com/538/
CS52 - Assignment 7 Due Friday 11/13 at 5:00pm https://xkcd.com/538/ For this assignment we will be writing code that allows us to encrypt and decrypt strings using RSA encryption. Put your solution in
More informationCSE341 Autumn 2017, Midterm Examination October 30, 2017
CSE341 Autumn 2017, Midterm Examination October 30, 2017 Please do not turn the page until 2:30. Rules: The exam is closed-book, closed-note, etc. except for one side of one 8.5x11in piece of paper. Please
More informationProblem Set 1 Due: 11:59pm Wednesday, February 7
CS251 Programming Languages Handout # 13 Prof. Lyn Turbak January 31, 2007 Wellesley College Reading: Problem Set 1 Due: 11:59pm Wednesday, February 7 Handouts #1 #12 (only Chapters 1 5 of Handout #9 =
More informationCSE341, Fall 2011, Midterm Examination October 31, 2011
CSE341, Fall 2011, Midterm Examination October 31, 2011 Please do not turn the page until the bell rings. Rules: The exam is closed-book, closed-note, except for one side of one 8.5x11in piece of paper.
More informationHigher-Order Functions
Higher-Order Functions Tjark Weber Functional Programming 1 Based on notes by Pierre Flener, Jean-Noël Monette, Sven-Olof Nyström Tjark Weber (UU) Higher-Order Functions 1 / 1 Tail Recursion http://xkcd.com/1270/
More informationCSC/MAT-220: Lab 6. Due: 11/26/2018
CSC/MAT-220: Lab 6 Due: 11/26/2018 In Lab 2 we discussed value and type bindings. Recall, value bindings bind a value to a variable and are intended to be static for the life of a program. Type bindings
More informationCS109A ML Notes for the Week of 1/16/96. Using ML. ML can be used as an interactive language. We. shall use a version running under UNIX, called
CS109A ML Notes for the Week of 1/16/96 Using ML ML can be used as an interactive language. We shall use a version running under UNIX, called SML/NJ or \Standard ML of New Jersey." You can get SML/NJ by
More informationCOMP 105 Homework: Type Systems
Due Tuesday, March 29, at 11:59 PM (updated) The purpose of this assignment is to help you learn about type systems. Setup Make a clone of the book code: git clone linux.cs.tufts.edu:/comp/105/build-prove-compare
More informationCS 051 Homework Laboratory #2
CS 051 Homework Laboratory #2 Dirty Laundry Objective: To gain experience using conditionals. The Scenario. One thing many students have to figure out for the first time when they come to college is how
More informationA Brief Introduction to Standard ML
A Brief Introduction to Standard ML Specification and Verification with Higher-Order Logic Arnd Poetzsch-Heffter (Slides by Jens Brandt) Software Technology Group Fachbereich Informatik Technische Universität
More informationAssignment 7. Computer Science 52. Due November 30, 2018, at 5:00 pm
Computer Science 52 Assignment 7 Due November 30, 2018, at 5:00 pm Reading This assignment is about RSA encryption. Refer to the course document RSA Encryption and the original RSA paper for details on
More informationList Processing in SML
List Processing in SML CS251 Programming Languages Spring 2017 Lyn Turbak, Meera Hejmadi, Mary Ruth Ngo, & Angela Wu Department of Computer Science Wellesley College Consing Elements into Lists - val nums
More informationThe type checker will complain that the two branches have different types, one is string and the other is int
1 Intro to ML 1.1 Basic types Need ; after expression - 42 = ; val it = 42 : int - 7+1; val it = 8 : int Can reference it - it+2; val it = 10 : int - if it > 100 then "big" else "small"; val it = "small"
More informationComputer Science CSC324 Wednesday February 13, Homework Assignment #3 Due: Thursday February 28, 2013, by 10 p.m.
Computer Science CSC324 Wednesday February 13, 2013 St. George Campus University of Toronto Homework Assignment #3 Due: Thursday February 28, 2013, by 10 p.m. Silent Policy A silent policy takes effect
More informationCMSC 201 Fall 2016 Homework 6 Functions
CMSC 201 Fall 2016 Homework 6 Functions Assignment: Homework 6 Functions Due Date: Wednesday, October 26th, 2016 by 8:59:59 PM Value: 40 points Collaboration: For Homework 6, collaboration is not allowed
More informationList Processing in SML
CS251 Programming Languages Spring 2016, Lyn Turbak Department of Computer Science Wellesley College Consing Elements into Lists - val nums = 9 :: 4 :: 7 :: []; val nums = [9,4,7] : int list - 5 :: nums;
More informationProgramming Languages ML Programming Project Due 9/28/2001, 5:00 p.m.
Programming Languages ML Programming Project Due 9/28/2001, 5:00 p.m. Functional Suite Instead of writing a single ML program, you are going to write a suite of ML functions to complete various tasks.
More informationSpring 2012 Homework 10
15-150 Spring 2012 Homework 10 Out: 24 April, 2012 Due: 2 May, 2012, 0900 EST 1 Introduction This homework will give you additional practice with imperative programming in SML. It is slightly short to
More informationShell CSCE 314 TAMU. Functions continued
1 CSCE 314: Programming Languages Dr. Dylan Shell Functions continued 2 Outline Defining Functions List Comprehensions Recursion 3 A Function without Recursion Many functions can naturally be defined in
More informationProblem Set 3 Due: 11:59 pm on Thursday, September 25
CS235 Languages and Automata Handout # 6 Prof. Lyn Turbak September 18, 2008 Wellesley College Problem Set 3 Due: 11:59 pm on Thursday, September 25 Reading: Handout #4: Standard ML of New Jersey (SML/NJ)
More informationHomework 8: Matrices Due: 11:59 PM, Oct 30, 2018
CS17 Integrated Introduction to Computer Science Klein Homework 8: Matrices Due: 11:59 PM, Oct 30, 2018 Contents 1 Reverse (Practice) 4 2 Main Diagonal (Practice) 5 3 Horizontal Flip 6 4 Vertical Flip
More informationCS Final Exam Review Suggestions - Spring 2014
CS 111 - Final Exam Review Suggestions p. 1 CS 111 - Final Exam Review Suggestions - Spring 2014 last modified: 2014-05-09 before lab You are responsible for material covered in class sessions, lab exercises,
More informationCSE 341 : Programming Languages Midterm, Spring 2015
Name: CSE 341 : Programming Languages Midterm, Spring 2015 Please do not turn the page until 12:30. Rules: Closed book, closed note, except for one side of one 8.5x11in piece of paper. Please stop promptly
More informationCSE341 Spring 2016, Midterm Examination April 29, 2016
CSE341 Spring 2016, Midterm Examination April 29, 2016 Please do not turn the page until 10:30. Rules: The exam is closed-book, closed-note, etc. except for one side of one 8.5x11in piece of paper. Please
More informationAustralian researchers develop typeface they say can boost memory, that could help students cramming for exams.
Font of all knowledge? Australian researchers develop typeface they say can boost memory, that could help students cramming for exams. About 400 university students took part in a study that found a small
More informationML 4 Unification Algorithm
ML 4 Unification Algorithm CS 421 Fall 2017 Revision 1.0 Assigned Thursday, October 19, 201y Due October 25-27, 2017 Extension None past the allowed lab sign-up time 1 Change Log 1.0 Initial Release. 2
More informationCOMP 105 Assignment: Hindley-Milner Type Inference
COMP 105 Assignment: Hindley-Milner Type Inference Due Monday, Novermber 21 at 11:59PM. In this assignment you will implement Hindley-Milner type inference, which represents the current ``best practice''
More information15 212: Principles of Programming. Some Notes on Continuations
15 212: Principles of Programming Some Notes on Continuations Michael Erdmann Spring 2011 These notes provide a brief introduction to continuations as a programming technique. Continuations have a rich
More informationCSci 4223 Principles of Programming Languages
CSci 4223 Principles of Programming Languages Lecture 11 Review Features learned: functions, tuples, lists, let expressions, options, records, datatypes, case expressions, type synonyms, pattern matching,
More information15 212: Principles of Programming. Some Notes on Induction
5 22: Principles of Programming Some Notes on Induction Michael Erdmann Spring 20 These notes provide a brief introduction to induction for proving properties of ML programs. We assume that the reader
More informationCIS24 Project #3. Student Name: Chun Chung Cheung Course Section: SA Date: 4/28/2003 Professor: Kopec. Subject: Functional Programming Language (ML)
CIS24 Project #3 Student Name: Chun Chung Cheung Course Section: SA Date: 4/28/2003 Professor: Kopec Subject: Functional Programming Language (ML) 1 Introduction ML Programming Language Functional programming
More informationCS 312 Problem Set 1: An Introduction to SML
CS 312 Problem Set 1: An Introduction to SML Assigned: September 1, 2003 Revised: September 4, 2003 Due: 11:59PM, September 10th, 2003 1 Introduction The goal of this problem set is to expose you to as
More informationn! = 1 * 2 * 3 * 4 * * (n-1) * n
The Beauty and Joy of Computing 1 Lab Exercise 9: Problem self-similarity and recursion Objectives By completing this lab exercise, you should learn to Recognize simple self-similar problems which are
More informationIf we have a call. Now consider fastmap, a version of map that uses futures: Now look at the call. That is, instead of
If we have a call (map slow-function long-list where slow-function executes slowly and long-list is a large data structure, we can expect to wait quite a while for computation of the result list to complete.
More informationCSE341: Programming Languages Lecture 9 Function-Closure Idioms. Dan Grossman Fall 2011
CSE341: Programming Languages Lecture 9 Function-Closure Idioms Dan Grossman Fall 2011 More idioms We know the rule for lexical scope and function closures Now what is it good for A partial but wide-ranging
More informationCSE 341, Autumn 2005, Assignment 3 ML - MiniML Interpreter
Due: Thurs October 27, 10:00pm CSE 341, Autumn 2005, Assignment 3 ML - MiniML Interpreter Note: This is a much longer assignment than anything we ve seen up until now. You are given two weeks to complete
More informationML Type Inference and Unification. Arlen Cox
ML Type Inference and Unification Arlen Cox Research Goals Easy to use, high performance parallel programming Primary contributions in backend and runtime Need a front end to target backend ML offers ease
More informationCSE341 Spring 2016, Midterm Examination April 29, 2016
CSE341 Spring 2016, Midterm Examination April 29, 2016 Please do not turn the page until 10:30. Rules: The exam is closed-book, closed-note, etc. except for one side of one 8.5x11in piece of paper. Please
More informationCS457/557 Functional Languages
CS457/557 Functional Languages Spring 2018 Lecture 1: Course Introduction Andrew Tolmach Portland State University (with thanks to Mark P. Jones) 1 Goals of this course Introduce the beautiful ideas of
More informationLists. Michael P. Fourman. February 2, 2010
Lists Michael P. Fourman February 2, 2010 1 Introduction The list is a fundamental datatype in most functional languages. ML is no exception; list is a built-in ML type constructor. However, to introduce
More informationCS Final Exam Review Suggestions - Fall 2017
CS 111 - Final Exam Review Suggestions p. 1 CS 111 - Final Exam Review Suggestions - Fall 2017 last modified: 2016-12-09 You are responsible for material covered in class sessions, lab exercises, and homeworks;
More informationModule 04: Lists. Topics: Lists and their methods Mutating lists Abstract list functions Readings: ThinkP 8, 10. CS116 Fall : Lists
Module 04: Lists Topics: Lists and their methods Mutating lists Abstract list functions Readings: ThinkP 8, 10 1 Consider the string method split >>> name = "Harry James Potter" >>> name.split() ['Harry',
More informationCS 320 Homework One Due 2/5 11:59pm
Name: BU ID (no dashes): CS 320 Homework One Due 2/5 11:59pm Write your answers to the problems in the space indicated. Scan your solution and submit to Gradescope as a PDF file. You will receive an email
More informationCSE341 Section 3. Standard-Library Docs, First-Class Functions, & More
CSE341 Section 3 Standard-Library Docs, First-Class Functions, & More Adapted from slides by Daniel Snitkovskiy, Nick Mooney, Nicholas Shahan, Patrick Larson, and Dan Grossman Agenda 1. SML Docs Standard
More informationCSE341 Spring 2016, Final Examination June 6, 2016
CSE341 Spring 2016, Final Examination June 6, 2016 Please do not turn the page until 8:30. Rules: The exam is closed-book, closed-note, etc. except for both sides of one 8.5x11in piece of paper. Please
More informationCMSC 201 Spring 2017 Homework 4 Lists (and Loops and Strings)
CMSC 201 Spring 2017 Homework 4 Lists (and Loops and Strings) Assignment: Homework 4 Lists (and Loops and Strings) Due Date: Friday, March 3rd, 2017 by 8:59:59 PM Value: 40 points Collaboration: For Homework
More informationCSE341: Programming Languages Lecture 9 Function-Closure Idioms. Dan Grossman Winter 2013
CSE341: Programming Languages Lecture 9 Function-Closure Idioms Dan Grossman Winter 2013 More idioms We know the rule for lexical scope and function closures Now what is it good for A partial but wide-ranging
More informationCSE 341 Section 5. Winter 2018
CSE 341 Section 5 Winter 2018 Midterm Review! Variable Bindings, Shadowing, Let Expressions Boolean, Comparison and Arithmetic Operations Equality Types Types, Datatypes, Type synonyms Tuples, Records
More informationImplementing nml: Hindley-Milner Type Inference
Implementing nml: Hindley-Milner Type Inference Due Friday, April 10 at 5:59PM. In this assignment you will implement Hindley-Milner type inference, which represents the current ``best practice'' for flexible
More informationScope and Introduction to Functional Languages. Review and Finish Scoping. Announcements. Assignment 3 due Thu at 11:55pm. Website has SML resources
Scope and Introduction to Functional Languages Prof. Evan Chang Meeting 7, CSCI 3155, Fall 2009 Announcements Assignment 3 due Thu at 11:55pm Submit in pairs Website has SML resources Text: Harper, Programming
More informationMini-ML. CS 502 Lecture 2 8/28/08
Mini-ML CS 502 Lecture 2 8/28/08 ML This course focuses on compilation techniques for functional languages Programs expressed in Standard ML Mini-ML (the source language) is an expressive core subset of
More informationCMSC 201 Fall 2018 Lab 04 While Loops
CMSC 201 Fall 2018 Lab 04 While Loops Assignment: Lab 04 While Loops Due Date: During discussion, September 24 th through September 27 th Value: 10 points (8 points during lab, 2 points for Pre Lab quiz)
More informationA LISP Interpreter in ML
UNIVERSITY OF OSLO Department of Informatics A LISP Interpreter in ML Mandatory Assignment 1 INF3110 September 21, 2009 Contents 1 1 Introduction The purpose of this assignment is to write an interpreter,
More informationA Brief Introduction to SML
Computer Science 52 A Brief Introduction to SML Spring Semester, 2015 Contents Introduction 1 Part I Using the SML System 4 1 Obtaining an Account.......................... 4 2 Your First Session.............................
More informationCOP4530 Data Structures, Algorithms and Generic Programming Recitation 3 Date: January 20 & 22, 2009
COP4530 Data Structures, Algorithms and Generic Programming Recitation 3 Date: January 20 & 22, 2009 Lab objectives: 1) Quiz 2) Set up SSH to run external programs. 3) Learn how to use the DDD debuger.
More informationCpSc 1111 Lab 6 Conditional Statements, Loops, the Math Library, and Random Numbers What s the Point?
CpSc 1111 Lab 6 Conditional Statements, Loops, the Math Library, and Random Numbers What s the Point? Overview For this lab, you will use: one or more of the conditional statements explained below scanf()
More informationClick the Add a New Value Tab. Click Add. The system will populate the Event ID field with a number after the event request is saved.
How to login to SIS: SIS-only users go to: https://buckeyelink2.osu.edu/, click on Student Information System (main page), login using your lastname.# and password. Schedule an Event Path: Main Menu Campus
More informationIntroduction to ML. Based on materials by Vitaly Shmatikov. General-purpose, non-c-like, non-oo language. Related languages: Haskell, Ocaml, F#,
Introduction to ML Based on materials by Vitaly Shmatikov slide 1 ML General-purpose, non-c-like, non-oo language Related languages: Haskell, Ocaml, F#, Combination of Lisp and Algol-like features (1958)
More informationFunctional programming Primer I
Functional programming Primer I COS 320 Compiling Techniques Princeton University Spring 2016 Lennart Beringer 1 Characteristics of functional programming Primary notions: functions and expressions (not
More informationLecture Notes on Induction and Recursion
Lecture Notes on Induction and Recursion 15-317: Constructive Logic Frank Pfenning Lecture 7 September 19, 2017 1 Introduction At this point in the course we have developed a good formal understanding
More informationCS 1803 Pair Homework 3 Calculator Pair Fun Due: Wednesday, September 15th, before 6 PM Out of 100 points
CS 1803 Pair Homework 3 Calculator Pair Fun Due: Wednesday, September 15th, before 6 PM Out of 100 points Files to submit: 1. HW3.py This is a PAIR PROGRAMMING Assignment: Work with your partner! For pair
More informationCS 6353 Compiler Construction Project Assignments
CS 6353 Compiler Construction Project Assignments In this project, you need to implement a compiler for a language defined in this handout. The programming language you need to use is C or C++ (and the
More informationScientific Programming Algolab. Wednesday 21 Dec 2016
Algolab (index.html#chapters) Out[1]: Exam Simulation Exam Simulation Scientific Programming Algolab Wednesday 21 Dec 2016 Introduction This is just an exam simulation. If you don't ship it or do a poor
More informationCpSc 1011 Lab 3 Integer Variables, Mathematical Operations, & Redirection
CpSc 1011 Lab 3 Integer Variables, Mathematical Operations, & Redirection Overview By the end of the lab, you will be able to: declare variables perform basic arithmetic operations on integer variables
More informationCS Homework 10 p. 1. CS Homework 10
CS 111 - Homework 10 p. 1 Deadline 11:59 pm on Friday, December 2, 2016 How to submit Each time you would like to submit your work: CS 111 - Homework 10 If your files are not already on nrs-labs, be sure
More informationCPSC 150 Laboratory Manual. Lab 1 Introduction to Program Creation
CPSC 150 Laboratory Manual A Practical Approach to Java, jedit & WebCAT Department of Physics, Computer Science & Engineering Christopher Newport University Lab 1 Introduction to Program Creation Welcome
More informationIntroduction to Blackboard
Blackboard 9.1: Student Guide Introduction to Blackboard Logging into Blackboard Blackboard Blackboard is an integrated set of web-based tools for course management and delivery. Requirements For web-based
More informationFinal Examination: Topics and Sample Problems
Computer Science 52 Final Examination: Topics and Sample Problems Spring Semester, 2015 In examinations the foolish ask questions that the wise cannot answer. Oscar Wilde, 1894 Time and Place Wednesday,
More informationCSC324 Functional Programming Typing, Exceptions in ML
CSC324 Functional Programming Typing, Exceptions in ML Afsaneh Fazly 1 Winter 2013 1 with many thanks to Anya Tafliovich, Gerald Penn, Sheila McIlraith, Wael Aboelsaddat, Tony Bonner, Eric Joanis, Suzanne
More informationCSCI 136 Data Structures & Advanced Programming. Fall 2018 Instructors Bill Lenhart & Bill Jannen
CSCI 136 Data Structures & Advanced Programming Fall 2018 Instructors Bill Lenhart & Bill Jannen Administrative Details Class roster: Who s here? And who s trying to get in? Handout: Class syllabus Lecture
More informationInformatics 1 Functional Programming 19 Tuesday 23 November IO and Monads. Philip Wadler University of Edinburgh
Informatics 1 Functional Programming 19 Tuesday 23 November 2010 IO and Monads Philip Wadler University of Edinburgh The 2010 Informatics 1 Competition Sponsored by Galois (galois.com) List everyone who
More informationFrom Templates to Folds
From Templates to Folds CS 5010 Program Design Paradigms Bootcamp Lesson 6.3 Mitchell Wand, 2012-2014 This work is licensed under a Creative Commons Attribution-NonCommercial 4.0 International License.
More informationLecture 6: Sequential Sorting
15-150 Lecture 6: Sequential Sorting Lecture by Dan Licata February 2, 2012 Today s lecture is about sorting. Along the way, we ll learn about divide and conquer algorithms, the tree method, and complete
More informationOCaml. ML Flow. Complex types: Lists. Complex types: Lists. The PL for the discerning hacker. All elements must have same type.
OCaml The PL for the discerning hacker. ML Flow Expressions (Syntax) Compile-time Static 1. Enter expression 2. ML infers a type Exec-time Dynamic Types 3. ML crunches expression down to a value 4. Value
More information02157 Functional Programming Tagged values and Higher-order list functions
Tagged values and Higher-order list functions nsen 1 DTU Informatics, Technical University of Denmark Tagged values and Higher-order list functions MRH 27/09/2012 Part I: Disjoint Sets An Example A shape
More informationCMSC 330: Organization of Programming Languages. Operational Semantics
CMSC 330: Organization of Programming Languages Operational Semantics Notes about Project 4, Parts 1 & 2 Still due today (7/2) Will not be graded until 7/11 (along with Part 3) You are strongly encouraged
More informationLab 1: Accessing the Linux Operating System Spring 2009
CIS 90 Linux Lab Exercise Lab 1: Accessing the Linux Operating System Spring 2009 Lab 1: Accessing the Linux Operating System This lab takes a look at UNIX through an online experience on an Ubuntu Linux
More informationIntroduction to SML Basic Types, Tuples, Lists, Trees and Higher-Order Functions
Introduction to SML Basic Types, Tuples, Lists, Trees and Higher-Order Functions Michael R. Hansen mrh@imm.dtu.dk Informatics and Mathematical Modelling Technical University of Denmark c Michael R. Hansen,
More informationLoop Invariant Examples
Loop Invariant Examples Page 1 Problems Page 3 Help (Code) Page 5 Solutions (to Help Code) Problems: Exercise 0 @return the average of the list average(double[ ] a) // Yes, this should be as easy as it
More informationProgramming in Haskell Aug-Nov 2015
Programming in Haskell Aug-Nov 2015 LECTURE 11 SEPTEMBER 10, 2015 S P SURESH CHENNAI MATHEMATICAL INSTITUTE Measuring efficiency Measuring efficiency Computation is reduction Application of definitions
More informationModule 10: Imperative Programming, Modularization, and The Future
Module 10: Imperative Programming, Modularization, and The Future If you have not already, make sure you Read How to Design Programs Sections 18. 1 CS 115 Module 10: Imperative Programming, Modularization,
More informationWeek 5 Tutorial Structural Induction
Department of Computer Science, Australian National University COMP2600 / COMP6260 Formal Methods in Software Engineering Semester 2, 2016 Week 5 Tutorial Structural Induction You should hand in attempts
More informationKnowledge: This lab will help you become familiar with the following content knowledge:
CS119 Module 2 Due Date: February 12 Purpose: Recursion is a powerful tool for for solving algorithmic problems by having a function repeatedly call itself. We start with a version of recursion called
More informationInformation Technology Virtual EMS Help https://msum.bookitadmin.minnstate.edu/ For More Information Please contact Information Technology Services at support@mnstate.edu or 218.477.2603 if you have questions
More informationRecap from last time. Programming Languages. CSE 130 : Fall Lecture 3: Data Types. Put it together: a filter function
CSE 130 : Fall 2011 Recap from last time Programming Languages Lecture 3: Data Types Ranjit Jhala UC San Diego 1 2 A shorthand for function binding Put it together: a filter function # let neg = fun f
More informationNote that pcall can be implemented using futures. That is, instead of. we can use
Note that pcall can be implemented using futures. That is, instead of (pcall F X Y Z) we can use ((future F) (future X) (future Y) (future Z)) In fact the latter version is actually more parallel execution
More information