| 1 | // Generated automatically from src/optional/wren_opt_random.wren. Do not edit. | 
|---|
| 2 | static const char* randomModuleSource = | 
|---|
| 3 | "foreign class Random {\n" | 
|---|
| 4 | "  construct new() {\n" | 
|---|
| 5 | "    seed_()\n" | 
|---|
| 6 | "  }\n" | 
|---|
| 7 | "\n" | 
|---|
| 8 | "  construct new(seed) {\n" | 
|---|
| 9 | "    if (seed is Num) {\n" | 
|---|
| 10 | "      seed_(seed)\n" | 
|---|
| 11 | "    } else if (seed is Sequence) {\n" | 
|---|
| 12 | "      if (seed.isEmpty) Fiber.abort(\"Sequence cannot be empty.\")\n" | 
|---|
| 13 | "\n" | 
|---|
| 14 | "      // TODO: Empty sequence.\n" | 
|---|
| 15 | "      var seeds = []\n" | 
|---|
| 16 | "      for (element in seed) {\n" | 
|---|
| 17 | "        if (!(element is Num)) Fiber.abort(\"Sequence elements must all be numbers.\")\n" | 
|---|
| 18 | "\n" | 
|---|
| 19 | "        seeds.add(element)\n" | 
|---|
| 20 | "        if (seeds.count == 16) break\n" | 
|---|
| 21 | "      }\n" | 
|---|
| 22 | "\n" | 
|---|
| 23 | "      // Cycle the values to fill in any missing slots.\n" | 
|---|
| 24 | "      var i = 0\n" | 
|---|
| 25 | "      while (seeds.count < 16) {\n" | 
|---|
| 26 | "        seeds.add(seeds[i])\n" | 
|---|
| 27 | "        i = i + 1\n" | 
|---|
| 28 | "      }\n" | 
|---|
| 29 | "\n" | 
|---|
| 30 | "      seed_(\n" | 
|---|
| 31 | "          seeds[0], seeds[1], seeds[2], seeds[3],\n" | 
|---|
| 32 | "          seeds[4], seeds[5], seeds[6], seeds[7],\n" | 
|---|
| 33 | "          seeds[8], seeds[9], seeds[10], seeds[11],\n" | 
|---|
| 34 | "          seeds[12], seeds[13], seeds[14], seeds[15])\n" | 
|---|
| 35 | "    } else {\n" | 
|---|
| 36 | "      Fiber.abort(\"Seed must be a number or a sequence of numbers.\")\n" | 
|---|
| 37 | "    }\n" | 
|---|
| 38 | "  }\n" | 
|---|
| 39 | "\n" | 
|---|
| 40 | "  foreign seed_()\n" | 
|---|
| 41 | "  foreign seed_(seed)\n" | 
|---|
| 42 | "  foreign seed_(n1, n2, n3, n4, n5, n6, n7, n8, n9, n10, n11, n12, n13, n14, n15, n16)\n" | 
|---|
| 43 | "\n" | 
|---|
| 44 | "  foreign float()\n" | 
|---|
| 45 | "  float(end) { float() * end }\n" | 
|---|
| 46 | "  float(start, end) { float() * (end - start) + start }\n" | 
|---|
| 47 | "\n" | 
|---|
| 48 | "  foreign int()\n" | 
|---|
| 49 | "  int(end) { (float() * end).floor }\n" | 
|---|
| 50 | "  int(start, end) { (float() * (end - start)).floor + start }\n" | 
|---|
| 51 | "\n" | 
|---|
| 52 | "  sample(list) {\n" | 
|---|
| 53 | "    if (list.count == 0) Fiber.abort(\"Not enough elements to sample.\")\n" | 
|---|
| 54 | "    return list[int(list.count)]\n" | 
|---|
| 55 | "  }\n" | 
|---|
| 56 | "  sample(list, count) {\n" | 
|---|
| 57 | "    if (count > list.count) Fiber.abort(\"Not enough elements to sample.\")\n" | 
|---|
| 58 | "\n" | 
|---|
| 59 | "    var result = []\n" | 
|---|
| 60 | "\n" | 
|---|
| 61 | "    // The algorithm described in \"Programming pearls: a sample of brilliance\".\n" | 
|---|
| 62 | "    // Use a hash map for sample sizes less than 1/4 of the population size and\n" | 
|---|
| 63 | "    // an array of booleans for larger samples. This simple heuristic improves\n" | 
|---|
| 64 | "    // performance for large sample sizes as well as reduces memory usage.\n" | 
|---|
| 65 | "    if (count * 4 < list.count) {\n" | 
|---|
| 66 | "      var picked = {}\n" | 
|---|
| 67 | "      for (i in list.count - count...list.count) {\n" | 
|---|
| 68 | "        var index = int(i + 1)\n" | 
|---|
| 69 | "        if (picked.containsKey(index)) index = i\n" | 
|---|
| 70 | "        picked[index] = true\n" | 
|---|
| 71 | "        result.add(list[index])\n" | 
|---|
| 72 | "      }\n" | 
|---|
| 73 | "    } else {\n" | 
|---|
| 74 | "      var picked = List.filled(list.count, false)\n" | 
|---|
| 75 | "      for (i in list.count - count...list.count) {\n" | 
|---|
| 76 | "        var index = int(i + 1)\n" | 
|---|
| 77 | "        if (picked[index]) index = i\n" | 
|---|
| 78 | "        picked[index] = true\n" | 
|---|
| 79 | "        result.add(list[index])\n" | 
|---|
| 80 | "      }\n" | 
|---|
| 81 | "    }\n" | 
|---|
| 82 | "\n" | 
|---|
| 83 | "    return result\n" | 
|---|
| 84 | "  }\n" | 
|---|
| 85 | "\n" | 
|---|
| 86 | "  shuffle(list) {\n" | 
|---|
| 87 | "    if (list.isEmpty) return\n" | 
|---|
| 88 | "\n" | 
|---|
| 89 | "    // Fisher-Yates shuffle.\n" | 
|---|
| 90 | "    for (i in 0...list.count - 1) {\n" | 
|---|
| 91 | "      var from = int(i, list.count)\n" | 
|---|
| 92 | "      var temp = list[from]\n" | 
|---|
| 93 | "      list[from] = list[i]\n" | 
|---|
| 94 | "      list[i] = temp\n" | 
|---|
| 95 | "    }\n" | 
|---|
| 96 | "  }\n" | 
|---|
| 97 | "}\n"; | 
|---|
| 98 |  | 
|---|