Skip to content
Snippets Groups Projects
Commit d066cb98 authored by Moritz Langenstein's avatar Moritz Langenstein
Browse files

(ml5717) Compressed erase intervals representation, fixed singular point erasing

parent 90763166
No related branches found
No related tags found
1 merge request!57Erasure intervals
Pipeline #104621 passed
...@@ -200,9 +200,13 @@ const applyErasureIntervals = (pathID, points, erasureIntervals) => { ...@@ -200,9 +200,13 @@ const applyErasureIntervals = (pathID, points, erasureIntervals) => {
pathID, pathID,
i, i,
) )
if (!eraseIntervals || nextPoint === undefined) {
if (!eraseIntervals) {
subpath.push(point) subpath.push(point)
continue continue
} else if (nextPoint === undefined) {
if (JSON.stringify(eraseIntervals) != "[[0,0]]") subpath.push(point)
continue
} }
if (!pointWasErased(eraseIntervals) || subpath.length) { if (!pointWasErased(eraseIntervals) || subpath.length) {
......
...@@ -45,14 +45,19 @@ function project([x1, y1], [x2, y2], [x3, y3]) { ...@@ -45,14 +45,19 @@ function project([x1, y1], [x2, y2], [x3, y3]) {
} }
function erasureInterval(lineStart, lineEnd, erasureCenter, erasureRadius) { function erasureInterval(lineStart, lineEnd, erasureCenter, erasureRadius) {
if (!(lineStart && lineEnd && erasureCenter)) return if (!(lineStart && erasureCenter)) return undefined
if (!lineEnd) {
const dist2ToSingularity = distanceSquared(erasureCenter, lineStart)
return dist2ToSingularity <= erasureRadius ** 2 ? [0, 0] : undefined
}
const distToSegment2 = distToSegmentSquared(lineStart, lineEnd, erasureCenter) const distToSegment2 = distToSegmentSquared(lineStart, lineEnd, erasureCenter)
if (erasureRadius ** 2 < distToSegment2) return if (erasureRadius ** 2 < distToSegment2) return undefined
const lineLength = distance(lineStart, lineEnd) const lineLength = distance(lineStart, lineEnd)
if (lineLength === 0) { if (lineLength === 0) {
return distToSegment2 <= erasureRadius ** 2 ? [0, 1] : [0, 0] return distToSegment2 <= erasureRadius ** 2 ? [0, 1] : undefined
} }
const projT = project(lineStart, lineEnd, erasureCenter) const projT = project(lineStart, lineEnd, erasureCenter)
...@@ -98,7 +103,6 @@ function overlaps([s1, e1], [, e2]) { ...@@ -98,7 +103,6 @@ function overlaps([s1, e1], [, e2]) {
function mergeIntervals(...intervals) { function mergeIntervals(...intervals) {
if (!intervals.length) return [] if (!intervals.length) return []
const sorted = intervals.sort(([a], [b]) => a > b) const sorted = intervals.sort(([a], [b]) => a > b)
const stack = [sorted[0]] const stack = [sorted[0]]
sorted.forEach((x) => { sorted.forEach((x) => {
...@@ -121,3 +125,38 @@ export function combineErasureIntervals(i1, i2) { ...@@ -121,3 +125,38 @@ export function combineErasureIntervals(i1, i2) {
}) })
return { ...i2, ..._i1 } return { ...i2, ..._i1 }
} }
export function spreadErasureIntervals(intervals) {
const spread = []
intervals.forEach(([l, u]) => {
if (u > l) {
for (let li = Math.floor(l); li < u; li++) {
const list = spread[li] || []
const [il, iu] = [Math.max(li, l), Math.min(li + 1, u)]
list.push([il % 1, iu == li + 1 ? 1 : iu % 1])
spread[li] = list
}
} else {
spread[Math.floor(l)] = [[l % 1, u % 1]]
}
})
return spread
}
export function flattenErasureIntervals(intervals) {
const flatten = []
for (const idx in intervals) {
if (intervals[idx])
flatten.push(
intervals[idx].map(([l, u]) => [parseInt(idx) + l, parseInt(idx) + u]),
)
}
return flatten.flat()
}
...@@ -11,6 +11,12 @@ yMap(Y) ...@@ -11,6 +11,12 @@ yMap(Y)
yArray(Y) yArray(Y)
yWebrtc(Y) yWebrtc(Y)
import {
combineErasureIntervals,
spreadErasureIntervals,
flattenErasureIntervals,
} from "./erasure.js"
class Room extends EventTarget { class Room extends EventTarget {
constructor(name) { constructor(name) {
super() super()
...@@ -37,23 +43,22 @@ class Room extends EventTarget { ...@@ -37,23 +43,22 @@ class Room extends EventTarget {
extendErasureIntervals(pathID, pointID, newIntervals) { extendErasureIntervals(pathID, pointID, newIntervals) {
const self = this const self = this
const afterJSON = JSON.stringify(newIntervals) // eslint-disable-next-line require-yield
this._y.db.requestTransaction(function* requestTransaction() { this._y.db.requestTransaction(function* requestTransaction() {
const pathIntervals = yield* JSON.parse( const prevJSON = self.sharedMergeIntervals.get(pathID) || "[]"
self.sharedMergeIntervals.get(pathID) || "{}", const pathIntervals = JSON.parse(prevJSON)
)
const combinedIntervals = combineErasureIntervals(
[pathIntervals],
[flattenErasureIntervals({ [pointID]: newIntervals })],
)[0]
const postJSON = JSON.stringify(combinedIntervals)
if (afterJSON == JSON.stringify(pathIntervals[pointID])) { if (prevJSON == postJSON) {
return return
} }
pathIntervals[pointID] = newIntervals self.sharedMergeIntervals.set(pathID, postJSON)
yield* self.sharedMergeIntervals.set(
pathID,
JSON.stringify(pathIntervals),
)
}) })
} }
...@@ -88,8 +93,10 @@ class Room extends EventTarget { ...@@ -88,8 +93,10 @@ class Room extends EventTarget {
_generateRemovedIntervals(id) { _generateRemovedIntervals(id) {
const intervals = this.sharedMergeIntervals.get(id) const intervals = this.sharedMergeIntervals.get(id)
if (!intervals) return [] if (!intervals) return []
return JSON.parse(intervals)
return spreadErasureIntervals(JSON.parse(intervals))
} }
inviteUser(id) { inviteUser(id) {
......
0% Loading or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment