958189227d
Auditoria del issue 0044: anota en notes: el contexto de consumo de
huerfanos que no pueden registrarse en uses_functions porque sus
consumidores no son funciones del registry:
- consumido por cpp/framework/app_base.cpp (framework no indexado)
- consumido por cpp/apps/{shaders_lab,chart_demo,text_editor_smoke}/main.cpp
- scaffolding/demo en primitives_gallery
31 huerfanas anotadas. Las que quedan en uses_functions=[] tras esto
son hojas legitimas (no llaman a nada) o realmente sin uso (lista
DEAD reportada en el issue 0044).
Co-Authored-By: Claude Opus 4.7 (1M context) <noreply@anthropic.com>
66 lines
2.2 KiB
Markdown
66 lines
2.2 KiB
Markdown
---
|
|
name: contour
|
|
kind: component
|
|
lang: cpp
|
|
domain: viz
|
|
version: "1.0.0"
|
|
purity: pure
|
|
signature: "void contour(const char* id, const float* grid, int nx, int ny, const float* levels, int n_levels, ImVec2 size)"
|
|
description: "Contour plot 2D usando marching squares clasico (16 casos) con interpolacion lineal entre celdas. Layout puro separado del render."
|
|
tags: [imgui, drawlist, chart, visualization, contour, marching-squares, scalar-field]
|
|
uses_functions: []
|
|
uses_types: []
|
|
returns: []
|
|
returns_optional: false
|
|
error_type: ""
|
|
imports: [imgui]
|
|
tested: false
|
|
tests: []
|
|
test_file_path: ""
|
|
file_path: "cpp/functions/viz/contour.cpp"
|
|
framework: imgui
|
|
params:
|
|
- name: id
|
|
desc: "Identificador unico para PushID"
|
|
- name: grid
|
|
desc: "Grid 2D row-major (grid[y*nx + x])"
|
|
- name: nx
|
|
desc: "Numero de columnas del grid"
|
|
- name: ny
|
|
desc: "Numero de filas del grid"
|
|
- name: levels
|
|
desc: "Array de niveles a contornear"
|
|
- name: n_levels
|
|
desc: "Cantidad de niveles"
|
|
- name: size
|
|
desc: "Tamano del rect de render. x <= 0 usa el ancho disponible"
|
|
output: "Renderiza los contornos como segmentos de linea (AddLine) con color por nivel (gradiente azul->amarillo)"
|
|
notes: "scaffolding/demo en primitives_gallery"
|
|
---
|
|
|
|
# contour
|
|
|
|
Marching squares clasico para contornos isovaluados de un grid 2D escalar.
|
|
|
|
`contour_compute` es pura: para cada nivel devuelve un `ContourLine{pts, level}` donde `pts` es una secuencia de pares (cada par es un segmento). Los puntos estan en coords [0..nx-1] x [0..ny-1] del grid — el render escala a la region.
|
|
|
|
Casos ambiguos 5 y 10 se resuelven con dos segmentos (sin desambiguar por el centro). Para campos suaves (gaussianas, etc.) este caso es raro.
|
|
|
|
## Validacion
|
|
|
|
Para una gaussiana 2D (cumbre en el centro) con varios niveles, los contornos resultantes son anillos cerrados aproximadamente concentricos. Si las isolineas de una gaussiana no se cierran, es un bug del algoritmo.
|
|
|
|
## Ejemplo
|
|
|
|
```cpp
|
|
constexpr int N = 32;
|
|
float grid[N*N];
|
|
for (int y = 0; y < N; y++)
|
|
for (int x = 0; x < N; x++) {
|
|
float dx = x - N/2.0f, dy = y - N/2.0f;
|
|
grid[y*N + x] = std::exp(-(dx*dx + dy*dy) / 80.0f);
|
|
}
|
|
float levels[] = {0.1f, 0.3f, 0.5f, 0.7f, 0.9f};
|
|
contour("##gauss", grid, N, N, levels, 5, ImVec2(-1, 300));
|
|
```
|