Añadido endpoint para el cálculo de referencias
This commit is contained in:
+54
-2
@@ -1,8 +1,60 @@
|
|||||||
from fastapi import FastAPI
|
from fastapi import FastAPI
|
||||||
|
from pydantic import BaseModel
|
||||||
|
from typing import List, Dict
|
||||||
|
|
||||||
app = FastAPI()
|
app = FastAPI()
|
||||||
|
|
||||||
|
# 1. Definimos el modelo de datos basado en el JSON que se enviará desde el frontend
|
||||||
|
class ValueFunctionRequest(BaseModel):
|
||||||
|
criterion_name: str
|
||||||
|
levels: List[str]
|
||||||
|
blank_cards: List[int]
|
||||||
|
references: Dict[str, float]
|
||||||
|
|
||||||
|
# Ruta prueba para probar que todo funciona
|
||||||
@app.get("/prueba")
|
@app.get("/prueba")
|
||||||
def ruta_de_prueba():
|
def ruta_de_prueba():
|
||||||
# En FastAPI si devuelves un diccionario, se transforma a JSON
|
return {"mensaje": "¡Hola desde FastAPI! El contenedor de docker está funcionando"}
|
||||||
return {"mensaje": "¡Hola desde FastAPI! El contenedor de docker está funcionando"}
|
|
||||||
|
# 2. Endpoint POST para recibir los datos y calcular los valores
|
||||||
|
@app.post("/api/criteria/doc/value-function")
|
||||||
|
def calcular_funcion_valor(request: ValueFunctionRequest):
|
||||||
|
levels = request.levels
|
||||||
|
blank_cards = request.blank_cards
|
||||||
|
refs = request.references
|
||||||
|
|
||||||
|
# Extraemos las claves de referencia y las convertimos a enteros
|
||||||
|
claves_ref = sorted(int(k) for k in refs.keys()) # ejemplo: [0, 4]
|
||||||
|
p, q = claves_ref # p = 0, q = 4
|
||||||
|
|
||||||
|
# Valores de referencia
|
||||||
|
up = refs[str(p)]
|
||||||
|
uq = refs[str(q)]
|
||||||
|
|
||||||
|
# PASO A: Calculamos el número total de unidades elementales 'h' entre p y q
|
||||||
|
h = sum(blank_cards[r] + 1 for r in range(p, q))
|
||||||
|
|
||||||
|
# PASO B: Calculamos el valor fraccional de una sola unidad 'alpha'
|
||||||
|
alpha = (uq - up) / h if h != 0 else 0
|
||||||
|
|
||||||
|
# Inicializamos la lista de valores V con el tamaño de los niveles
|
||||||
|
V = [0.0] * len(levels)
|
||||||
|
V[p] = up
|
||||||
|
|
||||||
|
# PASO C: Calculamos los valores hacia adelante (niveles por encima de p)
|
||||||
|
for i in range(p + 1, len(levels)):
|
||||||
|
suma_unidades = sum(blank_cards[r] + 1 for r in range(p, i))
|
||||||
|
V[i] = up + alpha * suma_unidades
|
||||||
|
|
||||||
|
# PASO D: Calculamos los valores hacia atrás (niveles por debajo de p)
|
||||||
|
for i in range(p - 1, -1, -1):
|
||||||
|
suma_unidades = sum(blank_cards[r] + 1 for r in range(i, p))
|
||||||
|
V[i] = up - alpha * suma_unidades
|
||||||
|
|
||||||
|
# Formateamos la respuesta
|
||||||
|
resultado_valores = {levels[i]: round(V[i], 4) for i in range(len(levels))}
|
||||||
|
|
||||||
|
return {
|
||||||
|
"criterion_name": request.criterion_name,
|
||||||
|
"values": resultado_valores
|
||||||
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user