Docs: Update Gemini benchmark results

This commit is contained in:
github-actions[bot]
2025-11-18 19:30:39 +00:00
parent 51a98c1e1b
commit 76fb066932
133 changed files with 2340 additions and 0 deletions

View File

@@ -0,0 +1,10 @@
const analyzeGPS = async (readings, boundary) => {
const T = await import('https://esm.sh/@turf/turf')
const pts = readings
.filter(r => T.booleanPointInPolygon(T.point(r.loc), boundary, { ignoreBoundary: true }))
.sort((a, b) => a.ts - b.ts)
.map(r => r.loc)
return pts.length < 2 ? 0 : +T.length(T.lineString(pts), { units: 'kilometers' }).toFixed(2)
}
export default analyzeGPS;

View File

@@ -0,0 +1,12 @@
const analyzeGPS = async (readings, boundary) => {
const t = await import('https://cdn.jsdelivr.net/npm/@turf/turf/+esm');
const pts = readings
.filter(({ loc }) => t.booleanPointInPolygon(t.point(loc), boundary, { ignoreBoundary: true }))
.sort((a, b) => a.ts - b.ts)
.map(({ loc }) => loc);
return pts.length < 2 ? 0 :
Math.round(t.length(t.lineString(pts), { units: 'kilometers' }) * 100) / 100;
};
export default analyzeGPS;

View File

@@ -0,0 +1,14 @@
const analyzeGPS = async (readings, boundary) => {
const T = await import('https://esm.sh/@turf/turf');
const pts = readings
.filter(r => T.booleanPointInPolygon(T.point(r.loc), boundary, { ignoreBoundary: true }))
.sort((a, b) => a.ts - b.ts)
.map(r => r.loc);
if (pts.length < 2) return 0;
const len = T.length(T.lineString(pts), { units: 'kilometers' });
return Math.round(len * 100) / 100;
};
export default analyzeGPS;

View File

@@ -0,0 +1,12 @@
const analyzeGPS = async (readings, boundary) => {
const t = await import('https://cdn.jsdelivr.net/npm/@turf/turf/+esm');
const pts = readings
.filter(({ loc }) => t.booleanPointInPolygon(t.point(loc), boundary, { ignoreBoundary: true }))
.sort((a, b) => a.ts - b.ts)
.map(({ loc }) => loc);
return pts.length < 2 ? 0 :
Math.round(t.length(t.lineString(pts), { units: 'kilometers' }) * 100) / 100;
};
export default analyzeGPS;

View File

@@ -0,0 +1,13 @@
const analyzeGPS = async (readings, boundary) => {
const { booleanPointInPolygon, point, lineString, length } = await import('https://esm.sh/@turf/turf');
const coords = readings
.filter(({ loc }) => booleanPointInPolygon(point(loc), boundary, { ignoreBoundary: true }))
.sort((a, b) => a.ts - b.ts)
.map(({ loc }) => loc);
return coords.length < 2
? 0
: +length(lineString(coords), { units: 'kilometers' }).toFixed(2);
};
export default analyzeGPS;

View File

@@ -0,0 +1,10 @@
const analyzeGPS = async (readings, boundary) => {
const t = await import('https://esm.sh/@turf/turf');
const pts = readings
.filter(r => t.booleanPointInPolygon(t.point(r.loc), boundary, { ignoreBoundary: true }))
.sort((a, b) => a.ts - b.ts)
.map(r => r.loc);
return pts.length < 2 ? 0 : +t.length(t.lineString(pts), { units: 'kilometers' }).toFixed(2);
};
export default analyzeGPS;

View File

@@ -0,0 +1,12 @@
const analyzeGPS = async (readings, boundary) => {
const { booleanPointInPolygon, point, lineString, length } = await import('https://esm.sh/@turf/turf');
const path = readings
.filter(({ loc }) => booleanPointInPolygon(point(loc), boundary, { ignoreBoundary: true }))
.sort((a, b) => a.ts - b.ts)
.map(({ loc }) => loc);
return path.length < 2 ? 0 :
Math.round(length(lineString(path), { units: 'kilometers' }) * 100) / 100;
};
export default analyzeGPS;

View File

@@ -0,0 +1,10 @@
const analyzeGPS = async (readings, boundary) => {
const T = await import('https://cdn.jsdelivr.net/npm/@turf/turf/+esm')
const pts = readings
.filter(r => T.booleanPointInPolygon(T.point(r.loc), boundary, { ignoreBoundary: true }))
.sort((a, b) => a.ts - b.ts)
.map(r => r.loc)
return pts.length < 2 ? 0 : +T.length(T.lineString(pts), { units: 'kilometers' }).toFixed(2)
}
export default analyzeGPS;

View File

@@ -0,0 +1,12 @@
const analyzeGPS = async (readings, boundary) => {
const { booleanPointInPolygon, point, lineString, length } = await import('https://esm.sh/@turf/turf');
const pts = readings
.filter(r => booleanPointInPolygon(point(r.loc), boundary, { ignoreBoundary: true }))
.sort((a, b) => a.ts - b.ts)
.map(r => r.loc);
return pts.length < 2 ? 0
: +length(lineString(pts), { units: 'kilometers' }).toFixed(2);
};
export default analyzeGPS;

View File

@@ -0,0 +1,12 @@
const analyzeGPS = async (readings, boundary) => {
const { booleanPointInPolygon, point, lineString, length } = await import('https://esm.sh/@turf/turf');
const coords = readings
.filter(({ loc }) => booleanPointInPolygon(point(loc), boundary, { ignoreBoundary: true }))
.sort((a, b) => a.ts - b.ts)
.map(({ loc }) => loc);
return coords.length < 2 ? 0 :
Math.round(length(lineString(coords), { units: 'kilometers' }) * 100) / 100;
};
export default analyzeGPS;

View File

@@ -0,0 +1,14 @@
const analyzeGPS = async (readings, boundary) => {
const { booleanPointInPolygon, point, lineString, length } = await import('https://esm.sh/@turf/turf')
const path = readings
.filter(({ loc }) => booleanPointInPolygon(point(loc), boundary))
.sort((a, b) => a.ts - b.ts)
.map(({ loc }) => loc)
if (path.length < 2) return 0
const dist = length(lineString(path), { units: 'kilometers' })
return Math.round(dist * 100) / 100
}
export default analyzeGPS;

View File

@@ -0,0 +1,14 @@
const analyzeGPS = async (readings, boundary) => {
const { booleanPointInPolygon, point, lineString, length } = await import('https://esm.sh/@turf/turf')
const path = readings
.filter(({ loc }) => booleanPointInPolygon(point(loc), boundary, { ignoreBoundary: true }))
.sort((a, b) => a.ts - b.ts)
.map(({ loc }) => loc)
if (path.length < 2) return 0
const dist = length(lineString(path), { units: 'kilometers' })
return Math.round(dist * 100) / 100
}
export default analyzeGPS;