0000: 27 75 73 65 20 73 74 72 69 63 74 27 3b 0a 0a 69 'use strict';..i
0010: 6d 70 6f 72 74 20 6d 61 74 68 20 66 72 6f 6d 20 mport math from
0020: 27 2e 2e 2f 75 74 69 6c 2f 6d 61 74 68 27 3b 0a '../util/math';.
0030: 69 6d 70 6f 72 74 20 53 65 71 75 65 6e 63 65 20 import Sequence
0040: 66 72 6f 6d 20 27 2e 2e 2f 6d 6f 64 65 6c 73 2f from '../models/
0050: 73 65 71 75 65 6e 63 65 27 3b 0a 0a 2f 2f 20 46 sequence';..// F
0060: 6f 72 20 74 68 65 20 74 75 74 6f 72 69 61 6c 2c or the tutorial,
0070: 20 6c 6f 6f 6b 69 6e 67 20 61 74 0a 0a 2f 2f 50 looking at..//P
0080: 61 74 74 65 72 6e 20 73 65 63 74 69 6f 6e 3a 0a attern section:.
0090: 2f 2f 20 2e 63 72 65 61 74 65 28 29 2c 20 2e 72 // .create(), .r
00a0: 6f 77 73 2c 20 2e 63 6f 6c 75 6d 6e 73 2c 0a 2f ows, .columns,./
00b0: 2f 20 2e 70 61 74 74 65 72 6e 2c 20 2e 6c 65 6e / .pattern, .len
00c0: 67 74 68 2c 20 2e 66 6f 72 6d 61 74 41 73 54 65 gth, .formatAsTe
00d0: 78 74 28 29 2c 20 2e 6c 6f 67 28 29 2c 0a 2f 2f xt(), .log(),.//
00e0: 20 2e 6c 6f 63 61 74 65 28 69 29 2c 20 2e 69 6e .locate(i), .in
00f0: 64 65 78 4f 66 28 63 2c 72 29 0a 2f 2f 20 72 6f dexOf(c,r).// ro
0100: 77 28 29 2c 20 63 6f 6c 75 6d 6e 28 29 20 28 72 w(), column() (r
0110: 65 74 75 72 6e 73 20 63 6f 6e 74 65 6e 74 73 20 eturns contents
0120: 6f 66 20 72 6f 77 20 6f 72 20 63 6f 6c 75 6d 29 of row or colum)
0130: 0a 0a 2f 2f 43 6f 6e 74 72 6f 6c 20 73 65 63 74 ..//Control sect
0140: 69 6f 6e 3a 0a 2f 2f 20 74 6f 67 67 6c 65 20 78 ion:.// toggle x
0150: 33 0a 2f 2f 20 73 65 74 20 78 34 0a 2f 2f 20 72 3.// set x4.// r
0160: 6f 74 61 74 65 20 78 33 0a 2f 2f 20 70 6f 70 75 otate x3.// popu
0170: 6c 61 74 65 20 78 33 0a 2f 2f 20 65 72 61 73 65 late x3.// erase
0180: 20 78 33 0a 0a 0a 2f 2f 20 73 68 6f 75 6c 64 20 x3...// should
0190: 73 6f 6d 65 20 76 65 72 73 69 6f 6e 20 6f 66 20 some version of
01a0: 74 68 69 73 20 68 61 76 65 20 61 20 66 6c 6f 61 this have a floa
01b0: 74 20 76 61 6c 75 65 20 66 6f 72 20 65 61 63 68 t value for each
01c0: 20 63 65 6c 6c 3f 0a 2f 2f 20 63 6f 75 6c 64 20 cell?.// could
01d0: 62 65 20 6c 69 6b 65 20 61 20 6d 69 72 72 6f 72 be like a mirror
01e0: 20 2e 70 61 74 74 65 72 6e 20 74 68 61 74 20 68 .pattern that h
01f0: 61 73 20 76 61 6c 75 65 73 2e 20 62 79 20 64 65 as values. by de
0200: 66 61 75 6c 74 2c 20 65 76 65 72 79 74 68 69 6e fault, everythin
0210: 67 20 69 73 20 31 2c 20 62 75 74 20 63 6f 75 6c g is 1, but coul
0220: 64 20 62 65 20 73 65 74 2e 2e 2e 0a 2f 2f 20 6e d be set....// n
0230: 6f 74 20 61 20 67 6f 6f 64 20 77 61 79 20 74 6f ot a good way to
0240: 20 64 6f 20 74 68 61 74 20 6f 6e 20 69 6e 74 65 do that on inte
0250: 72 66 61 63 65 2c 20 62 75 74 20 61 73 20 61 20 rface, but as a
0260: 6d 6f 64 65 6c 20 69 74 20 77 6f 75 6c 64 20 62 model it would b
0270: 65 20 6e 69 63 65 2e 2e 2e 0a 2f 2f 20 66 6f 72 e nice....// for
0280: 20 2e 66 6f 72 6d 61 74 41 73 54 65 78 74 28 29 .formatAsText()
0290: 2c 20 63 6f 75 6c 64 20 6d 75 6c 74 69 70 6c 79 , could multiply
02a0: 20 62 79 20 31 30 30 20 61 6e 64 20 66 6c 6f 6f by 100 and floo
02b0: 72 2c 20 73 6f 20 65 61 63 68 20 63 65 6c 6c 20 r, so each cell
02c0: 69 73 20 61 6e 20 69 6e 74 20 66 72 6f 6d 20 30 is an int from 0
02d0: 20 74 6f 20 39 0a 0a 65 78 70 6f 72 74 20 64 65 to 9..export de
02e0: 66 61 75 6c 74 20 63 6c 61 73 73 20 4d 61 74 72 fault class Matr
02f0: 69 78 20 7b 0a 0a 20 20 63 6f 6e 73 74 72 75 63 ix {.. construc
0300: 74 6f 72 28 72 6f 77 73 2c 63 6f 6c 75 6d 6e 73 tor(rows,columns
0310: 29 20 7b 0a 20 20 20 20 2f 2f 20 73 68 6f 75 6c ) {. // shoul
0320: 64 20 61 6c 73 6f 20 68 61 76 65 20 61 62 69 6c d also have abil
0330: 69 74 79 20 74 6f 20 63 72 65 61 74 65 20 75 73 ity to create us
0340: 69 6e 67 20 61 6e 20 65 78 69 73 74 69 6e 67 20 ing an existing
0350: 6d 61 74 72 69 78 20 28 32 64 20 61 72 72 61 79 matrix (2d array
0360: 29 0a 20 20 20 20 74 68 69 73 2e 70 61 74 74 65 ). this.patte
0370: 72 6e 20 3d 20 5b 5d 3b 0a 20 20 20 20 74 68 69 rn = [];. thi
0380: 73 2e 63 72 65 61 74 65 28 72 6f 77 73 2c 63 6f s.create(rows,co
0390: 6c 75 6d 6e 73 29 3b 0a 0a 20 20 20 20 74 68 69 lumns);.. thi
03a0: 73 2e 74 6f 67 67 6c 65 20 3d 20 7b 0a 20 20 20 s.toggle = {.
03b0: 20 20 20 63 65 6c 6c 3a 20 28 63 6f 6c 75 6d 6e cell: (column
03c0: 2c 20 72 6f 77 29 20 3d 3e 20 7b 0a 20 20 20 20 , row) => {.
03d0: 20 20 20 20 74 68 69 73 2e 70 61 74 74 65 72 6e this.pattern
03e0: 5b 72 6f 77 5d 5b 63 6f 6c 75 6d 6e 5d 20 3d 20 [row][column] =
03f0: 21 74 68 69 73 2e 70 61 74 74 65 72 6e 5b 72 6f !this.pattern[ro
0400: 77 5d 5b 63 6f 6c 75 6d 6e 5d 3b 20 2f 2f 20 6d w][column]; // m
0410: 61 74 68 2e 69 6e 76 65 72 74 28 74 68 69 73 2e ath.invert(this.
0420: 70 61 74 74 65 72 6e 5b 72 6f 77 5d 5b 63 6f 6c pattern[row][col
0430: 75 6d 6e 5d 29 3b 0a 20 20 20 20 20 20 20 20 69 umn]);. i
0440: 66 20 28 74 68 69 73 2e 75 69 29 20 7b 20 74 68 f (this.ui) { th
0450: 69 73 2e 75 69 2e 75 70 64 61 74 65 28 29 3b 20 is.ui.update();
0460: 7d 0a 20 20 20 20 20 20 20 20 72 65 74 75 72 6e }. return
0470: 20 74 68 69 73 2e 70 61 74 74 65 72 6e 5b 72 6f this.pattern[ro
0480: 77 5d 5b 63 6f 6c 75 6d 6e 5d 3b 0a 20 20 20 20 w][column];.
0490: 20 20 7d 2c 0a 20 20 20 20 20 20 61 6c 6c 3a 20 },. all:
04a0: 28 29 20 3d 3e 20 7b 0a 20 20 20 20 20 20 20 20 () => {.
04b0: 74 68 69 73 2e 69 74 65 72 61 74 65 28 28 72 2c this.iterate((r,
04c0: 63 29 20 3d 3e 20 7b 20 74 68 69 73 2e 74 6f 67 c) => { this.tog
04d0: 67 6c 65 2e 63 65 6c 6c 28 63 2c 72 29 3b 20 7d gle.cell(c,r); }
04e0: 29 3b 0a 20 20 20 20 20 20 20 20 69 66 20 28 74 );. if (t
04f0: 68 69 73 2e 75 69 29 20 7b 20 74 68 69 73 2e 75 his.ui) { this.u
0500: 69 2e 75 70 64 61 74 65 28 29 3b 20 7d 0a 20 20 i.update(); }.
0510: 20 20 20 20 7d 2c 0a 20 20 20 20 20 20 72 6f 77 },. row
0520: 3a 20 28 72 6f 77 29 20 3d 3e 20 7b 0a 20 20 20 : (row) => {.
0530: 20 20 20 20 20 66 6f 72 20 28 6c 65 74 20 69 3d for (let i=
0540: 30 3b 20 69 3c 74 68 69 73 2e 63 6f 6c 75 6d 6e 0; i<this.column
0550: 73 3b 20 69 2b 2b 29 20 7b 0a 20 20 20 20 20 20 s; i++) {.
0560: 20 20 20 20 74 68 69 73 2e 74 6f 67 67 6c 65 2e this.toggle.
0570: 63 65 6c 6c 28 69 2c 72 6f 77 29 3b 0a 20 20 20 cell(i,row);.
0580: 20 20 20 20 20 7d 0a 20 20 20 20 20 20 20 20 69 }. i
0590: 66 20 28 74 68 69 73 2e 75 69 29 20 7b 20 74 68 f (this.ui) { th
05a0: 69 73 2e 75 69 2e 75 70 64 61 74 65 28 29 3b 20 is.ui.update();
05b0: 7d 0a 20 20 20 20 20 20 7d 2c 0a 20 20 20 20 20 }. },.
05c0: 20 63 6f 6c 75 6d 6e 3a 20 28 63 6f 6c 75 6d 6e column: (column
05d0: 29 20 3d 3e 20 7b 0a 20 20 20 20 20 20 20 20 66 ) => {. f
05e0: 6f 72 20 28 6c 65 74 20 69 3d 30 3b 20 69 3c 74 or (let i=0; i<t
05f0: 68 69 73 2e 72 6f 77 73 3b 20 69 2b 2b 29 20 7b his.rows; i++) {
0600: 0a 20 20 20 20 20 20 20 20 20 20 74 68 69 73 2e . this.
0610: 74 6f 67 67 6c 65 2e 63 65 6c 6c 28 63 6f 6c 75 toggle.cell(colu
0620: 6d 6e 2c 69 29 3b 0a 20 20 20 20 20 20 20 20 7d mn,i);. }
0630: 0a 20 20 20 20 20 20 20 20 69 66 20 28 74 68 69 . if (thi
0640: 73 2e 75 69 29 20 7b 20 74 68 69 73 2e 75 69 2e s.ui) { this.ui.
0650: 75 70 64 61 74 65 28 29 3b 20 7d 0a 20 20 20 20 update(); }.
0660: 20 20 7d 0a 20 20 20 20 7d 3b 0a 0a 20 20 20 20 }. };..
0670: 74 68 69 73 2e 73 65 74 20 3d 20 7b 0a 20 20 20 this.set = {.
0680: 20 20 20 63 65 6c 6c 3a 20 28 63 6f 6c 75 6d 6e cell: (column
0690: 2c 20 72 6f 77 2c 20 76 61 6c 75 65 29 20 3d 3e , row, value) =>
06a0: 20 7b 0a 20 20 20 20 20 20 20 20 74 68 69 73 2e {. this.
06b0: 70 61 74 74 65 72 6e 5b 72 6f 77 5d 5b 63 6f 6c pattern[row][col
06c0: 75 6d 6e 5d 20 3d 20 76 61 6c 75 65 3b 0a 20 20 umn] = value;.
06d0: 20 20 20 20 20 20 69 66 20 28 74 68 69 73 2e 75 if (this.u
06e0: 69 29 20 7b 20 74 68 69 73 2e 75 69 2e 75 70 64 i) { this.ui.upd
06f0: 61 74 65 28 29 3b 20 7d 0a 20 20 20 20 20 20 7d ate(); }. }
0700: 2c 0a 20 20 20 20 20 20 61 6c 6c 3a 20 28 76 61 ,. all: (va
0710: 6c 75 65 73 29 20 3d 3e 20 7b 0a 20 20 20 20 20 lues) => {.
0720: 20 20 20 2f 2f 20 73 65 74 20 74 68 65 20 77 68 // set the wh
0730: 6f 6c 65 20 6d 61 74 72 69 78 20 75 73 69 6e 67 ole matrix using
0740: 20 61 20 32 64 20 61 72 72 61 79 20 61 73 20 69 a 2d array as i
0750: 6e 70 75 74 0a 20 20 20 20 20 20 20 20 2f 2f 20 nput. //
0760: 74 68 69 73 20 73 68 6f 75 6c 64 20 61 6c 73 6f this should also
0770: 20 72 65 73 69 7a 65 20 74 68 65 20 61 72 72 61 resize the arra
0780: 79 3f 0a 20 20 20 20 20 20 20 20 74 68 69 73 2e y?. this.
0790: 70 61 74 74 65 72 6e 20 3d 20 76 61 6c 75 65 73 pattern = values
07a0: 3b 0a 20 20 20 20 20 20 20 20 69 66 20 28 74 68 ;. if (th
07b0: 69 73 2e 75 69 29 20 7b 20 74 68 69 73 2e 75 69 is.ui) { this.ui
07c0: 2e 75 70 64 61 74 65 28 29 3b 20 7d 0a 20 20 20 .update(); }.
07d0: 20 20 20 7d 2c 0a 20 20 20 20 20 20 72 6f 77 3a },. row:
07e0: 20 28 72 6f 77 2c 76 61 6c 75 65 73 29 20 3d 3e (row,values) =>
07f0: 20 7b 0a 20 20 20 20 20 20 20 20 2f 2f 20 73 65 {. // se
0800: 74 20 61 20 72 6f 77 20 75 73 69 6e 67 20 61 6e t a row using an
0810: 20 61 72 72 61 79 20 61 73 20 69 6e 70 75 74 0a array as input.
0820: 20 20 20 20 20 20 20 20 74 68 69 73 2e 70 61 74 this.pat
0830: 74 65 72 6e 5b 72 6f 77 5d 20 3d 20 76 61 6c 75 tern[row] = valu
0840: 65 73 3b 0a 20 20 20 20 20 20 20 20 69 66 20 28 es;. if (
0850: 74 68 69 73 2e 75 69 29 20 7b 20 74 68 69 73 2e this.ui) { this.
0860: 75 69 2e 75 70 64 61 74 65 28 29 3b 20 7d 0a 20 ui.update(); }.
0870: 20 20 20 20 20 7d 2c 0a 20 20 20 20 20 20 63 6f },. co
0880: 6c 75 6d 6e 3a 20 28 63 6f 6c 75 6d 6e 2c 76 61 lumn: (column,va
0890: 6c 75 65 73 29 20 3d 3e 20 7b 0a 20 20 20 20 20 lues) => {.
08a0: 20 20 20 2f 2f 20 73 65 74 20 61 20 63 6f 6c 75 // set a colu
08b0: 6d 6e 20 75 73 69 6e 67 20 61 6e 20 61 72 72 61 mn using an arra
08c0: 79 20 61 73 20 69 6e 70 75 74 0a 20 20 20 20 20 y as input.
08d0: 20 20 20 74 68 69 73 2e 70 61 74 74 65 72 6e 2e this.pattern.
08e0: 66 6f 72 45 61 63 68 28 28 72 6f 77 2c 69 29 20 forEach((row,i)
08f0: 3d 3e 20 7b 0a 20 20 20 20 20 20 20 20 20 20 74 => {. t
0900: 68 69 73 2e 70 61 74 74 65 72 6e 5b 69 5d 5b 63 his.pattern[i][c
0910: 6f 6c 75 6d 6e 5d 20 3d 20 76 61 6c 75 65 73 5b olumn] = values[
0920: 69 5d 3b 0a 20 20 20 20 20 20 20 20 7d 29 3b 0a i];. });.
0930: 20 20 20 20 20 20 20 20 69 66 20 28 74 68 69 73 if (this
0940: 2e 75 69 29 20 7b 20 74 68 69 73 2e 75 69 2e 75 .ui) { this.ui.u
0950: 70 64 61 74 65 28 29 3b 20 7d 0a 20 20 20 20 20 pdate(); }.
0960: 20 7d 0a 20 20 20 20 7d 3b 0a 0a 20 20 20 20 74 }. };.. t
0970: 68 69 73 2e 72 6f 74 61 74 65 20 3d 20 7b 0a 20 his.rotate = {.
0980: 20 20 20 20 20 2f 2f 73 68 6f 75 6c 64 20 65 76 //should ev
0990: 65 6e 74 75 61 6c 6c 79 20 64 6f 20 28 61 6d 6f entually do (amo
09a0: 75 6e 74 58 2c 20 61 6d 6f 75 6e 74 59 29 20 68 untX, amountY) h
09b0: 65 72 65 0a 20 20 20 20 20 20 2f 2f 20 63 6f 75 ere. // cou
09c0: 6c 64 20 6a 75 73 74 20 75 73 65 20 61 20 6c 6f ld just use a lo
09d0: 6f 70 20 61 6e 64 20 74 68 69 73 2e 72 6f 74 61 op and this.rota
09e0: 74 65 2e 72 6f 77 28 69 2c 61 6d 6f 75 6e 74 58 te.row(i,amountX
09f0: 29 3b 0a 20 20 20 20 20 20 61 6c 6c 3a 20 28 61 );. all: (a
0a00: 6d 6f 75 6e 74 29 20 3d 3e 20 7b 0a 20 20 20 20 mount) => {.
0a10: 20 20 20 20 69 66 20 28 21 61 6d 6f 75 6e 74 20 if (!amount
0a20: 26 26 20 61 6d 6f 75 6e 74 21 3d 3d 30 29 20 7b && amount!==0) {
0a30: 0a 20 20 20 20 20 20 20 20 20 20 61 6d 6f 75 6e . amoun
0a40: 74 20 3d 20 31 3b 0a 20 20 20 20 20 20 20 20 7d t = 1;. }
0a50: 0a 20 20 20 20 20 20 20 20 61 6d 6f 75 6e 74 20 . amount
0a60: 25 3d 20 74 68 69 73 2e 70 61 74 74 65 72 6e 5b %= this.pattern[
0a70: 30 5d 2e 6c 65 6e 67 74 68 3b 0a 20 20 20 20 20 0].length;.
0a80: 20 20 20 69 66 20 28 61 6d 6f 75 6e 74 20 3c 20 if (amount <
0a90: 30 29 20 7b 0a 20 20 20 20 20 20 20 20 20 20 61 0) {. a
0aa0: 6d 6f 75 6e 74 20 3d 20 74 68 69 73 2e 70 61 74 mount = this.pat
0ab0: 74 65 72 6e 5b 30 5d 2e 6c 65 6e 67 74 68 20 2b tern[0].length +
0ac0: 20 61 6d 6f 75 6e 74 3b 0a 20 20 20 20 20 20 20 amount;.
0ad0: 20 7d 0a 20 20 20 20 20 20 20 20 66 6f 72 20 28 }. for (
0ae0: 6c 65 74 20 69 3d 30 3b 20 69 3c 74 68 69 73 2e let i=0; i<this.
0af0: 72 6f 77 73 3b 20 69 2b 2b 29 20 7b 0a 20 20 20 rows; i++) {.
0b00: 20 20 20 20 20 20 20 6c 65 74 20 63 75 74 20 3d let cut =
0b10: 20 74 68 69 73 2e 70 61 74 74 65 72 6e 5b 69 5d this.pattern[i]
0b20: 2e 73 70 6c 69 63 65 28 20 74 68 69 73 2e 70 61 .splice( this.pa
0b30: 74 74 65 72 6e 5b 69 5d 2e 6c 65 6e 67 74 68 20 ttern[i].length
0b40: 2d 20 61 6d 6f 75 6e 74 2c 20 61 6d 6f 75 6e 74 - amount, amount
0b50: 20 29 3b 0a 20 20 20 20 20 20 20 20 20 20 74 68 );. th
0b60: 69 73 2e 70 61 74 74 65 72 6e 5b 69 5d 20 3d 20 is.pattern[i] =
0b70: 63 75 74 2e 63 6f 6e 63 61 74 28 20 74 68 69 73 cut.concat( this
0b80: 2e 70 61 74 74 65 72 6e 5b 69 5d 20 29 3b 0a 20 .pattern[i] );.
0b90: 20 20 20 20 20 20 20 7d 0a 20 20 20 20 20 20 20 }.
0ba0: 20 69 66 20 28 74 68 69 73 2e 75 69 29 20 7b 20 if (this.ui) {
0bb0: 74 68 69 73 2e 75 69 2e 75 70 64 61 74 65 28 29 this.ui.update()
0bc0: 3b 20 7d 0a 20 20 20 20 20 20 7d 2c 0a 20 20 20 ; }. },.
0bd0: 20 20 20 72 6f 77 3a 20 28 72 6f 77 2c 61 6d 6f row: (row,amo
0be0: 75 6e 74 29 20 3d 3e 20 7b 0a 20 20 20 20 20 20 unt) => {.
0bf0: 20 20 69 66 20 28 21 61 6d 6f 75 6e 74 20 26 26 if (!amount &&
0c00: 20 61 6d 6f 75 6e 74 21 3d 3d 30 29 20 7b 0a 20 amount!==0) {.
0c10: 20 20 20 20 20 20 20 20 20 61 6d 6f 75 6e 74 20 amount
0c20: 3d 20 31 3b 0a 20 20 20 20 20 20 20 20 7d 0a 20 = 1;. }.
0c30: 20 20 20 20 20 20 20 61 6d 6f 75 6e 74 20 25 3d amount %=
0c40: 20 74 68 69 73 2e 70 61 74 74 65 72 6e 5b 30 5d this.pattern[0]
0c50: 2e 6c 65 6e 67 74 68 3b 0a 20 20 20 20 20 20 20 .length;.
0c60: 20 69 66 20 28 61 6d 6f 75 6e 74 20 3c 20 30 29 if (amount < 0)
0c70: 20 7b 0a 20 20 20 20 20 20 20 20 20 20 61 6d 6f {. amo
0c80: 75 6e 74 20 3d 20 74 68 69 73 2e 70 61 74 74 65 unt = this.patte
0c90: 72 6e 5b 30 5d 2e 6c 65 6e 67 74 68 20 2b 20 61 rn[0].length + a
0ca0: 6d 6f 75 6e 74 3b 0a 20 20 20 20 20 20 20 20 7d mount;. }
0cb0: 0a 20 20 20 20 20 20 20 20 6c 65 74 20 63 75 74 . let cut
0cc0: 20 3d 20 74 68 69 73 2e 70 61 74 74 65 72 6e 5b = this.pattern[
0cd0: 72 6f 77 5d 2e 73 70 6c 69 63 65 28 20 74 68 69 row].splice( thi
0ce0: 73 2e 70 61 74 74 65 72 6e 5b 72 6f 77 5d 2e 6c s.pattern[row].l
0cf0: 65 6e 67 74 68 20 2d 20 61 6d 6f 75 6e 74 2c 20 ength - amount,
0d00: 61 6d 6f 75 6e 74 20 29 3b 0a 20 20 20 20 20 20 amount );.
0d10: 20 20 74 68 69 73 2e 70 61 74 74 65 72 6e 5b 72 this.pattern[r
0d20: 6f 77 5d 20 3d 20 63 75 74 2e 63 6f 6e 63 61 74 ow] = cut.concat
0d30: 28 20 74 68 69 73 2e 70 61 74 74 65 72 6e 5b 72 ( this.pattern[r
0d40: 6f 77 5d 20 29 3b 0a 20 20 20 20 20 20 20 20 69 ow] );. i
0d50: 66 20 28 74 68 69 73 2e 75 69 29 20 7b 20 74 68 f (this.ui) { th
0d60: 69 73 2e 75 69 2e 75 70 64 61 74 65 28 29 3b 20 is.ui.update();
0d70: 7d 0a 20 20 20 20 20 20 7d 2c 0a 20 20 20 20 20 }. },.
0d80: 20 63 6f 6c 75 6d 6e 3a 20 28 63 6f 6c 75 6d 6e column: (column
0d90: 2c 20 61 6d 6f 75 6e 74 29 20 3d 3e 20 7b 0a 20 , amount) => {.
0da0: 20 20 20 20 20 20 20 69 66 20 28 21 61 6d 6f 75 if (!amou
0db0: 6e 74 20 26 26 20 61 6d 6f 75 6e 74 21 3d 3d 30 nt && amount!==0
0dc0: 29 20 7b 0a 20 20 20 20 20 20 20 20 20 20 61 6d ) {. am
0dd0: 6f 75 6e 74 20 3d 20 31 3b 0a 20 20 20 20 20 20 ount = 1;.
0de0: 20 20 7d 0a 20 20 20 20 20 20 20 20 61 6d 6f 75 }. amou
0df0: 6e 74 20 25 3d 20 74 68 69 73 2e 70 61 74 74 65 nt %= this.patte
0e00: 72 6e 2e 6c 65 6e 67 74 68 3b 0a 20 20 20 20 20 rn.length;.
0e10: 20 20 20 69 66 20 28 61 6d 6f 75 6e 74 20 3c 20 if (amount <
0e20: 30 29 20 7b 0a 20 20 20 20 20 20 20 20 20 20 61 0) {. a
0e30: 6d 6f 75 6e 74 20 3d 20 74 68 69 73 2e 70 61 74 mount = this.pat
0e40: 74 65 72 6e 2e 6c 65 6e 67 74 68 20 2b 20 61 6d tern.length + am
0e50: 6f 75 6e 74 3b 0a 20 20 20 20 20 20 20 20 7d 0a ount;. }.
0e60: 20 20 20 20 20 20 20 20 6c 65 74 20 70 72 6f 78 let prox
0e70: 79 20 3d 20 5b 5d 3b 0a 20 20 20 20 20 20 20 20 y = [];.
0e80: 74 68 69 73 2e 70 61 74 74 65 72 6e 2e 66 6f 72 this.pattern.for
0e90: 45 61 63 68 28 28 72 6f 77 29 20 3d 3e 20 7b 0a Each((row) => {.
0ea0: 20 20 20 20 20 20 20 20 20 20 70 72 6f 78 79 2e proxy.
0eb0: 70 75 73 68 28 20 72 6f 77 5b 63 6f 6c 75 6d 6e push( row[column
0ec0: 5d 20 29 3b 0a 20 20 20 20 20 20 20 20 7d 29 3b ] );. });
0ed0: 0a 20 20 20 20 20 20 20 20 6c 65 74 20 63 75 74 . let cut
0ee0: 20 3d 20 70 72 6f 78 79 2e 73 70 6c 69 63 65 28 = proxy.splice(
0ef0: 20 70 72 6f 78 79 2e 6c 65 6e 67 74 68 20 2d 20 proxy.length -
0f00: 61 6d 6f 75 6e 74 2c 20 61 6d 6f 75 6e 74 20 29 amount, amount )
0f10: 3b 0a 20 20 20 20 20 20 20 20 70 72 6f 78 79 20 ;. proxy
0f20: 3d 20 63 75 74 2e 63 6f 6e 63 61 74 28 20 70 72 = cut.concat( pr
0f30: 6f 78 79 20 29 3b 0a 20 20 20 20 20 20 20 20 74 oxy );. t
0f40: 68 69 73 2e 70 61 74 74 65 72 6e 2e 66 6f 72 45 his.pattern.forE
0f50: 61 63 68 28 28 72 6f 77 2c 69 29 20 3d 3e 20 7b ach((row,i) => {
0f60: 0a 20 20 20 20 20 20 20 20 20 20 72 6f 77 5b 63 . row[c
0f70: 6f 6c 75 6d 6e 5d 20 3d 20 70 72 6f 78 79 5b 69 olumn] = proxy[i
0f80: 5d 3b 0a 20 20 20 20 20 20 20 20 7d 29 3b 0a 20 ];. });.
0f90: 20 20 20 20 20 20 20 69 66 20 28 74 68 69 73 2e if (this.
0fa0: 75 69 29 20 7b 20 74 68 69 73 2e 75 69 2e 75 70 ui) { this.ui.up
0fb0: 64 61 74 65 28 29 3b 20 7d 0a 20 20 20 20 20 20 date(); }.
0fc0: 7d 0a 20 20 20 20 7d 3b 0a 0a 20 20 20 20 2f 2f }. };.. //
0fd0: 20 74 68 65 20 69 64 65 61 20 62 65 68 69 6e 64 the idea behind
0fe0: 20 70 6f 70 75 6c 61 74 65 20 69 73 20 74 6f 20 populate is to
0ff0: 62 65 20 61 62 6c 65 20 74 6f 20 73 65 74 20 61 be able to set a
1000: 20 77 68 6f 6c 65 20 72 6f 77 20 6f 72 20 63 6f whole row or co
1010: 6c 75 6d 6e 20 74 6f 20 30 20 6f 72 20 31 0a 20 lumn to 0 or 1.
1020: 20 20 20 2f 2f 20 49 46 20 74 68 65 20 76 61 6c // IF the val
1030: 75 65 20 69 73 20 61 20 66 6c 6f 61 74 2c 20 73 ue is a float, s
1040: 75 63 68 20 61 73 20 30 2e 37 2c 20 74 68 65 6e uch as 0.7, then
1050: 20 69 74 20 77 6f 75 6c 64 20 62 65 63 6f 6d 65 it would become
1060: 20 61 20 70 72 6f 62 61 62 69 6c 69 74 79 0a 20 a probability.
1070: 20 20 20 2f 2f 20 73 6f 20 70 6f 70 75 6c 61 74 // so populat
1080: 65 28 30 2e 37 29 20 77 6f 75 6c 64 20 67 69 76 e(0.7) would giv
1090: 65 20 65 61 63 68 20 63 65 6c 6c 20 61 20 37 30 e each cell a 70
10a0: 25 20 63 68 61 6e 63 65 20 6f 66 20 62 65 69 6e % chance of bein
10b0: 67 20 31 0a 20 20 20 20 74 68 69 73 2e 70 6f 70 g 1. this.pop
10c0: 75 6c 61 74 65 20 3d 20 7b 0a 20 20 20 20 20 20 ulate = {.
10d0: 61 6c 6c 3a 20 28 6f 64 64 73 29 20 3d 3e 20 7b all: (odds) => {
10e0: 0a 20 20 20 20 20 20 20 20 6c 65 74 20 6f 64 64 . let odd
10f0: 73 53 65 71 75 65 6e 63 65 20 3d 20 6e 65 77 20 sSequence = new
1100: 53 65 71 75 65 6e 63 65 28 6f 64 64 73 29 3b 0a Sequence(odds);.
1110: 20 20 20 20 20 20 20 20 74 68 69 73 2e 69 74 65 this.ite
1120: 72 61 74 65 28 28 72 2c 63 29 20 3d 3e 20 7b 0a rate((r,c) => {.
1130: 20 20 20 20 20 20 20 20 20 20 74 68 69 73 2e 70 this.p
1140: 61 74 74 65 72 6e 5b 72 5d 5b 63 5d 20 3d 20 6d attern[r][c] = m
1150: 61 74 68 2e 63 6f 69 6e 28 6f 64 64 73 53 65 71 ath.coin(oddsSeq
1160: 75 65 6e 63 65 2e 6e 65 78 74 28 29 29 3b 0a 20 uence.next());.
1170: 20 20 20 20 20 20 20 7d 29 3b 0a 20 20 20 20 20 });.
1180: 20 20 20 2f 2f 20 54 68 69 73 20 63 6f 75 6c 64 // This could
1190: 20 62 65 20 75 73 65 64 20 73 6f 20 74 68 61 74 be used so that
11a0: 20 65 61 63 68 20 72 6f 77 20 68 61 73 20 73 61 each row has sa
11b0: 6d 65 20 6f 64 64 73 20 70 61 74 74 65 72 6e 2c me odds pattern,
11c0: 20 65 76 65 6e 20 69 66 20 72 6f 77 20 6c 65 6e even if row len
11d0: 67 74 68 20 69 73 20 6e 6f 74 20 64 69 76 69 73 gth is not divis
11e0: 69 62 6c 79 20 62 79 20 73 65 71 75 65 6e 63 65 ibly by sequence
11f0: 20 6c 65 6e 67 74 68 2e 0a 20 20 20 20 20 20 20 length..
1200: 20 2f 2f 2c 28 29 20 3d 3e 20 7b 0a 20 20 20 20 //,() => {.
1210: 20 20 20 20 2f 2f 20 20 6f 64 64 73 2e 70 6f 73 // odds.pos
1220: 20 3d 20 2d 31 3b 0a 20 20 20 20 20 20 20 20 2f = -1;. /
1230: 2f 20 7d 0a 20 20 20 20 20 20 20 20 69 66 20 28 / }. if (
1240: 74 68 69 73 2e 75 69 29 20 7b 20 74 68 69 73 2e this.ui) { this.
1250: 75 69 2e 75 70 64 61 74 65 28 29 3b 20 7d 0a 20 ui.update(); }.
1260: 20 20 20 20 20 7d 2c 0a 20 20 20 20 20 20 72 6f },. ro
1270: 77 3a 20 28 72 6f 77 3d 30 2c 6f 64 64 73 3d 31 w: (row=0,odds=1
1280: 29 20 3d 3e 20 7b 0a 20 20 20 20 20 20 20 20 6c ) => {. l
1290: 65 74 20 6f 64 64 73 53 65 71 75 65 6e 63 65 20 et oddsSequence
12a0: 3d 20 6e 65 77 20 53 65 71 75 65 6e 63 65 28 6f = new Sequence(o
12b0: 64 64 73 29 3b 0a 20 20 20 20 20 20 20 20 74 68 dds);. th
12c0: 69 73 2e 70 61 74 74 65 72 6e 5b 72 6f 77 5d 2e is.pattern[row].
12d0: 66 6f 72 45 61 63 68 28 28 63 65 6c 6c 2c 69 29 forEach((cell,i)
12e0: 20 3d 3e 20 7b 0a 20 20 20 20 20 20 20 20 20 20 => {.
12f0: 74 68 69 73 2e 70 61 74 74 65 72 6e 5b 72 6f 77 this.pattern[row
1300: 5d 5b 69 5d 20 3d 20 6d 61 74 68 2e 63 6f 69 6e ][i] = math.coin
1310: 28 6f 64 64 73 53 65 71 75 65 6e 63 65 2e 6e 65 (oddsSequence.ne
1320: 78 74 28 29 29 3b 0a 20 20 20 20 20 20 20 20 7d xt());. }
1330: 29 3b 0a 20 20 20 20 20 20 20 20 69 66 20 28 74 );. if (t
1340: 68 69 73 2e 75 69 29 20 7b 20 74 68 69 73 2e 75 his.ui) { this.u
1350: 69 2e 75 70 64 61 74 65 28 29 3b 20 7d 0a 20 20 i.update(); }.
1360: 20 20 20 20 7d 2c 0a 20 20 20 20 20 20 63 6f 6c },. col
1370: 75 6d 6e 3a 20 28 63 6f 6c 75 6d 6e 3d 30 2c 6f umn: (column=0,o
1380: 64 64 73 3d 31 29 20 3d 3e 20 7b 0a 20 20 20 20 dds=1) => {.
1390: 20 20 20 20 6c 65 74 20 6f 64 64 73 53 65 71 75 let oddsSequ
13a0: 65 6e 63 65 20 3d 20 6e 65 77 20 53 65 71 75 65 ence = new Seque
13b0: 6e 63 65 28 6f 64 64 73 29 3b 0a 20 20 20 20 20 nce(odds);.
13c0: 20 20 20 74 68 69 73 2e 70 61 74 74 65 72 6e 2e this.pattern.
13d0: 66 6f 72 45 61 63 68 28 28 72 6f 77 2c 69 29 20 forEach((row,i)
13e0: 3d 3e 20 7b 0a 20 20 20 20 20 20 20 20 20 20 74 => {. t
13f0: 68 69 73 2e 70 61 74 74 65 72 6e 5b 69 5d 5b 63 his.pattern[i][c
1400: 6f 6c 75 6d 6e 5d 20 3d 20 6d 61 74 68 2e 63 6f olumn] = math.co
1410: 69 6e 28 6f 64 64 73 53 65 71 75 65 6e 63 65 2e in(oddsSequence.
1420: 6e 65 78 74 28 29 29 3b 0a 20 20 20 20 20 20 20 next());.
1430: 20 7d 29 3b 0a 20 20 20 20 20 20 20 20 69 66 20 });. if
1440: 28 74 68 69 73 2e 75 69 29 20 7b 20 74 68 69 73 (this.ui) { this
1450: 2e 75 69 2e 75 70 64 61 74 65 28 29 3b 20 7d 0a .ui.update(); }.
1460: 20 20 20 20 20 20 7d 0a 20 20 20 20 7d 3b 0a 0a }. };..
1470: 20 20 20 20 2f 2f 20 65 73 73 65 6e 74 69 61 6c // essential
1480: 6c 20 70 6f 70 75 6c 61 74 65 28 30 29 20 73 6f l populate(0) so
1490: 20 69 27 6d 20 6e 6f 74 20 73 75 72 65 20 69 66 i'm not sure if
14a0: 20 74 68 69 73 20 69 73 20 6e 65 63 65 73 73 61 this is necessa
14b0: 72 79 20 62 75 74 20 69 73 20 6e 69 63 65 0a 20 ry but is nice.
14c0: 20 20 20 74 68 69 73 2e 65 72 61 73 65 20 3d 20 this.erase =
14d0: 7b 0a 20 20 20 20 20 20 61 6c 6c 3a 20 28 29 20 {. all: ()
14e0: 3d 3e 20 7b 0a 20 20 20 20 20 20 20 20 74 68 69 => {. thi
14f0: 73 2e 73 65 74 2e 61 6c 6c 28 30 29 3b 0a 20 20 s.set.all(0);.
1500: 20 20 20 20 7d 2c 0a 20 20 20 20 20 20 72 6f 77 },. row
1510: 3a 20 28 72 6f 77 29 20 3d 3e 20 7b 0a 20 20 20 : (row) => {.
1520: 20 20 20 20 20 74 68 69 73 2e 73 65 74 2e 72 6f this.set.ro
1530: 77 28 72 6f 77 2c 30 29 3b 0a 20 20 20 20 20 20 w(row,0);.
1540: 7d 2c 0a 20 20 20 20 20 20 63 6f 6c 75 6d 6e 3a },. column:
1550: 20 28 63 6f 6c 75 6d 6e 29 20 3d 3e 20 7b 0a 20 (column) => {.
1560: 20 20 20 20 20 20 20 74 68 69 73 2e 73 65 74 2e this.set.
1570: 63 6f 6c 75 6d 6e 28 63 6f 6c 75 6d 6e 2c 30 29 column(column,0)
1580: 3b 0a 20 20 20 20 20 20 7d 0a 20 20 20 20 7d 3b ;. }. };
1590: 0a 0a 20 20 2f 2f 20 65 6e 64 20 63 6f 6e 73 74 .. // end const
15a0: 72 75 63 74 6f 72 0a 20 20 7d 0a 0a 0a 20 20 63 ructor. }... c
15b0: 72 65 61 74 65 28 72 6f 77 73 2c 63 6f 6c 75 6d reate(rows,colum
15c0: 6e 73 29 20 7b 0a 20 20 20 20 74 68 69 73 2e 70 ns) {. this.p
15d0: 61 74 74 65 72 6e 20 3d 20 5b 5d 3b 0a 20 20 20 attern = [];.
15e0: 20 66 6f 72 20 28 20 6c 65 74 20 72 6f 77 3d 30 for ( let row=0
15f0: 3b 20 72 6f 77 20 3c 20 72 6f 77 73 3b 20 72 6f ; row < rows; ro
1600: 77 2b 2b 20 29 20 7b 0a 20 20 20 20 20 20 6c 65 w++ ) {. le
1610: 74 20 61 72 72 20 3d 20 6e 65 77 20 41 72 72 61 t arr = new Arra
1620: 79 28 63 6f 6c 75 6d 6e 73 29 3b 0a 20 20 20 20 y(columns);.
1630: 20 20 74 68 69 73 2e 70 61 74 74 65 72 6e 2e 70 this.pattern.p
1640: 75 73 68 28 61 72 72 29 3b 0a 20 20 20 20 7d 0a ush(arr);. }.
1650: 20 20 20 20 74 68 69 73 2e 69 74 65 72 61 74 65 this.iterate
1660: 28 28 72 2c 63 29 20 3d 3e 20 7b 20 74 68 69 73 ((r,c) => { this
1670: 2e 70 61 74 74 65 72 6e 5b 72 5d 5b 63 5d 20 3d .pattern[r][c] =
1680: 20 66 61 6c 73 65 3b 20 7d 29 3b 0a 20 20 7d 0a false; });. }.
1690: 0a 20 20 69 74 65 72 61 74 65 28 66 2c 20 66 32 . iterate(f, f2
16a0: 29 20 7b 0a 20 20 20 20 6c 65 74 20 69 20 3d 20 ) {. let i =
16b0: 30 3b 0a 20 20 20 20 66 6f 72 20 28 20 6c 65 74 0;. for ( let
16c0: 20 72 6f 77 3d 30 3b 20 72 6f 77 20 3c 20 74 68 row=0; row < th
16d0: 69 73 2e 72 6f 77 73 3b 20 72 6f 77 2b 2b 20 29 is.rows; row++ )
16e0: 20 7b 0a 20 20 20 20 20 20 69 66 20 28 66 32 29 {. if (f2)
16f0: 20 7b 20 66 32 28 72 6f 77 29 3b 20 7d 0a 20 20 { f2(row); }.
1700: 20 20 20 20 66 6f 72 20 28 20 6c 65 74 20 63 6f for ( let co
1710: 6c 75 6d 6e 3d 30 3b 20 63 6f 6c 75 6d 6e 20 3c lumn=0; column <
1720: 20 74 68 69 73 2e 63 6f 6c 75 6d 6e 73 3b 20 63 this.columns; c
1730: 6f 6c 75 6d 6e 2b 2b 20 29 20 7b 0a 20 20 20 20 olumn++ ) {.
1740: 20 20 20 20 66 28 72 6f 77 2c 63 6f 6c 75 6d 6e f(row,column
1750: 2c 69 29 3b 0a 20 20 20 20 20 20 20 20 69 2b 2b ,i);. i++
1760: 3b 0a 20 20 20 20 20 20 7d 0a 20 20 20 20 7d 0a ;. }. }.
1770: 20 20 7d 0a 0a 20 20 66 6f 72 6d 61 74 41 73 54 }.. formatAsT
1780: 65 78 74 28 29 20 7b 0a 20 20 20 20 6c 65 74 20 ext() {. let
1790: 70 61 74 74 65 72 6e 53 74 72 69 6e 67 20 3d 20 patternString =
17a0: 27 27 3b 0a 20 20 20 20 74 68 69 73 2e 69 74 65 '';. this.ite
17b0: 72 61 74 65 28 0a 20 20 20 20 20 20 28 72 2c 63 rate(. (r,c
17c0: 29 20 3d 3e 20 7b 20 70 61 74 74 65 72 6e 53 74 ) => { patternSt
17d0: 72 69 6e 67 20 2b 3d 20 28 74 68 69 73 2e 70 61 ring += (this.pa
17e0: 74 74 65 72 6e 5b 72 5d 5b 63 5d 20 3f 20 31 20 ttern[r][c] ? 1
17f0: 3a 20 30 29 20 2b 20 27 20 27 3b 20 7d 2c 0a 20 : 0) + ' '; },.
1800: 20 20 20 20 20 28 29 20 3d 3e 20 7b 20 70 61 74 () => { pat
1810: 74 65 72 6e 53 74 72 69 6e 67 20 2b 3d 20 27 5c ternString += '\
1820: 6e 27 3b 20 7d 0a 20 20 20 20 29 3b 0a 20 20 20 n'; }. );.
1830: 20 72 65 74 75 72 6e 20 70 61 74 74 65 72 6e 53 return patternS
1840: 74 72 69 6e 67 3b 0a 20 20 7d 0a 0a 20 20 6c 6f tring;. }.. lo
1850: 67 28 29 20 7b 0a 20 20 20 20 63 6f 6e 73 6f 6c g() {. consol
1860: 65 2e 6c 6f 67 28 74 68 69 73 2e 66 6f 72 6d 61 e.log(this.forma
1870: 74 41 73 54 65 78 74 28 29 29 3b 0a 20 20 7d 0a tAsText());. }.
1880: 0a 20 20 75 70 64 61 74 65 28 70 61 74 74 65 72 . update(patter
1890: 6e 29 20 7b 0a 20 20 20 20 74 68 69 73 2e 70 61 n) {. this.pa
18a0: 74 74 65 72 6e 20 3d 20 70 61 74 74 65 72 6e 20 ttern = pattern
18b0: 7c 7c 20 74 68 69 73 2e 70 61 74 74 65 72 6e 3b || this.pattern;
18c0: 0a 20 20 7d 0a 0a 20 20 67 65 74 20 6c 65 6e 67 . }.. get leng
18d0: 74 68 28 29 20 7b 0a 20 20 20 20 72 65 74 75 72 th() {. retur
18e0: 6e 20 74 68 69 73 2e 72 6f 77 73 2a 74 68 69 73 n this.rows*this
18f0: 2e 63 6f 6c 75 6d 6e 73 3b 0a 20 20 7d 0a 0a 20 .columns;. }..
1900: 20 6c 6f 63 61 74 65 28 69 6e 64 65 78 29 20 7b locate(index) {
1910: 0a 20 20 20 20 2f 2f 20 72 65 74 75 72 6e 73 20 . // returns
1920: 72 6f 77 20 61 6e 64 20 63 6f 6c 75 6d 6e 20 6f row and column o
1930: 66 20 63 65 6c 6c 20 62 79 20 69 6e 64 65 78 0a f cell by index.
1940: 20 20 20 20 72 65 74 75 72 6e 20 7b 0a 20 20 20 return {.
1950: 20 20 20 72 6f 77 3a 20 7e 7e 28 20 69 6e 64 65 row: ~~( inde
1960: 78 20 2f 20 74 68 69 73 2e 63 6f 6c 75 6d 6e 73 x / this.columns
1970: 20 29 2c 0a 20 20 20 20 20 20 63 6f 6c 75 6d 6e ),. column
1980: 3a 20 69 6e 64 65 78 20 25 20 74 68 69 73 2e 63 : index % this.c
1990: 6f 6c 75 6d 6e 73 0a 20 20 20 20 7d 3b 0a 20 20 olumns. };.
19a0: 7d 0a 0a 20 20 69 6e 64 65 78 4f 66 28 72 6f 77 }.. indexOf(row
19b0: 2c 63 6f 6c 75 6d 6e 29 20 7b 0a 20 20 20 20 72 ,column) {. r
19c0: 65 74 75 72 6e 20 63 6f 6c 75 6d 6e 20 2b 20 72 eturn column + r
19d0: 6f 77 20 2a 20 74 68 69 73 2e 63 6f 6c 75 6d 6e ow * this.column
19e0: 73 3b 0a 20 20 20 20 2f 2f 20 72 65 74 75 72 6e s;. // return
19f0: 73 20 69 6e 64 65 78 20 6f 66 20 63 65 6c 6c 20 s index of cell
1a00: 62 79 20 72 6f 77 20 61 6e 64 20 63 6f 6c 75 6d by row and colum
1a10: 6e 0a 20 20 7d 0a 0a 20 20 72 6f 77 28 72 6f 77 n. }.. row(row
1a20: 29 20 7b 0a 20 20 20 20 6c 65 74 20 64 61 74 61 ) {. let data
1a30: 20 3d 20 5b 5d 3b 0a 20 20 20 20 66 6f 72 20 28 = [];. for (
1a40: 6c 65 74 20 69 3d 30 3b 20 69 3c 74 68 69 73 2e let i=0; i<this.
1a50: 63 6f 6c 75 6d 6e 73 3b 20 69 2b 2b 29 20 7b 0a columns; i++) {.
1a60: 20 20 20 20 20 20 64 61 74 61 2e 70 75 73 68 28 data.push(
1a70: 74 68 69 73 2e 70 61 74 74 65 72 6e 5b 72 6f 77 this.pattern[row
1a80: 5d 20 3f 20 31 20 3a 20 30 29 3b 0a 20 20 20 20 ] ? 1 : 0);.
1a90: 7d 0a 20 20 20 20 72 65 74 75 72 6e 20 64 61 74 }. return dat
1aa0: 61 3b 0a 20 20 7d 0a 0a 20 20 63 6f 6c 75 6d 6e a;. }.. column
1ab0: 28 63 6f 6c 75 6d 6e 29 20 7b 0a 20 20 20 20 6c (column) {. l
1ac0: 65 74 20 64 61 74 61 20 3d 20 5b 5d 3b 0a 20 20 et data = [];.
1ad0: 20 20 66 6f 72 20 28 6c 65 74 20 69 3d 30 3b 20 for (let i=0;
1ae0: 69 3c 74 68 69 73 2e 72 6f 77 73 3b 20 69 2b 2b i<this.rows; i++
1af0: 29 20 7b 0a 20 20 20 20 20 20 64 61 74 61 2e 70 ) {. data.p
1b00: 75 73 68 28 74 68 69 73 2e 70 61 74 74 65 72 6e ush(this.pattern
1b10: 5b 69 5d 5b 63 6f 6c 75 6d 6e 5d 20 3f 20 31 20 [i][column] ? 1
1b20: 3a 20 30 29 3b 0a 20 20 20 20 7d 0a 20 20 20 20 : 0);. }.
1b30: 72 65 74 75 72 6e 20 64 61 74 61 3b 0a 20 20 7d return data;. }
1b40: 0a 0a 20 20 67 65 74 20 72 6f 77 73 28 29 20 7b .. get rows() {
1b50: 0a 20 20 20 20 72 65 74 75 72 6e 20 74 68 69 73 . return this
1b60: 2e 70 61 74 74 65 72 6e 2e 6c 65 6e 67 74 68 3b .pattern.length;
1b70: 0a 20 20 7d 0a 20 20 73 65 74 20 72 6f 77 73 28 . }. set rows(
1b80: 76 29 20 7b 0a 20 20 20 20 6c 65 74 20 70 72 65 v) {. let pre
1b90: 76 69 6f 75 73 20 3d 20 74 68 69 73 2e 70 61 74 vious = this.pat
1ba0: 74 65 72 6e 2e 73 6c 69 63 65 28 30 29 3b 0a 20 tern.slice(0);.
1bb0: 20 20 20 74 68 69 73 2e 63 72 65 61 74 65 28 76 this.create(v
1bc0: 2c 74 68 69 73 2e 63 6f 6c 75 6d 6e 73 29 3b 0a ,this.columns);.
1bd0: 20 20 20 20 74 68 69 73 2e 69 74 65 72 61 74 65 this.iterate
1be0: 28 28 72 2c 63 29 20 3d 3e 20 7b 0a 20 20 20 20 ((r,c) => {.
1bf0: 20 20 69 66 20 28 70 72 65 76 69 6f 75 73 5b 72 if (previous[r
1c00: 5d 20 26 26 20 70 72 65 76 69 6f 75 73 5b 72 5d ] && previous[r]
1c10: 5b 63 5d 29 20 7b 0a 20 20 20 20 20 20 20 20 74 [c]) {. t
1c20: 68 69 73 2e 70 61 74 74 65 72 6e 5b 72 5d 5b 63 his.pattern[r][c
1c30: 5d 20 3d 20 70 72 65 76 69 6f 75 73 5b 72 5d 5b ] = previous[r][
1c40: 63 5d 3b 0a 20 20 20 20 20 20 7d 0a 20 20 20 20 c];. }.
1c50: 7d 29 3b 0a 20 20 7d 0a 0a 20 20 67 65 74 20 63 });. }.. get c
1c60: 6f 6c 75 6d 6e 73 28 29 20 7b 0a 20 20 20 20 72 olumns() {. r
1c70: 65 74 75 72 6e 20 74 68 69 73 2e 70 61 74 74 65 eturn this.patte
1c80: 72 6e 5b 30 5d 2e 6c 65 6e 67 74 68 3b 0a 20 20 rn[0].length;.
1c90: 7d 0a 20 20 73 65 74 20 63 6f 6c 75 6d 6e 73 28 }. set columns(
1ca0: 76 29 20 7b 0a 20 20 20 20 6c 65 74 20 70 72 65 v) {. let pre
1cb0: 76 69 6f 75 73 20 3d 20 74 68 69 73 2e 70 61 74 vious = this.pat
1cc0: 74 65 72 6e 2e 73 6c 69 63 65 28 30 29 3b 0a 20 tern.slice(0);.
1cd0: 20 20 20 74 68 69 73 2e 63 72 65 61 74 65 28 74 this.create(t
1ce0: 68 69 73 2e 72 6f 77 73 2c 76 29 3b 0a 20 20 20 his.rows,v);.
1cf0: 20 74 68 69 73 2e 69 74 65 72 61 74 65 28 28 72 this.iterate((r
1d00: 2c 63 29 20 3d 3e 20 7b 0a 20 20 20 20 20 20 69 ,c) => {. i
1d10: 66 20 28 70 72 65 76 69 6f 75 73 5b 72 5d 20 26 f (previous[r] &
1d20: 26 20 70 72 65 76 69 6f 75 73 5b 72 5d 5b 63 5d & previous[r][c]
1d30: 29 20 7b 0a 20 20 20 20 20 20 20 20 74 68 69 73 ) {. this
1d40: 2e 70 61 74 74 65 72 6e 5b 72 5d 5b 63 5d 20 3d .pattern[r][c] =
1d50: 20 70 72 65 76 69 6f 75 73 5b 72 5d 5b 63 5d 3b previous[r][c];
1d60: 0a 20 20 20 20 20 20 7d 0a 20 20 20 20 7d 29 3b . }. });
1d70: 0a 20 20 7d 0a 0a 7d 0a . }..}.