⌈⌋ ⎇ branch:  Bitrhythm


Hex Artifact Content

Artifact 9db567f394ca3a2b2c4d5d53d21ba6011525693185dfb63fade9cd3c615a5989:


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                          .  }..}.