@scrabble-solver/solver 2.12.1 → 2.12.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +1 -1
- package/build/areDigraphsValid.d.ts +3 -0
- package/build/areDigraphsValid.js +16 -0
- package/build/index.d.ts +1 -0
- package/build/index.js +3 -1
- package/build/solve.js +3 -1
- package/package.json +7 -7
- package/src/areDigraphsValid.ts +20 -0
- package/src/getPatternScore.test.ts +9 -0
- package/src/index.ts +1 -0
- package/src/solve.test.ts +25 -1
- package/src/solve.ts +3 -1
package/README.md
CHANGED
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
const areDigraphsValid = (config, pattern) => {
|
|
4
|
+
const { twoCharacterTiles } = config;
|
|
5
|
+
const { cells } = pattern;
|
|
6
|
+
for (let index = 0; index < cells.length - 1; ++index) {
|
|
7
|
+
const current = cells[index];
|
|
8
|
+
const next = cells[index + 1];
|
|
9
|
+
const digraphCandidate = current.tile.character + next.tile.character;
|
|
10
|
+
if (twoCharacterTiles.includes(digraphCandidate)) {
|
|
11
|
+
return false;
|
|
12
|
+
}
|
|
13
|
+
}
|
|
14
|
+
return true;
|
|
15
|
+
};
|
|
16
|
+
exports.default = areDigraphsValid;
|
package/build/index.d.ts
CHANGED
|
@@ -1,3 +1,4 @@
|
|
|
1
|
+
export { default as areDigraphsValid } from './areDigraphsValid';
|
|
1
2
|
export { default as fillPattern } from './fillPattern';
|
|
2
3
|
export { default as generateEndIndices } from './generateEndIndices';
|
|
3
4
|
export { default as generateHorizontalPatterns } from './generateHorizontalPatterns';
|
package/build/index.js
CHANGED
|
@@ -3,7 +3,9 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
|
3
3
|
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
4
|
};
|
|
5
5
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
-
exports.solve = exports.getUniquePatterns = exports.getPatternScore = exports.getPatternHash = exports.getCellsScore = exports.generateVerticalPatterns = exports.generateVectors = exports.generateStartIndices = exports.generatePatterns = exports.generatePattern = exports.generateHorizontalPatterns = exports.generateEndIndices = exports.fillPattern = void 0;
|
|
6
|
+
exports.solve = exports.getUniquePatterns = exports.getPatternScore = exports.getPatternHash = exports.getCellsScore = exports.generateVerticalPatterns = exports.generateVectors = exports.generateStartIndices = exports.generatePatterns = exports.generatePattern = exports.generateHorizontalPatterns = exports.generateEndIndices = exports.fillPattern = exports.areDigraphsValid = void 0;
|
|
7
|
+
var areDigraphsValid_1 = require("./areDigraphsValid");
|
|
8
|
+
Object.defineProperty(exports, "areDigraphsValid", { enumerable: true, get: function () { return __importDefault(areDigraphsValid_1).default; } });
|
|
7
9
|
var fillPattern_1 = require("./fillPattern");
|
|
8
10
|
Object.defineProperty(exports, "fillPattern", { enumerable: true, get: function () { return __importDefault(fillPattern_1).default; } });
|
|
9
11
|
var generateEndIndices_1 = require("./generateEndIndices");
|
package/build/solve.js
CHANGED
|
@@ -3,6 +3,7 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
|
3
3
|
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
4
|
};
|
|
5
5
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
const areDigraphsValid_1 = __importDefault(require("./areDigraphsValid"));
|
|
6
7
|
const fillPattern_1 = __importDefault(require("./fillPattern"));
|
|
7
8
|
const generatePatterns_1 = __importDefault(require("./generatePatterns"));
|
|
8
9
|
const getPatternScore_1 = __importDefault(require("./getPatternScore"));
|
|
@@ -10,7 +11,8 @@ const getUniquePatterns_1 = __importDefault(require("./getUniquePatterns"));
|
|
|
10
11
|
const solve = (trie, config, board, tiles) => {
|
|
11
12
|
const patterns = (0, generatePatterns_1.default)(config, board);
|
|
12
13
|
const filledPatterns = patterns.flatMap((pattern) => (0, fillPattern_1.default)(trie, config, pattern, tiles));
|
|
13
|
-
const
|
|
14
|
+
const validPatterns = filledPatterns.filter((pattern) => (0, areDigraphsValid_1.default)(config, pattern));
|
|
15
|
+
const uniquePatterns = (0, getUniquePatterns_1.default)(validPatterns);
|
|
14
16
|
const results = uniquePatterns.map((pattern, index) => ({
|
|
15
17
|
cells: pattern.cells.map((cell) => cell.toJson()),
|
|
16
18
|
collisions: pattern.getCollisions().map((collision) => collision.cells.map((cell) => cell.toJson())),
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@scrabble-solver/solver",
|
|
3
|
-
"version": "2.12.
|
|
3
|
+
"version": "2.12.2",
|
|
4
4
|
"description": "Scrabble Solver 2 - Solver",
|
|
5
5
|
"main": "build/index.js",
|
|
6
6
|
"types": "build/index.d.ts",
|
|
@@ -17,7 +17,7 @@
|
|
|
17
17
|
"bugs": {
|
|
18
18
|
"url": "https://github.com/kamilmielnik/scrabble-solver/issues"
|
|
19
19
|
},
|
|
20
|
-
"homepage": "https://
|
|
20
|
+
"homepage": "https://scrabble-solver.org",
|
|
21
21
|
"scripts": {
|
|
22
22
|
"build": "tsc --project .",
|
|
23
23
|
"clean": "rimraf build/ node_modules/",
|
|
@@ -25,12 +25,12 @@
|
|
|
25
25
|
},
|
|
26
26
|
"dependencies": {
|
|
27
27
|
"@kamilmielnik/trie": "^2.0.1",
|
|
28
|
-
"@scrabble-solver/types": "^2.12.
|
|
28
|
+
"@scrabble-solver/types": "^2.12.2"
|
|
29
29
|
},
|
|
30
30
|
"devDependencies": {
|
|
31
|
-
"@scrabble-solver/configs": "^2.12.
|
|
32
|
-
"@scrabble-solver/constants": "^2.12.
|
|
33
|
-
"@scrabble-solver/dictionaries": "^2.12.
|
|
31
|
+
"@scrabble-solver/configs": "^2.12.2",
|
|
32
|
+
"@scrabble-solver/constants": "^2.12.2",
|
|
33
|
+
"@scrabble-solver/dictionaries": "^2.12.2"
|
|
34
34
|
},
|
|
35
|
-
"gitHead": "
|
|
35
|
+
"gitHead": "22ec8b756bf1f50d94028c8e69ccc269c23e5759"
|
|
36
36
|
}
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import { Config, Pattern } from '@scrabble-solver/types';
|
|
2
|
+
|
|
3
|
+
const areDigraphsValid = (config: Config, pattern: Pattern): boolean => {
|
|
4
|
+
const { twoCharacterTiles } = config;
|
|
5
|
+
const { cells } = pattern;
|
|
6
|
+
|
|
7
|
+
for (let index = 0; index < cells.length - 1; ++index) {
|
|
8
|
+
const current = cells[index];
|
|
9
|
+
const next = cells[index + 1];
|
|
10
|
+
const digraphCandidate = current.tile.character + next.tile.character;
|
|
11
|
+
|
|
12
|
+
if (twoCharacterTiles.includes(digraphCandidate)) {
|
|
13
|
+
return false;
|
|
14
|
+
}
|
|
15
|
+
}
|
|
16
|
+
|
|
17
|
+
return true;
|
|
18
|
+
};
|
|
19
|
+
|
|
20
|
+
export default areDigraphsValid;
|
|
@@ -57,4 +57,13 @@ describe('getPatternScore', () => {
|
|
|
57
57
|
|
|
58
58
|
expect(getPatternScore(config, pattern)).toBe(2);
|
|
59
59
|
});
|
|
60
|
+
|
|
61
|
+
it('gives 0 score for unknown characters', () => {
|
|
62
|
+
const pattern = new HorizontalPattern(board, [
|
|
63
|
+
new Cell({ x: 13, y: 14, tile: new Tile({ character: '?', isBlank: false }), isEmpty: true }),
|
|
64
|
+
new Cell({ x: 12, y: 14, tile: new Tile({ character: 't' }), isEmpty: false }),
|
|
65
|
+
]);
|
|
66
|
+
|
|
67
|
+
expect(getPatternScore(config, pattern)).toBe(2);
|
|
68
|
+
});
|
|
60
69
|
});
|
package/src/index.ts
CHANGED
|
@@ -1,3 +1,4 @@
|
|
|
1
|
+
export { default as areDigraphsValid } from './areDigraphsValid';
|
|
1
2
|
export { default as fillPattern } from './fillPattern';
|
|
2
3
|
export { default as generateEndIndices } from './generateEndIndices';
|
|
3
4
|
export { default as generateHorizontalPatterns } from './generateHorizontalPatterns';
|
package/src/solve.test.ts
CHANGED
|
@@ -47,7 +47,7 @@ describe('solve - PL', () => {
|
|
|
47
47
|
]);
|
|
48
48
|
const tiles = generateTiles(['l', 'i', 'n', 'o']);
|
|
49
49
|
const results = solve(trie!, config, board, tiles);
|
|
50
|
-
expect(results.length).toBe(
|
|
50
|
+
expect(results.length).toBe(60);
|
|
51
51
|
});
|
|
52
52
|
|
|
53
53
|
it('zmartwychwstałą x9', () => {
|
|
@@ -136,4 +136,28 @@ describe('solve - ES', () => {
|
|
|
136
136
|
expect(results.length).toBe(24);
|
|
137
137
|
expect(bestResult.points).toBe(22);
|
|
138
138
|
});
|
|
139
|
+
|
|
140
|
+
it('chooho - does not use C + H to imitate CH', () => {
|
|
141
|
+
const board = Board.fromStringArray([
|
|
142
|
+
' ',
|
|
143
|
+
' ',
|
|
144
|
+
' ',
|
|
145
|
+
' ',
|
|
146
|
+
' ',
|
|
147
|
+
' ',
|
|
148
|
+
' ',
|
|
149
|
+
' ',
|
|
150
|
+
' ',
|
|
151
|
+
' ',
|
|
152
|
+
' ',
|
|
153
|
+
' ',
|
|
154
|
+
' ',
|
|
155
|
+
' ',
|
|
156
|
+
' ',
|
|
157
|
+
]);
|
|
158
|
+
const tiles = generateTiles(['ch', 'o', 'o', 'c', 'h']);
|
|
159
|
+
const results = solve(trie!, config, board, tiles);
|
|
160
|
+
const words = results.map((result) => result.cells.map((cell) => cell.tile?.character).join(''));
|
|
161
|
+
expect(words).not.toContain('chocho');
|
|
162
|
+
});
|
|
139
163
|
});
|
package/src/solve.ts
CHANGED
|
@@ -1,6 +1,7 @@
|
|
|
1
1
|
import { Trie } from '@kamilmielnik/trie';
|
|
2
2
|
import { Board, Config, ResultJson, Tile } from '@scrabble-solver/types';
|
|
3
3
|
|
|
4
|
+
import areDigraphsValid from './areDigraphsValid';
|
|
4
5
|
import fillPattern from './fillPattern';
|
|
5
6
|
import generatePatterns from './generatePatterns';
|
|
6
7
|
import getPatternScore from './getPatternScore';
|
|
@@ -9,7 +10,8 @@ import getUniquePatterns from './getUniquePatterns';
|
|
|
9
10
|
const solve = (trie: Trie, config: Config, board: Board, tiles: Tile[]): ResultJson[] => {
|
|
10
11
|
const patterns = generatePatterns(config, board);
|
|
11
12
|
const filledPatterns = patterns.flatMap((pattern) => fillPattern(trie, config, pattern, tiles));
|
|
12
|
-
const
|
|
13
|
+
const validPatterns = filledPatterns.filter((pattern) => areDigraphsValid(config, pattern));
|
|
14
|
+
const uniquePatterns = getUniquePatterns(validPatterns);
|
|
13
15
|
const results = uniquePatterns.map((pattern, index) => ({
|
|
14
16
|
cells: pattern.cells.map((cell) => cell.toJson()),
|
|
15
17
|
collisions: pattern.getCollisions().map((collision) => collision.cells.map((cell) => cell.toJson())),
|