Fahad/Scala/Chapter5.sc
author fahadausaf <fahad.ausaf@icloud.com>
Tue, 04 Nov 2014 19:51:39 +0000
changeset 40 e5afb97b54f6
parent 32 fa92e8f089a2
child 42 6b8e3d232361
permissions -rw-r--r--
a1
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
30
197babb05539 scala by example code
fahadausaf <fahad.ausaf@icloud.com>
parents:
diff changeset
     1
package greeter
197babb05539 scala by example code
fahadausaf <fahad.ausaf@icloud.com>
parents:
diff changeset
     2
197babb05539 scala by example code
fahadausaf <fahad.ausaf@icloud.com>
parents:
diff changeset
     3
object Chapter5 {
197babb05539 scala by example code
fahadausaf <fahad.ausaf@icloud.com>
parents:
diff changeset
     4
  println("Welcome to the Scala worksheet")       //> Welcome to the Scala worksheet
197babb05539 scala by example code
fahadausaf <fahad.ausaf@icloud.com>
parents:
diff changeset
     5
197babb05539 scala by example code
fahadausaf <fahad.ausaf@icloud.com>
parents:
diff changeset
     6
  /////////////////////////////////////////////////////////////////////////////
197babb05539 scala by example code
fahadausaf <fahad.ausaf@icloud.com>
parents:
diff changeset
     7
  //   CHAPTER 5: FIRST-CLASS FUNCTIONS
197babb05539 scala by example code
fahadausaf <fahad.ausaf@icloud.com>
parents:
diff changeset
     8
197babb05539 scala by example code
fahadausaf <fahad.ausaf@icloud.com>
parents:
diff changeset
     9
  /*
197babb05539 scala by example code
fahadausaf <fahad.ausaf@icloud.com>
parents:
diff changeset
    10
  // Write a function to sumall integers between two given numbers a and b
197babb05539 scala by example code
fahadausaf <fahad.ausaf@icloud.com>
parents:
diff changeset
    11
  def sumInts(a: Int, b: Int): Int =
197babb05539 scala by example code
fahadausaf <fahad.ausaf@icloud.com>
parents:
diff changeset
    12
    if (a > b) 0 else a + sumInts(a + 1, b)
197babb05539 scala by example code
fahadausaf <fahad.ausaf@icloud.com>
parents:
diff changeset
    13
197babb05539 scala by example code
fahadausaf <fahad.ausaf@icloud.com>
parents:
diff changeset
    14
  sumInts(1, 5)
197babb05539 scala by example code
fahadausaf <fahad.ausaf@icloud.com>
parents:
diff changeset
    15
197babb05539 scala by example code
fahadausaf <fahad.ausaf@icloud.com>
parents:
diff changeset
    16
  //Write a function to sum the squares of all integers between two given numbers a and b
197babb05539 scala by example code
fahadausaf <fahad.ausaf@icloud.com>
parents:
diff changeset
    17
  def square(x: Int): Int = x * x
197babb05539 scala by example code
fahadausaf <fahad.ausaf@icloud.com>
parents:
diff changeset
    18
  def sumSquares(a: Int, b: Int): Int =
197babb05539 scala by example code
fahadausaf <fahad.ausaf@icloud.com>
parents:
diff changeset
    19
    if (a > b) 0 else square(a) + sumSquares(a + 1, b)
197babb05539 scala by example code
fahadausaf <fahad.ausaf@icloud.com>
parents:
diff changeset
    20
197babb05539 scala by example code
fahadausaf <fahad.ausaf@icloud.com>
parents:
diff changeset
    21
  square(5)
197babb05539 scala by example code
fahadausaf <fahad.ausaf@icloud.com>
parents:
diff changeset
    22
197babb05539 scala by example code
fahadausaf <fahad.ausaf@icloud.com>
parents:
diff changeset
    23
  //Write a function to sum the powers 2n of all integers n between two given numbers a and b:
197babb05539 scala by example code
fahadausaf <fahad.ausaf@icloud.com>
parents:
diff changeset
    24
  def powerOfTwo(x: Int): Int = if (x == 0) 1 else 2 * powerOfTwo(x - 1)
197babb05539 scala by example code
fahadausaf <fahad.ausaf@icloud.com>
parents:
diff changeset
    25
  def sumPowersOfTwo(a: Int, b: Int): Int =
197babb05539 scala by example code
fahadausaf <fahad.ausaf@icloud.com>
parents:
diff changeset
    26
    if (a > b) 0 else powerOfTwo(a) + sumPowersOfTwo(a + 1, b)
197babb05539 scala by example code
fahadausaf <fahad.ausaf@icloud.com>
parents:
diff changeset
    27
197babb05539 scala by example code
fahadausaf <fahad.ausaf@icloud.com>
parents:
diff changeset
    28
  sumPowersOfTwo(2, 4)
197babb05539 scala by example code
fahadausaf <fahad.ausaf@icloud.com>
parents:
diff changeset
    29
  */
197babb05539 scala by example code
fahadausaf <fahad.ausaf@icloud.com>
parents:
diff changeset
    30
32
fa92e8f089a2 no message
fahadausaf <fahad.ausaf@icloud.com>
parents: 30
diff changeset
    31
  /*
30
197babb05539 scala by example code
fahadausaf <fahad.ausaf@icloud.com>
parents:
diff changeset
    32
  def sum(f: Int => Int, a: Int, b: Int): Int =
32
fa92e8f089a2 no message
fahadausaf <fahad.ausaf@icloud.com>
parents: 30
diff changeset
    33
    if (a > b) 0 else f(a) + sum(f, a + 1, b)
30
197babb05539 scala by example code
fahadausaf <fahad.ausaf@icloud.com>
parents:
diff changeset
    34
197babb05539 scala by example code
fahadausaf <fahad.ausaf@icloud.com>
parents:
diff changeset
    35
  //def sumInts(a: Int, b: Int): Int = sum(id, a, b)
197babb05539 scala by example code
fahadausaf <fahad.ausaf@icloud.com>
parents:
diff changeset
    36
  //def sumInts(a: Int, b: Int): Int = sum((x: Int) => x, a, b)
197babb05539 scala by example code
fahadausaf <fahad.ausaf@icloud.com>
parents:
diff changeset
    37
  def sumInts(a: Int, b: Int): Int = sum(x => x, a, b)
197babb05539 scala by example code
fahadausaf <fahad.ausaf@icloud.com>
parents:
diff changeset
    38
  //def sumSquares(a: Int, b: Int): Int = sum(square, a, b)
197babb05539 scala by example code
fahadausaf <fahad.ausaf@icloud.com>
parents:
diff changeset
    39
  //def sumSquares(a: Int, b: Int): Int = sum((x: Int) => x * x, a, b)
197babb05539 scala by example code
fahadausaf <fahad.ausaf@icloud.com>
parents:
diff changeset
    40
  def sumSquares(a: Int, b: Int): Int = sum(x => x * x, a, b)
197babb05539 scala by example code
fahadausaf <fahad.ausaf@icloud.com>
parents:
diff changeset
    41
  def sumPowersOfTwo(a: Int, b: Int): Int = sum(powerOfTwo, a, b)
197babb05539 scala by example code
fahadausaf <fahad.ausaf@icloud.com>
parents:
diff changeset
    42
  
32
fa92e8f089a2 no message
fahadausaf <fahad.ausaf@icloud.com>
parents: 30
diff changeset
    43
  def id(x: Int): Int = x
fa92e8f089a2 no message
fahadausaf <fahad.ausaf@icloud.com>
parents: 30
diff changeset
    44
	def square(x: Int): Int = x * x
fa92e8f089a2 no message
fahadausaf <fahad.ausaf@icloud.com>
parents: 30
diff changeset
    45
	*/
30
197babb05539 scala by example code
fahadausaf <fahad.ausaf@icloud.com>
parents:
diff changeset
    46
	def powerOfTwo(x: Int): Int = if (x == 0) 1 else 2 * powerOfTwo(x - 1)
197babb05539 scala by example code
fahadausaf <fahad.ausaf@icloud.com>
parents:
diff changeset
    47
                                                  //> powerOfTwo: (x: Int)Int
32
fa92e8f089a2 no message
fahadausaf <fahad.ausaf@icloud.com>
parents: 30
diff changeset
    48
  
fa92e8f089a2 no message
fahadausaf <fahad.ausaf@icloud.com>
parents: 30
diff changeset
    49
30
197babb05539 scala by example code
fahadausaf <fahad.ausaf@icloud.com>
parents:
diff changeset
    50
  // 5.2: Currying
32
fa92e8f089a2 no message
fahadausaf <fahad.ausaf@icloud.com>
parents: 30
diff changeset
    51
fa92e8f089a2 no message
fahadausaf <fahad.ausaf@icloud.com>
parents: 30
diff changeset
    52
  def sum(f: Int => Int): (Int, Int) => Int = {
fa92e8f089a2 no message
fahadausaf <fahad.ausaf@icloud.com>
parents: 30
diff changeset
    53
    def sumF(a: Int, b: Int): Int =
fa92e8f089a2 no message
fahadausaf <fahad.ausaf@icloud.com>
parents: 30
diff changeset
    54
      if (a > b) 0 else f(a) + sumF(a + 1, b)
fa92e8f089a2 no message
fahadausaf <fahad.ausaf@icloud.com>
parents: 30
diff changeset
    55
    sumF
fa92e8f089a2 no message
fahadausaf <fahad.ausaf@icloud.com>
parents: 30
diff changeset
    56
  }                                               //> sum: (f: Int => Int)(Int, Int) => Int
fa92e8f089a2 no message
fahadausaf <fahad.ausaf@icloud.com>
parents: 30
diff changeset
    57
fa92e8f089a2 no message
fahadausaf <fahad.ausaf@icloud.com>
parents: 30
diff changeset
    58
  def sumInts = sum(x => x)                       //> sumInts: => (Int, Int) => Int
fa92e8f089a2 no message
fahadausaf <fahad.ausaf@icloud.com>
parents: 30
diff changeset
    59
  def sumSquares = sum(x => x * x)                //> sumSquares: => (Int, Int) => Int
fa92e8f089a2 no message
fahadausaf <fahad.ausaf@icloud.com>
parents: 30
diff changeset
    60
  def sumPowersOfTwo = sum(powerOfTwo)            //> sumPowersOfTwo: => (Int, Int) => Int
30
197babb05539 scala by example code
fahadausaf <fahad.ausaf@icloud.com>
parents:
diff changeset
    61
  
32
fa92e8f089a2 no message
fahadausaf <fahad.ausaf@icloud.com>
parents: 30
diff changeset
    62
  sumSquares(1,10) + sumPowersOfTwo(10,20)        //> res0: Int = 2096513
fa92e8f089a2 no message
fahadausaf <fahad.ausaf@icloud.com>
parents: 30
diff changeset
    63
  sum(x => x * x)(2,4)                            //> res1: Int = 29
fa92e8f089a2 no message
fahadausaf <fahad.ausaf@icloud.com>
parents: 30
diff changeset
    64
fa92e8f089a2 no message
fahadausaf <fahad.ausaf@icloud.com>
parents: 30
diff changeset
    65
	// 5.3: Finding Fixed Points of Functions
fa92e8f089a2 no message
fahadausaf <fahad.ausaf@icloud.com>
parents: 30
diff changeset
    66
	
fa92e8f089a2 no message
fahadausaf <fahad.ausaf@icloud.com>
parents: 30
diff changeset
    67
	val tolerance = 0.001                     //> tolerance  : Double = 0.001
fa92e8f089a2 no message
fahadausaf <fahad.ausaf@icloud.com>
parents: 30
diff changeset
    68
	def isCloseEnough(x: Double, y: Double) = Math.abs((x-y) / x) < tolerance
fa92e8f089a2 no message
fahadausaf <fahad.ausaf@icloud.com>
parents: 30
diff changeset
    69
                                                  //> isCloseEnough: (x: Double, y: Double)Boolean
fa92e8f089a2 no message
fahadausaf <fahad.ausaf@icloud.com>
parents: 30
diff changeset
    70
	def fixedPoint(f: Double => Double)(firstGuess: Double) = {
fa92e8f089a2 no message
fahadausaf <fahad.ausaf@icloud.com>
parents: 30
diff changeset
    71
		def iterate(guess: Double): Double = {
fa92e8f089a2 no message
fahadausaf <fahad.ausaf@icloud.com>
parents: 30
diff changeset
    72
			val next = f(guess)
fa92e8f089a2 no message
fahadausaf <fahad.ausaf@icloud.com>
parents: 30
diff changeset
    73
			if (isCloseEnough(guess, next)) next
fa92e8f089a2 no message
fahadausaf <fahad.ausaf@icloud.com>
parents: 30
diff changeset
    74
			else iterate(next)
fa92e8f089a2 no message
fahadausaf <fahad.ausaf@icloud.com>
parents: 30
diff changeset
    75
		}
fa92e8f089a2 no message
fahadausaf <fahad.ausaf@icloud.com>
parents: 30
diff changeset
    76
		iterate(firstGuess)
fa92e8f089a2 no message
fahadausaf <fahad.ausaf@icloud.com>
parents: 30
diff changeset
    77
	}                                         //> fixedPoint: (f: Double => Double)(firstGuess: Double)Double
fa92e8f089a2 no message
fahadausaf <fahad.ausaf@icloud.com>
parents: 30
diff changeset
    78
	
fa92e8f089a2 no message
fahadausaf <fahad.ausaf@icloud.com>
parents: 30
diff changeset
    79
	
fa92e8f089a2 no message
fahadausaf <fahad.ausaf@icloud.com>
parents: 30
diff changeset
    80
	
fa92e8f089a2 no message
fahadausaf <fahad.ausaf@icloud.com>
parents: 30
diff changeset
    81
	
fa92e8f089a2 no message
fahadausaf <fahad.ausaf@icloud.com>
parents: 30
diff changeset
    82
	
fa92e8f089a2 no message
fahadausaf <fahad.ausaf@icloud.com>
parents: 30
diff changeset
    83
	
fa92e8f089a2 no message
fahadausaf <fahad.ausaf@icloud.com>
parents: 30
diff changeset
    84
	
fa92e8f089a2 no message
fahadausaf <fahad.ausaf@icloud.com>
parents: 30
diff changeset
    85
	
fa92e8f089a2 no message
fahadausaf <fahad.ausaf@icloud.com>
parents: 30
diff changeset
    86
	
fa92e8f089a2 no message
fahadausaf <fahad.ausaf@icloud.com>
parents: 30
diff changeset
    87
	
fa92e8f089a2 no message
fahadausaf <fahad.ausaf@icloud.com>
parents: 30
diff changeset
    88
	
fa92e8f089a2 no message
fahadausaf <fahad.ausaf@icloud.com>
parents: 30
diff changeset
    89
	
fa92e8f089a2 no message
fahadausaf <fahad.ausaf@icloud.com>
parents: 30
diff changeset
    90
	
fa92e8f089a2 no message
fahadausaf <fahad.ausaf@icloud.com>
parents: 30
diff changeset
    91
	
fa92e8f089a2 no message
fahadausaf <fahad.ausaf@icloud.com>
parents: 30
diff changeset
    92
	
fa92e8f089a2 no message
fahadausaf <fahad.ausaf@icloud.com>
parents: 30
diff changeset
    93
	
fa92e8f089a2 no message
fahadausaf <fahad.ausaf@icloud.com>
parents: 30
diff changeset
    94
	
fa92e8f089a2 no message
fahadausaf <fahad.ausaf@icloud.com>
parents: 30
diff changeset
    95
	
fa92e8f089a2 no message
fahadausaf <fahad.ausaf@icloud.com>
parents: 30
diff changeset
    96
	
fa92e8f089a2 no message
fahadausaf <fahad.ausaf@icloud.com>
parents: 30
diff changeset
    97
	
fa92e8f089a2 no message
fahadausaf <fahad.ausaf@icloud.com>
parents: 30
diff changeset
    98
	
fa92e8f089a2 no message
fahadausaf <fahad.ausaf@icloud.com>
parents: 30
diff changeset
    99
	
fa92e8f089a2 no message
fahadausaf <fahad.ausaf@icloud.com>
parents: 30
diff changeset
   100
	
fa92e8f089a2 no message
fahadausaf <fahad.ausaf@icloud.com>
parents: 30
diff changeset
   101
	
fa92e8f089a2 no message
fahadausaf <fahad.ausaf@icloud.com>
parents: 30
diff changeset
   102
	
fa92e8f089a2 no message
fahadausaf <fahad.ausaf@icloud.com>
parents: 30
diff changeset
   103
	
fa92e8f089a2 no message
fahadausaf <fahad.ausaf@icloud.com>
parents: 30
diff changeset
   104
	
fa92e8f089a2 no message
fahadausaf <fahad.ausaf@icloud.com>
parents: 30
diff changeset
   105
	
30
197babb05539 scala by example code
fahadausaf <fahad.ausaf@icloud.com>
parents:
diff changeset
   106
}