kitchen-simulator 1.1.1-test.48 → 1.1.1-test.49
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/lib/KitchenConfiguratorApp.js +3 -0
- package/package.json +1 -1
- package/es/@history.js +0 -2
- package/es/AppContext.js +0 -3
- package/es/KitchenConfigurator.js +0 -645
- package/es/KitchenConfiguratorApp.js +0 -478
- package/es/actions/area-actions.js +0 -14
- package/es/actions/export.js +0 -23
- package/es/actions/groups-actions.js +0 -89
- package/es/actions/holes-actions.js +0 -119
- package/es/actions/items-actions.js +0 -313
- package/es/actions/lines-actions.js +0 -81
- package/es/actions/project-actions.js +0 -281
- package/es/actions/scene-actions.js +0 -33
- package/es/actions/vertices-actions.js +0 -27
- package/es/actions/viewer2d-actions.js +0 -58
- package/es/actions/viewer3d-actions.js +0 -23
- package/es/catalog/areas/area/planner-element.js +0 -40
- package/es/catalog/areas/area/textures/ceramic-tile.jpg +0 -0
- package/es/catalog/areas/area/textures/grass.jpg +0 -0
- package/es/catalog/areas/area/textures/parquet.jpg +0 -0
- package/es/catalog/areas/area/textures/strand-porcelain.jpg +0 -0
- package/es/catalog/areas/area/textures/tile1.jpg +0 -0
- package/es/catalog/catalog.js +0 -277
- package/es/catalog/envMap/nx.hdr +0 -0
- package/es/catalog/envMap/ny.hdr +0 -0
- package/es/catalog/envMap/nz.hdr +0 -0
- package/es/catalog/envMap/px.hdr +0 -0
- package/es/catalog/envMap/py.hdr +0 -0
- package/es/catalog/envMap/pz.hdr +0 -0
- package/es/catalog/factories/area-factory-3d.js +0 -181
- package/es/catalog/factories/area-factory.js +0 -81
- package/es/catalog/factories/export.js +0 -7
- package/es/catalog/factories/wall-factory-3d.js +0 -202
- package/es/catalog/factories/wall-factory.js +0 -268
- package/es/catalog/holes/door-closet/planner-element.js +0 -222
- package/es/catalog/holes/door-double/door_double.png +0 -0
- package/es/catalog/holes/door-double/planner-element.js +0 -315
- package/es/catalog/holes/door-exterior/planner-element.js +0 -215
- package/es/catalog/holes/door-interior/planner-element.js +0 -227
- package/es/catalog/holes/door-panic/panicDoor.png +0 -0
- package/es/catalog/holes/door-panic/planner-element.js +0 -503
- package/es/catalog/holes/door-panic-double/panicDoorDouble.png +0 -0
- package/es/catalog/holes/door-panic-double/planner-element.js +0 -463
- package/es/catalog/holes/door-sliding/planner-element.js +0 -225
- package/es/catalog/holes/doorway-framed/planner-element.js +0 -145
- package/es/catalog/holes/doorway-frameless/planner-element.js +0 -104
- package/es/catalog/holes/export.js +0 -13
- package/es/catalog/holes/gate/gate.jpg +0 -0
- package/es/catalog/holes/window-clear/planner-element.js +0 -166
- package/es/catalog/holes/window-clear/texture.png +0 -0
- package/es/catalog/holes/window-cross/planner-element.js +0 -165
- package/es/catalog/holes/window-cross/texture.png +0 -0
- package/es/catalog/holes/window-double-hung/planner-element.js +0 -303
- package/es/catalog/holes/window-double-hung/texture.png +0 -0
- package/es/catalog/holes/window-vertical/planner-element.js +0 -276
- package/es/catalog/holes/window-vertical/texture.png +0 -0
- package/es/catalog/lines/wall/planner-element.js +0 -70
- package/es/catalog/lines/wall/textures/bricks-normal.jpg +0 -0
- package/es/catalog/lines/wall/textures/bricks-normal2.jpg +0 -0
- package/es/catalog/lines/wall/textures/bricks.jpg +0 -0
- package/es/catalog/lines/wall/textures/bricks2.jpg +0 -0
- package/es/catalog/lines/wall/textures/bricks3.jpg +0 -0
- package/es/catalog/lines/wall/textures/morden-normal.jpg +0 -0
- package/es/catalog/lines/wall/textures/morden.jpg +0 -0
- package/es/catalog/lines/wall/textures/painted-normal.jpg +0 -0
- package/es/catalog/lines/wall/textures/painted.jpg +0 -0
- package/es/catalog/lines/wall/textures/plaster-normal.jpg +0 -0
- package/es/catalog/lines/wall/textures/plaster.jpg +0 -0
- package/es/catalog/lines/wall/wall.png +0 -0
- package/es/catalog/molding/molding-dcm/planner-element.js +0 -28
- package/es/catalog/molding/molding-dcm/texture.png +0 -0
- package/es/catalog/molding/molding-fbm/planner-element.js +0 -28
- package/es/catalog/molding/molding-fbm/texture.png +0 -0
- package/es/catalog/molding/molding-lrm/planner-element.js +0 -28
- package/es/catalog/molding/molding-lrm/texture.png +0 -0
- package/es/catalog/properties/export.js +0 -21
- package/es/catalog/properties/property-checkbox.js +0 -116
- package/es/catalog/properties/property-color.js +0 -39
- package/es/catalog/properties/property-enum.js +0 -97
- package/es/catalog/properties/property-hidden.js +0 -19
- package/es/catalog/properties/property-lenght-measure.js +0 -101
- package/es/catalog/properties/property-length-measure.js +0 -134
- package/es/catalog/properties/property-length-measure_hole.js +0 -101
- package/es/catalog/properties/property-number.js +0 -48
- package/es/catalog/properties/property-read-only.js +0 -26
- package/es/catalog/properties/property-string.js +0 -48
- package/es/catalog/properties/property-toggle.js +0 -39
- package/es/catalog/properties/shared-property-style.js +0 -14
- package/es/catalog/utils/FuseUtils.js +0 -82
- package/es/catalog/utils/exporter.js +0 -148
- package/es/catalog/utils/geom-utils.js +0 -189
- package/es/catalog/utils/item-loader.js +0 -1521
- package/es/catalog/utils/load-obj.js +0 -91
- package/es/catalog/utils/mtl-loader.js +0 -358
- package/es/catalog/utils/obj-loader.js +0 -477
- package/es/class/FuseUtils.js +0 -82
- package/es/class/area.js +0 -145
- package/es/class/export.js +0 -24
- package/es/class/group.js +0 -440
- package/es/class/guide.js +0 -62
- package/es/class/hole.js +0 -929
- package/es/class/item.js +0 -1883
- package/es/class/layer.js +0 -667
- package/es/class/line.js +0 -1180
- package/es/class/project.js +0 -793
- package/es/class/vertex.js +0 -202
- package/es/components/content.js +0 -107
- package/es/components/disclaimer/disclaimer.js +0 -97
- package/es/components/export.js +0 -9
- package/es/components/style/button.js +0 -113
- package/es/components/style/cancel-button.js +0 -22
- package/es/components/style/content-container.js +0 -33
- package/es/components/style/content-title.js +0 -29
- package/es/components/style/delete-button.js +0 -25
- package/es/components/style/export.js +0 -31
- package/es/components/style/form-block.js +0 -24
- package/es/components/style/form-color-input.js +0 -27
- package/es/components/style/form-label.js +0 -26
- package/es/components/style/form-number-input.js +0 -213
- package/es/components/style/form-number-input_2.js +0 -206
- package/es/components/style/form-select.js +0 -68
- package/es/components/style/form-slider.js +0 -61
- package/es/components/style/form-submit-button.js +0 -26
- package/es/components/style/form-text-input.js +0 -95
- package/es/components/viewer2d/area.js +0 -81
- package/es/components/viewer2d/export.js +0 -31
- package/es/components/viewer2d/grids/grid-horizontal-streak.js +0 -37
- package/es/components/viewer2d/grids/grid-streak.js +0 -37
- package/es/components/viewer2d/grids/grid-vertical-streak.js +0 -37
- package/es/components/viewer2d/grids/grids.js +0 -35
- package/es/components/viewer2d/group.js +0 -53
- package/es/components/viewer2d/item.js +0 -513
- package/es/components/viewer2d/layer.js +0 -164
- package/es/components/viewer2d/line.js +0 -882
- package/es/components/viewer2d/ruler.js +0 -100
- package/es/components/viewer2d/rulerDist.js +0 -146
- package/es/components/viewer2d/rulerX.js +0 -151
- package/es/components/viewer2d/rulerY.js +0 -153
- package/es/components/viewer2d/scene.js +0 -140
- package/es/components/viewer2d/snap.js +0 -74
- package/es/components/viewer2d/state.js +0 -78
- package/es/components/viewer2d/utils.js +0 -198
- package/es/components/viewer2d/vertex.js +0 -65
- package/es/components/viewer2d/viewer2d.js +0 -1398
- package/es/components/viewer3d/camera-controls-module/camera-controls.module.js +0 -2592
- package/es/components/viewer3d/dcm.js +0 -401
- package/es/components/viewer3d/fbm.js +0 -414
- package/es/components/viewer3d/front3D.js +0 -66
- package/es/components/viewer3d/grid-creator.js +0 -25
- package/es/components/viewer3d/grids/grid-horizontal-streak.js +0 -36
- package/es/components/viewer3d/grids/grid-streak.js +0 -27
- package/es/components/viewer3d/grids/grid-vertical-streak.js +0 -36
- package/es/components/viewer3d/libs/first-person-controls.js +0 -67
- package/es/components/viewer3d/libs/helvetiker_regular.typeface.js +0 -1281
- package/es/components/viewer3d/libs/mtl-loader.js +0 -357
- package/es/components/viewer3d/libs/obj-loader.js +0 -462
- package/es/components/viewer3d/libs/orbit-controls.js +0 -699
- package/es/components/viewer3d/libs/pointer-lock-controls.js +0 -46
- package/es/components/viewer3d/lrm.js +0 -305
- package/es/components/viewer3d/model.js +0 -708
- package/es/components/viewer3d/pointer-lock-navigation.js +0 -115
- package/es/components/viewer3d/ruler-utils/itemRect.js +0 -61
- package/es/components/viewer3d/ruler-utils/layer3D.js +0 -495
- package/es/components/viewer3d/ruler-utils/ruler3D.js +0 -227
- package/es/components/viewer3d/ruler-utils/scene3D.js +0 -60
- package/es/components/viewer3d/ruler-utils/state3D.js +0 -18
- package/es/components/viewer3d/scene-creator.js +0 -3608
- package/es/components/viewer3d/three-memory-cleaner.js +0 -51
- package/es/components/viewer3d/viewer3d-first-person.js +0 -315
- package/es/components/viewer3d/viewer3d.js +0 -2527
- package/es/constants.js +0 -636
- package/es/index.js +0 -16
- package/es/models.js +0 -510
- package/es/plugins/SVGLoader.js +0 -1412
- package/es/plugins/autosave.js +0 -33
- package/es/plugins/console-debugger.js +0 -37
- package/es/plugins/export.js +0 -9
- package/es/plugins/keyboard.js +0 -101
- package/es/reducers/areas-reducer.js +0 -12
- package/es/reducers/export.js +0 -25
- package/es/reducers/groups-reducer.js +0 -38
- package/es/reducers/holes-reducer.js +0 -62
- package/es/reducers/items-reducer.js +0 -140
- package/es/reducers/lines-reducer.js +0 -45
- package/es/reducers/project-reducer.js +0 -129
- package/es/reducers/reducer.js +0 -19
- package/es/reducers/scene-reducer.js +0 -28
- package/es/reducers/user-reducer.js +0 -40
- package/es/reducers/vertices-reducer.js +0 -19
- package/es/reducers/viewer2d-reducer.js +0 -75
- package/es/reducers/viewer3d-reducer.js +0 -56
- package/es/shared-style.js +0 -66
- package/es/styles/export.js +0 -5
- package/es/styles/tabs.css +0 -40
- package/es/translator/en.js +0 -104
- package/es/translator/it.js +0 -79
- package/es/translator/ru.js +0 -79
- package/es/translator/translator.js +0 -84
- package/es/utils/browser.js +0 -33
- package/es/utils/email-validator.js +0 -4
- package/es/utils/export.js +0 -25
- package/es/utils/geometry.js +0 -2420
- package/es/utils/get-edges-of-subgraphs.js +0 -27
- package/es/utils/graph-cycles.js +0 -237
- package/es/utils/graph-inner-cycles.js +0 -46
- package/es/utils/graph.js +0 -150
- package/es/utils/helper.js +0 -268
- package/es/utils/history.js +0 -29
- package/es/utils/id-broker.js +0 -19
- package/es/utils/logger.js +0 -8
- package/es/utils/math.js +0 -50
- package/es/utils/molding.js +0 -871
- package/es/utils/name-generator.js +0 -18
- package/es/utils/objects-utils.js +0 -50
- package/es/utils/phone-validator.js +0 -4
- package/es/utils/process-black-list.js +0 -18
- package/es/utils/react-if.js +0 -18
- package/es/utils/snap-scene.js +0 -99
- package/es/utils/snap.js +0 -237
- package/es/utils/summarizeCart.js +0 -24
- package/es/utils/threeCSG.es6.js +0 -498
- package/es/version.js +0 -2
- package/lib/catalog/properties/property-string.js +0 -55
- package/lib/catalog/properties/property-toggle.js +0 -46
- package/lib/catalog/properties/shared-property-style.js +0 -20
- package/lib/catalog/utils/FuseUtils.js +0 -88
- package/lib/catalog/utils/exporter.js +0 -155
- package/lib/catalog/utils/geom-utils.js +0 -205
- package/lib/catalog/utils/item-loader.js +0 -1533
- package/lib/catalog/utils/load-obj.js +0 -99
- package/lib/catalog/utils/mtl-loader.js +0 -363
- package/lib/catalog/utils/obj-loader.js +0 -482
- package/lib/class/FuseUtils.js +0 -88
- package/lib/class/area.js +0 -150
- package/lib/class/export.js +0 -96
- package/lib/class/group.js +0 -445
- package/lib/class/guide.js +0 -67
- package/lib/class/hole.js +0 -934
- package/lib/class/item.js +0 -1889
- package/lib/class/layer.js +0 -672
- package/lib/class/line.js +0 -1186
- package/lib/class/project.js +0 -799
- package/lib/class/vertex.js +0 -207
- package/lib/components/content.js +0 -116
- package/lib/components/disclaimer/disclaimer.js +0 -105
- package/lib/components/export.js +0 -33
- package/lib/components/style/button.js +0 -120
- package/lib/components/style/cancel-button.js +0 -29
- package/lib/components/style/content-container.js +0 -40
- package/lib/components/style/content-title.js +0 -37
- package/lib/components/style/delete-button.js +0 -34
- package/lib/components/style/export.js +0 -121
- package/lib/components/style/form-block.js +0 -31
- package/lib/components/style/form-color-input.js +0 -34
- package/lib/components/style/form-label.js +0 -33
- package/lib/components/style/form-number-input.js +0 -220
- package/lib/components/style/form-number-input_2.js +0 -213
- package/lib/components/style/form-select.js +0 -75
- package/lib/components/style/form-slider.js +0 -68
- package/lib/components/style/form-submit-button.js +0 -35
- package/lib/components/style/form-text-input.js +0 -101
- package/lib/components/viewer2d/area.js +0 -88
- package/lib/components/viewer2d/export.js +0 -121
- package/lib/components/viewer2d/grids/grid-horizontal-streak.js +0 -44
- package/lib/components/viewer2d/grids/grid-streak.js +0 -44
- package/lib/components/viewer2d/grids/grid-vertical-streak.js +0 -44
- package/lib/components/viewer2d/grids/grids.js +0 -44
- package/lib/components/viewer2d/group.js +0 -62
- package/lib/components/viewer2d/item.js +0 -521
- package/lib/components/viewer2d/layer.js +0 -171
- package/lib/components/viewer2d/line.js +0 -892
- package/lib/components/viewer2d/ruler.js +0 -107
- package/lib/components/viewer2d/rulerDist.js +0 -153
- package/lib/components/viewer2d/rulerX.js +0 -158
- package/lib/components/viewer2d/rulerY.js +0 -160
- package/lib/components/viewer2d/scene.js +0 -147
- package/lib/components/viewer2d/snap.js +0 -83
- package/lib/components/viewer2d/state.js +0 -87
- package/lib/components/viewer2d/utils.js +0 -210
- package/lib/components/viewer2d/vertex.js +0 -74
- package/lib/components/viewer2d/viewer2d.js +0 -1405
- package/lib/components/viewer3d/camera-controls-module/camera-controls.module.js +0 -2597
- package/lib/components/viewer3d/dcm.js +0 -407
- package/lib/components/viewer3d/fbm.js +0 -420
- package/lib/components/viewer3d/front3D.js +0 -75
- package/lib/components/viewer3d/grid-creator.js +0 -34
- package/lib/components/viewer3d/grids/grid-horizontal-streak.js +0 -44
- package/lib/components/viewer3d/grids/grid-streak.js +0 -35
- package/lib/components/viewer3d/grids/grid-vertical-streak.js +0 -44
- package/lib/components/viewer3d/libs/first-person-controls.js +0 -74
- package/lib/components/viewer3d/libs/helvetiker_regular.typeface.js +0 -1287
- package/lib/components/viewer3d/libs/mtl-loader.js +0 -363
- package/lib/components/viewer3d/libs/obj-loader.js +0 -468
- package/lib/components/viewer3d/libs/orbit-controls.js +0 -705
- package/lib/components/viewer3d/libs/pointer-lock-controls.js +0 -52
- package/lib/components/viewer3d/lrm.js +0 -311
- package/lib/components/viewer3d/model.js +0 -714
- package/lib/components/viewer3d/pointer-lock-navigation.js +0 -122
- package/lib/components/viewer3d/ruler-utils/itemRect.js +0 -68
- package/lib/components/viewer3d/ruler-utils/layer3D.js +0 -502
- package/lib/components/viewer3d/ruler-utils/ruler3D.js +0 -234
- package/lib/components/viewer3d/ruler-utils/scene3D.js +0 -68
- package/lib/components/viewer3d/ruler-utils/state3D.js +0 -25
- package/lib/components/viewer3d/scene-creator.js +0 -3642
- package/lib/components/viewer3d/three-memory-cleaner.js +0 -60
- package/lib/components/viewer3d/viewer3d-first-person.js +0 -320
- package/lib/components/viewer3d/viewer3d.js +0 -2532
- package/lib/constants.js +0 -645
- package/lib/index.js +0 -96
- package/lib/models.js +0 -517
- package/lib/plugins/SVGLoader.js +0 -1417
- package/lib/plugins/autosave.js +0 -39
- package/lib/plugins/console-debugger.js +0 -44
- package/lib/plugins/export.js +0 -33
- package/lib/plugins/keyboard.js +0 -107
- package/lib/reducers/areas-reducer.js +0 -18
- package/lib/reducers/export.js +0 -97
- package/lib/reducers/groups-reducer.js +0 -44
- package/lib/reducers/holes-reducer.js +0 -68
- package/lib/reducers/items-reducer.js +0 -146
- package/lib/reducers/lines-reducer.js +0 -51
- package/lib/reducers/project-reducer.js +0 -135
- package/lib/reducers/reducer.js +0 -26
- package/lib/reducers/scene-reducer.js +0 -34
- package/lib/reducers/user-reducer.js +0 -46
- package/lib/reducers/vertices-reducer.js +0 -25
- package/lib/reducers/viewer2d-reducer.js +0 -82
- package/lib/reducers/viewer3d-reducer.js +0 -63
- package/lib/shared-style.js +0 -72
- package/lib/styles/export.js +0 -13
- package/lib/translator/en.js +0 -110
- package/lib/translator/it.js +0 -85
- package/lib/translator/ru.js +0 -85
- package/lib/translator/translator.js +0 -90
- package/lib/utils/browser.js +0 -40
- package/lib/utils/email-validator.js +0 -10
- package/lib/utils/export.js +0 -56
- package/lib/utils/geometry.js +0 -2516
- package/lib/utils/get-edges-of-subgraphs.js +0 -34
- package/lib/utils/graph-cycles.js +0 -240
- package/lib/utils/graph-inner-cycles.js +0 -54
- package/lib/utils/graph.js +0 -157
- package/lib/utils/helper.js +0 -291
- package/lib/utils/history.js +0 -36
- package/lib/utils/id-broker.js +0 -25
- package/lib/utils/logger.js +0 -14
- package/lib/utils/math.js +0 -57
- package/lib/utils/molding.js +0 -895
- package/lib/utils/name-generator.js +0 -23
- package/lib/utils/objects-utils.js +0 -60
- package/lib/utils/phone-validator.js +0 -10
- package/lib/utils/process-black-list.js +0 -24
- package/lib/utils/react-if.js +0 -24
- package/lib/utils/snap-scene.js +0 -105
- package/lib/utils/snap.js +0 -249
- package/lib/utils/summarizeCart.js +0 -30
- package/lib/utils/threeCSG.es6.js +0 -503
- package/lib/version.js +0 -8
|
@@ -1,27 +0,0 @@
|
|
|
1
|
-
function getEdgesOfSubgraphs(subgraphs, graph) {
|
|
2
|
-
var edges = [];
|
|
3
|
-
subgraphs.forEach(function (component) {
|
|
4
|
-
edges.push([]);
|
|
5
|
-
var vertices = getVerticesFromBiconnectedComponent(component);
|
|
6
|
-
var inserted = [];
|
|
7
|
-
vertices.forEach(function (vertex) {
|
|
8
|
-
var adjacents = graph.adj[vertex];
|
|
9
|
-
adjacents.forEach(function (adj) {
|
|
10
|
-
if (vertex <= adj && vertices.has(adj)) {
|
|
11
|
-
edges[edges.length - 1].push([vertex, adj]);
|
|
12
|
-
}
|
|
13
|
-
});
|
|
14
|
-
});
|
|
15
|
-
});
|
|
16
|
-
return edges;
|
|
17
|
-
}
|
|
18
|
-
function getVerticesFromBiconnectedComponent(component) {
|
|
19
|
-
var vertices = new Set();
|
|
20
|
-
component.forEach(function (edge) {
|
|
21
|
-
vertices.add(edge.u);
|
|
22
|
-
vertices.add(edge.v);
|
|
23
|
-
});
|
|
24
|
-
return vertices;
|
|
25
|
-
}
|
|
26
|
-
export default getEdgesOfSubgraphs;
|
|
27
|
-
export { getEdgesOfSubgraphs, getVerticesFromBiconnectedComponent };
|
package/es/utils/graph-cycles.js
DELETED
|
@@ -1,237 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* UTILS
|
|
3
|
-
*/
|
|
4
|
-
|
|
5
|
-
function sub(v1, v2) {
|
|
6
|
-
return [v1[0] - v2[0], v1[1] - v2[1]];
|
|
7
|
-
}
|
|
8
|
-
function mod(n, m) {
|
|
9
|
-
return (n % m + m) % m;
|
|
10
|
-
}
|
|
11
|
-
|
|
12
|
-
/**
|
|
13
|
-
* CYCLES
|
|
14
|
-
*/
|
|
15
|
-
|
|
16
|
-
function compute_ev_mapping(EV) {
|
|
17
|
-
var ev_mapping = EV.map(function (ev) {
|
|
18
|
-
return {
|
|
19
|
-
ev: ev,
|
|
20
|
-
color: 0,
|
|
21
|
-
direction: -1
|
|
22
|
-
};
|
|
23
|
-
});
|
|
24
|
-
return ev_mapping;
|
|
25
|
-
}
|
|
26
|
-
function compute_angle(P, V) {
|
|
27
|
-
var point = sub(V, P);
|
|
28
|
-
var angle = Math.atan2(point[1], point[0]);
|
|
29
|
-
return angle;
|
|
30
|
-
}
|
|
31
|
-
function compute_incidences(V, EV) {
|
|
32
|
-
var incidences = V.map(function (vertex, i) {
|
|
33
|
-
var incidence = [];
|
|
34
|
-
EV.forEach(function (edge, j) {
|
|
35
|
-
var endpoint;
|
|
36
|
-
var position;
|
|
37
|
-
if (edge[0] === i) {
|
|
38
|
-
endpoint = edge[1];
|
|
39
|
-
position = 1;
|
|
40
|
-
}
|
|
41
|
-
if (edge[1] === i) {
|
|
42
|
-
endpoint = edge[0];
|
|
43
|
-
position = 0;
|
|
44
|
-
}
|
|
45
|
-
endpoint !== undefined && incidence.push({
|
|
46
|
-
index: j,
|
|
47
|
-
endpoint: endpoint,
|
|
48
|
-
angle: compute_angle(vertex, V[endpoint]),
|
|
49
|
-
edge: edge,
|
|
50
|
-
position: position
|
|
51
|
-
});
|
|
52
|
-
});
|
|
53
|
-
incidence.sort(function (i1, i2) {
|
|
54
|
-
return i2.angle - i1.angle;
|
|
55
|
-
});
|
|
56
|
-
return incidence;
|
|
57
|
-
});
|
|
58
|
-
return incidences;
|
|
59
|
-
}
|
|
60
|
-
function get_starting_edge(incidences, ev_mapping) {
|
|
61
|
-
var e;
|
|
62
|
-
var position;
|
|
63
|
-
var direction;
|
|
64
|
-
for (e = 0; e < ev_mapping.length; e += 1) {
|
|
65
|
-
if (ev_mapping[e].color < 2) {
|
|
66
|
-
direction = -1 * ev_mapping[e].direction;
|
|
67
|
-
color(ev_mapping, e, direction);
|
|
68
|
-
return {
|
|
69
|
-
edge: e,
|
|
70
|
-
direction: direction,
|
|
71
|
-
position: direction === -1 ? 0 : 1
|
|
72
|
-
};
|
|
73
|
-
}
|
|
74
|
-
}
|
|
75
|
-
}
|
|
76
|
-
function get_next_edge(incidences, edge, position, EV) {
|
|
77
|
-
var items = incidences[EV[edge][position]];
|
|
78
|
-
//console.log(items, incidences, EV, edge, position);
|
|
79
|
-
var n_items = items.length;
|
|
80
|
-
var item;
|
|
81
|
-
var out;
|
|
82
|
-
var j;
|
|
83
|
-
for (j = 0; j < n_items; j += 1) {
|
|
84
|
-
item = items[j];
|
|
85
|
-
if (item.index === edge) {
|
|
86
|
-
out = items[mod(j + 1, items.length)];
|
|
87
|
-
return {
|
|
88
|
-
edge: out.index,
|
|
89
|
-
vertex: out.endpoint,
|
|
90
|
-
position: out.position,
|
|
91
|
-
direction: out.position ? 1 : -1
|
|
92
|
-
};
|
|
93
|
-
}
|
|
94
|
-
}
|
|
95
|
-
}
|
|
96
|
-
function color(ev_mapping, index, direction) {
|
|
97
|
-
ev_mapping[index].color += 1;
|
|
98
|
-
ev_mapping[index].direction = direction;
|
|
99
|
-
}
|
|
100
|
-
function find_cycles(V, EV) {
|
|
101
|
-
var ev_mapping = compute_ev_mapping(EV);
|
|
102
|
-
var incidences = compute_incidences(V, EV);
|
|
103
|
-
var V_cycles = [];
|
|
104
|
-
var E_cycles = [];
|
|
105
|
-
var dir_E_cycles = [];
|
|
106
|
-
var V_cycle;
|
|
107
|
-
var E_cycle;
|
|
108
|
-
var dir_E_cycle;
|
|
109
|
-
var next;
|
|
110
|
-
var counter = 0;
|
|
111
|
-
var start = get_starting_edge(incidences, ev_mapping);
|
|
112
|
-
while (start !== undefined) {
|
|
113
|
-
V_cycle = [EV[start.edge][mod(start.position + 1, 2)], EV[start.edge][start.position]];
|
|
114
|
-
E_cycle = [start.edge];
|
|
115
|
-
dir_E_cycle = [start.direction];
|
|
116
|
-
next = get_next_edge(incidences, start.edge, start.position, EV);
|
|
117
|
-
while (next.edge !== start.edge) {
|
|
118
|
-
V_cycle.push(next.vertex);
|
|
119
|
-
E_cycle.push(next.edge);
|
|
120
|
-
dir_E_cycle.push(next.direction);
|
|
121
|
-
color(ev_mapping, next.edge, next.direction);
|
|
122
|
-
next = get_next_edge(incidences, next.edge, next.position, EV);
|
|
123
|
-
}
|
|
124
|
-
E_cycles.push(E_cycle);
|
|
125
|
-
V_cycles.push(V_cycle);
|
|
126
|
-
dir_E_cycles.push(dir_E_cycle);
|
|
127
|
-
|
|
128
|
-
//console.log('############## CYCLE ', ++counter)
|
|
129
|
-
//console.log('EDGES:', E_cycle)
|
|
130
|
-
//console.log('VERTICES:', V_cycle)
|
|
131
|
-
//console.log('START', 'edge:', start.edge, 'position:', start.position)
|
|
132
|
-
//console.log('COUNTER:', ev_mapping.map(e => e.color), ev_mapping.map(e => e.color).reduce((a, b) => a + b));
|
|
133
|
-
//console.log('\n')
|
|
134
|
-
|
|
135
|
-
start = get_starting_edge(incidences, ev_mapping);
|
|
136
|
-
}
|
|
137
|
-
return {
|
|
138
|
-
v_cycles: V_cycles,
|
|
139
|
-
e_cycles: E_cycles,
|
|
140
|
-
dir_e_cycles: dir_E_cycles,
|
|
141
|
-
ev_mapping: ev_mapping
|
|
142
|
-
};
|
|
143
|
-
}
|
|
144
|
-
function find_short_cycles_indexes(v_cycles, e_cycles) {
|
|
145
|
-
var indexes = [];
|
|
146
|
-
var e_cycle;
|
|
147
|
-
var v_cycle;
|
|
148
|
-
var i;
|
|
149
|
-
for (i = 0; i < e_cycles.length; i += 1) {
|
|
150
|
-
e_cycle = e_cycles[i];
|
|
151
|
-
v_cycle = v_cycles[i];
|
|
152
|
-
if (e_cycle.length < 3 || v_cycle[0] !== v_cycle[v_cycle.length - 1]) {
|
|
153
|
-
indexes.push(i);
|
|
154
|
-
}
|
|
155
|
-
}
|
|
156
|
-
return indexes;
|
|
157
|
-
}
|
|
158
|
-
function find_inner_cycles(V, EV) {
|
|
159
|
-
var cycles = find_cycles(V, EV);
|
|
160
|
-
var v_cycles = cycles.v_cycles;
|
|
161
|
-
var e_cycles = cycles.e_cycles;
|
|
162
|
-
var short_cycles_indexes = find_short_cycles_indexes(v_cycles, e_cycles);
|
|
163
|
-
short_cycles_indexes.forEach(function (indx) {
|
|
164
|
-
v_cycles.splice(indx, 1);
|
|
165
|
-
e_cycles.splice(indx, 1);
|
|
166
|
-
});
|
|
167
|
-
var dir_e_cycles = cycles.dir_e_cycles;
|
|
168
|
-
var rooms_values = cycles.e_cycles.map(function (cycle, i) {
|
|
169
|
-
return cycle.map(function (edge, j) {
|
|
170
|
-
var v1;
|
|
171
|
-
var v2;
|
|
172
|
-
var dir = dir_e_cycles[i][j] > 0;
|
|
173
|
-
if (dir > 0) {
|
|
174
|
-
v1 = EV[edge][0];
|
|
175
|
-
v2 = EV[edge][1];
|
|
176
|
-
} else {
|
|
177
|
-
v1 = EV[edge][1];
|
|
178
|
-
v2 = EV[edge][0];
|
|
179
|
-
}
|
|
180
|
-
return (V[v2][0] - V[v1][0]) * (V[v2][1] + V[v1][1]);
|
|
181
|
-
});
|
|
182
|
-
});
|
|
183
|
-
var rooms_sums = rooms_values.map(function (room) {
|
|
184
|
-
return room.reduce(function (a, b) {
|
|
185
|
-
return a + b;
|
|
186
|
-
});
|
|
187
|
-
});
|
|
188
|
-
var positive_count = rooms_sums.filter(function (sum) {
|
|
189
|
-
return sum > 0;
|
|
190
|
-
}).length;
|
|
191
|
-
var negative_count = rooms_sums.length - positive_count;
|
|
192
|
-
var rm_neg = positive_count >= negative_count ? 1 : -1;
|
|
193
|
-
return {
|
|
194
|
-
v_cycles: cycles.v_cycles.filter(function (v, i) {
|
|
195
|
-
return rm_neg * rooms_sums[i] > 0;
|
|
196
|
-
}),
|
|
197
|
-
e_cycles: cycles.e_cycles.filter(function (v, i) {
|
|
198
|
-
return rm_neg * rooms_sums[i] > 0;
|
|
199
|
-
}),
|
|
200
|
-
ev_mapping: cycles.ev_mapping
|
|
201
|
-
};
|
|
202
|
-
}
|
|
203
|
-
export default find_inner_cycles;
|
|
204
|
-
export { find_inner_cycles, find_cycles, compute_ev_mapping, compute_incidences };
|
|
205
|
-
|
|
206
|
-
/**
|
|
207
|
-
* DATA
|
|
208
|
-
*/
|
|
209
|
-
|
|
210
|
-
// let V = [[0.5774, 1.0], [1.0, 1.0], [1.1547, 0.0], [1.0, 0.0], [0.0, 0.0], [0.0, 0.732], [1.0, 0.1547], [0.732, 0.0], [1.0491, 0.183], [-0.317, 0.549], [1.0, 0.268], [0.183, -0.3169], [0.5491, 1.049], [0.4642, 1.0], [0.0, -0.4226], [0.0, 1.0]]
|
|
211
|
-
// let EV = [[0, 1], [2, 3], [5, 4], [7, 6], [2, 8], [3, 6], [4, 9], [0, 10], [9, 5], [8, 10], [7, 11], [12, 13], [6, 8], [6, 10], [4, 7], [4, 11], [4, 14], [5, 15], [11, 14], [0, 12], [13, 15], [0, 13], [1, 10], [3, 7], [5, 13]]
|
|
212
|
-
|
|
213
|
-
// let V = [[0,0],[10,0],[10,10],[0,10], [100,100],[110,100],[110,110],[100,110], [5,0], [5,10]]
|
|
214
|
-
// let V = [[0,0.5],[12,-0.7],[14,14],[-2,10], [103,106],[117,98],[96,112],[104,109], [5.5,0.8], [4.8,10.5]]
|
|
215
|
-
// let EV = [[3,9],[9,2],[2,1],[1,8],[8,0],[0,3],[8,9]] // IT WORKS
|
|
216
|
-
// let EV = [[3,9],[9,2],[2,1],[1,8],[8,0],[0,3],[8,9], [5,6], [6,7], [2,5]] // IT DOESN'T WORK
|
|
217
|
-
// let EV = [[3,2],[2,1],[1,0],[0,3]] // IT WORKS
|
|
218
|
-
// let EV = [[2,3],[1,2],[0,1],[3,0]] // IT WORKS
|
|
219
|
-
// let EV = [[2,3],[1,2],[0,1],[3,0],[6,7],[5,6],[4,5],[7,4]] // IT WORKS
|
|
220
|
-
// let EV = [[3,2],[2,1],[1,0],[0,3],[7,6],[6,5],[5,4],[4,7]] // IT WORKS
|
|
221
|
-
|
|
222
|
-
// let V = [[2,5],[5,6],[10,6.8],[23,8],[9.6,11.3],[20,15],[25,16],[29,18],[30,22],[4,11],[6,10],[24,25],[18,20],[27,7]]
|
|
223
|
-
// let EV = [[0,1],[10,0],[9,10],[9,1],[1,2],[4,2],[3,13],[2,3],[4,5],[5,6],[6,7],[12,5],[12,11],[11,6],[11,8],[7,8],[9,4]]
|
|
224
|
-
|
|
225
|
-
/**
|
|
226
|
-
* MAIN
|
|
227
|
-
*/
|
|
228
|
-
|
|
229
|
-
// let cycles_data = find_inner_cycles(V, EV)
|
|
230
|
-
// console.log('############## OUTPUT')
|
|
231
|
-
// console.log('EDGES:')
|
|
232
|
-
// console.log(cycles_data.e_cycles)
|
|
233
|
-
// console.log('\n')
|
|
234
|
-
// console.log('VERTICES:')
|
|
235
|
-
// console.log(cycles_data.v_cycles)
|
|
236
|
-
// console.log('\n')
|
|
237
|
-
// console.log(cycles_data.ev_mapping.every(m => m.color === 2))
|
|
@@ -1,46 +0,0 @@
|
|
|
1
|
-
import Graph from "./graph";
|
|
2
|
-
import getEdgesOfSubgraphs from "./get-edges-of-subgraphs";
|
|
3
|
-
import graphCycles from "./graph-cycles";
|
|
4
|
-
import { List } from 'immutable';
|
|
5
|
-
export function calculateInnerCycles(verticesArray, edgesArray) {
|
|
6
|
-
var innerCycles = new List();
|
|
7
|
-
var graph = new Graph(verticesArray.length);
|
|
8
|
-
edgesArray.forEach(function (line) {
|
|
9
|
-
graph.addEdge(line[0], line[1]);
|
|
10
|
-
graph.addEdge(line[1], line[0]);
|
|
11
|
-
});
|
|
12
|
-
graph.BCC();
|
|
13
|
-
var subgraphs = graph.subgraphs.filter(function (subgraph) {
|
|
14
|
-
return subgraph.length >= 3;
|
|
15
|
-
});
|
|
16
|
-
var edgesOfSubgraphsArray = getEdgesOfSubgraphs(subgraphs, graph);
|
|
17
|
-
var edges = [];
|
|
18
|
-
edgesOfSubgraphsArray.forEach(function (es) {
|
|
19
|
-
es.forEach(function (edge) {
|
|
20
|
-
return edges.push(edge);
|
|
21
|
-
});
|
|
22
|
-
});
|
|
23
|
-
var cycles = graphCycles(verticesArray, edges);
|
|
24
|
-
cycles.v_cycles.forEach(function (cycle) {
|
|
25
|
-
cycle.shift();
|
|
26
|
-
innerCycles = innerCycles.push(cycle);
|
|
27
|
-
});
|
|
28
|
-
return innerCycles;
|
|
29
|
-
}
|
|
30
|
-
export function isClockWiseOrder(innerCycleWithCoords) {
|
|
31
|
-
// See: https://stackoverflow.com/a/1165943 and http://blog.element84.com/polygon-winding.html
|
|
32
|
-
|
|
33
|
-
var i = 0;
|
|
34
|
-
var twiceEnclosedArea = 0;
|
|
35
|
-
var size = innerCycleWithCoords.size;
|
|
36
|
-
for (i = 0; i < size; i++) {
|
|
37
|
-
var _innerCycleWithCoords = innerCycleWithCoords.get(i),
|
|
38
|
-
x1 = _innerCycleWithCoords.x,
|
|
39
|
-
y1 = _innerCycleWithCoords.y;
|
|
40
|
-
var _innerCycleWithCoords2 = innerCycleWithCoords.get((i + 1) % size),
|
|
41
|
-
x2 = _innerCycleWithCoords2.x,
|
|
42
|
-
y2 = _innerCycleWithCoords2.y;
|
|
43
|
-
twiceEnclosedArea += (x2 - x1) * (y2 + y1);
|
|
44
|
-
}
|
|
45
|
-
return twiceEnclosedArea > 0;
|
|
46
|
-
}
|
package/es/utils/graph.js
DELETED
|
@@ -1,150 +0,0 @@
|
|
|
1
|
-
function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); }
|
|
2
|
-
function _defineProperties(e, r) { for (var t = 0; t < r.length; t++) { var o = r[t]; o.enumerable = o.enumerable || !1, o.configurable = !0, "value" in o && (o.writable = !0), Object.defineProperty(e, _toPropertyKey(o.key), o); } }
|
|
3
|
-
function _createClass(e, r, t) { return r && _defineProperties(e.prototype, r), t && _defineProperties(e, t), Object.defineProperty(e, "prototype", { writable: !1 }), e; }
|
|
4
|
-
function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == _typeof(i) ? i : i + ""; }
|
|
5
|
-
function _toPrimitive(t, r) { if ("object" != _typeof(t) || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != _typeof(i)) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); }
|
|
6
|
-
function _classCallCheck(a, n) { if (!(a instanceof n)) throw new TypeError("Cannot call a class as a function"); }
|
|
7
|
-
//JS porting of this code http://www.geeksforgeeks.org/biconnected-components/
|
|
8
|
-
|
|
9
|
-
function create_array(length) {
|
|
10
|
-
var array = [];
|
|
11
|
-
for (var i = 0; i < length; ++i) {
|
|
12
|
-
array.push([]);
|
|
13
|
-
}
|
|
14
|
-
return array;
|
|
15
|
-
}
|
|
16
|
-
var Edge = /*#__PURE__*/_createClass(function Edge(u, v) {
|
|
17
|
-
_classCallCheck(this, Edge);
|
|
18
|
-
this.u = u;
|
|
19
|
-
this.v = v;
|
|
20
|
-
});
|
|
21
|
-
var Graph = /*#__PURE__*/function () {
|
|
22
|
-
function Graph(v) {
|
|
23
|
-
_classCallCheck(this, Graph);
|
|
24
|
-
this.count = 0; // count is number of biconnected components
|
|
25
|
-
this.subgraphs = []; //biconnected components
|
|
26
|
-
this.time = 0; // time is used to find discovery times
|
|
27
|
-
|
|
28
|
-
this.V = v; // No. of vertices
|
|
29
|
-
this.E = 0; // No. of Edges
|
|
30
|
-
this.adj = []; // Adjacency List
|
|
31
|
-
|
|
32
|
-
this.adj = create_array(v);
|
|
33
|
-
}
|
|
34
|
-
|
|
35
|
-
//Function to add an edge into the graph
|
|
36
|
-
return _createClass(Graph, [{
|
|
37
|
-
key: "addEdge",
|
|
38
|
-
value: function addEdge(v, w) {
|
|
39
|
-
this.adj[v].push(w);
|
|
40
|
-
this.E++;
|
|
41
|
-
}
|
|
42
|
-
|
|
43
|
-
// A recursive function that finds and prints strongly connected
|
|
44
|
-
// components using DFS traversal
|
|
45
|
-
// u --> The vertex to be visited next
|
|
46
|
-
// disc[] --> Stores discovery times of visited vertices
|
|
47
|
-
// low[] -- >> earliest visited vertex (the vertex with minimum
|
|
48
|
-
// discovery time) that can be reached from subtree
|
|
49
|
-
// rooted with current vertex
|
|
50
|
-
// *st -- >> To store visited edges
|
|
51
|
-
// // A recursive function that finds and prints strongly connected
|
|
52
|
-
// components using DFS traversal
|
|
53
|
-
// u --> The vertex to be visited next
|
|
54
|
-
// disc[] --> Stores discovery times of visited vertices
|
|
55
|
-
// low[] -- >> earliest visited vertex (the vertex with minimum
|
|
56
|
-
// discovery time) that can be reached from subtree
|
|
57
|
-
// rooted with current vertex
|
|
58
|
-
// *st -- >> To store visited edges
|
|
59
|
-
}, {
|
|
60
|
-
key: "_BCCUtil",
|
|
61
|
-
value: function _BCCUtil(u, disc, low, st, parent) {
|
|
62
|
-
var _this = this;
|
|
63
|
-
// Initialize discovery time and low value
|
|
64
|
-
disc[u] = low[u] = ++this.time;
|
|
65
|
-
this.children = 0;
|
|
66
|
-
|
|
67
|
-
// Go through all vertices adjacent to this
|
|
68
|
-
// v is current adjacent of 'u'
|
|
69
|
-
this.adj[u].forEach(function (v) {
|
|
70
|
-
// If v is not visited yet, then recur for it
|
|
71
|
-
if (disc[v] == -1) {
|
|
72
|
-
_this.children++;
|
|
73
|
-
parent[v] = u;
|
|
74
|
-
|
|
75
|
-
// store the edge in stack
|
|
76
|
-
st.push(new Edge(u, v));
|
|
77
|
-
_this._BCCUtil(v, disc, low, st, parent);
|
|
78
|
-
|
|
79
|
-
// Check if the subtree rooted with 'v' has a
|
|
80
|
-
// connection to one of the ancestors of 'u'
|
|
81
|
-
// Case 1 -- per Strongly Connected Components Article
|
|
82
|
-
if (low[u] > low[v]) low[u] = low[v];
|
|
83
|
-
|
|
84
|
-
// If u is an articulation point,
|
|
85
|
-
// pop all edges from stack till u -- v
|
|
86
|
-
if (disc[u] == 1 && _this.children > 1 || disc[u] > 1 && low[v] >= disc[u]) {
|
|
87
|
-
var subgraph = [];
|
|
88
|
-
while (st[st.length - 1].u != u || st[st.length - 1].v != v) {
|
|
89
|
-
subgraph.push(st[st.length - 1]);
|
|
90
|
-
//console.log(st[st.length - 1].u + "--" + st[st.length - 1].v + " ");
|
|
91
|
-
st.splice(st.length - 1, 1);
|
|
92
|
-
}
|
|
93
|
-
subgraph.push(st[st.length - 1]);
|
|
94
|
-
//console.log(st[st.length - 1].u + "--" + st[st.length - 1].v + " ");
|
|
95
|
-
_this.subgraphs.push(subgraph);
|
|
96
|
-
subgraph = [];
|
|
97
|
-
//console.log()
|
|
98
|
-
st.splice(st.length - 1, 1);
|
|
99
|
-
_this.count++;
|
|
100
|
-
}
|
|
101
|
-
}
|
|
102
|
-
|
|
103
|
-
// Update low value of 'u' only of 'v' is still in stack
|
|
104
|
-
// (i.e. it's a back edge, not cross edge).
|
|
105
|
-
// Case 2 -- per Strongly Connected Components Article
|
|
106
|
-
else if (v != parent[u] && disc[v] < low[u]) {
|
|
107
|
-
if (low[u] > disc[v]) low[u] = disc[v];
|
|
108
|
-
st.push(new Edge(u, v));
|
|
109
|
-
}
|
|
110
|
-
});
|
|
111
|
-
}
|
|
112
|
-
}, {
|
|
113
|
-
key: "BCC",
|
|
114
|
-
value: function BCC() {
|
|
115
|
-
var V = this.V;
|
|
116
|
-
var disc = create_array(V);
|
|
117
|
-
var low = create_array(V);
|
|
118
|
-
var parent = create_array(V);
|
|
119
|
-
var st = [];
|
|
120
|
-
|
|
121
|
-
// Initialize disc and low, and parent arrays
|
|
122
|
-
for (var i = 0; i < V; i++) {
|
|
123
|
-
disc[i] = -1;
|
|
124
|
-
low[i] = -1;
|
|
125
|
-
parent[i] = -1;
|
|
126
|
-
}
|
|
127
|
-
for (var _i = 0; _i < V; _i++) {
|
|
128
|
-
if (disc[_i] == -1) this._BCCUtil(_i, disc, low, st, parent);
|
|
129
|
-
var j = 0;
|
|
130
|
-
|
|
131
|
-
// If stack is not empty, pop all edges from stack
|
|
132
|
-
var subgraph = [];
|
|
133
|
-
while (st.length > 0) {
|
|
134
|
-
j = 1;
|
|
135
|
-
subgraph.push(st[st.length - 1]);
|
|
136
|
-
//console.log(st[st.length - 1].u + "--" + st[st.length - 1].v + " ");
|
|
137
|
-
st.splice(st.length - 1, 1);
|
|
138
|
-
}
|
|
139
|
-
if (j == 1) {
|
|
140
|
-
this.subgraphs.push(subgraph);
|
|
141
|
-
subgraph = [];
|
|
142
|
-
//console.log();
|
|
143
|
-
this.count++;
|
|
144
|
-
}
|
|
145
|
-
}
|
|
146
|
-
}
|
|
147
|
-
}]);
|
|
148
|
-
}();
|
|
149
|
-
export default Graph;
|
|
150
|
-
export { Graph, Edge, create_array };
|