Major changes: - New frontend (platform/web/): Vite + React 18 + TypeScript + Tailwind - 4-module navigation: 数据送标 / 模型管理 / 车队管理 / 系统管理 - Data catalog with charts (DMS/ADAS/Lane 3-tab view) - Quality review workflow (标注质检): Good/Fine/Bad scoring with auto-advance - Audit enhancements: batch operations, rejection categories, Feishu notifications - Operation audit log (操作日志) - World model simulation studio (仿真工坊) - Dataset version management with snapshots and diff - ADAS 7-class dataset integration (138K images organized + compressed) - User management with Feishu integration and pagination - CRUD/search/filter on all pages, card layout redesign - PIL-optimized image overlay rendering - Auto-snapshot on build, in_review workflow stage - Removed embedded algorithm code (now in workspace)
25 lines
869 B
JavaScript
25 lines
869 B
JavaScript
/*
|
|
Given the ratio a : b : c = 2 : 3 : 4
|
|
What is c, given a = 40?
|
|
|
|
A general ratio chain is a_1 : a_2 : a_3 : ... : a_n = r_1 : r2 : r_3 : ... : r_n.
|
|
Now each term can be expressed as a_i = r_i * x for some unknown proportional constant x.
|
|
If a_k is known it follows that x = a_k / r_k. Substituting x into the first equation yields
|
|
a_i = r_i / r_k * a_k.
|
|
|
|
Given an array r and a given value a_k, the following function calculates all a_i:
|
|
*/
|
|
|
|
function calculateRatios(r, a_k, k) {
|
|
const x = Fraction(a_k).div(r[k]);
|
|
return r.map(r_i => x.mul(r_i));
|
|
}
|
|
|
|
// Example usage:
|
|
const r = [2, 3, 4]; // Ratio array representing a : b : c = 2 : 3 : 4
|
|
const a_k = 40; // Given value of a (corresponding to r[0])
|
|
const k = 0; // Index of the known value (a corresponds to r[0])
|
|
|
|
const result = calculateRatios(r, a_k, k);
|
|
console.log(result); // Output: [40, 60, 80]
|