#JusLab - Script para asignar causas judiciales por sorteo a los distintos juzgados
Se puede ver una presentación del proyecto en Presentación JusLab.odp (se puede abrir con LibreOffice o Google Slides)
El script export_delitos_unique.py exporta los tipos de delitos únicos del csv penal_df.csv (mirando el campo id de los delitos oju_id).
El script main.py lee ese archivo (renombrado a Tipos de delitos por complejidad - tipos-delitos.csv) y reparte secuencialmente por sorteo todas las causas de la planilla penal_df.csv a los 31 distintos juzgados, teniendo en consideración repartir equitativamente las causas según las gravedades de las mismas. De esta forma balancea la carga de trabajo entre todos los juzgados equitativamente.
El algoritmo se puede reducir a la siguiente línea que utiliza la librería numpy
para sortear un juzgado entre
todos los juzgados, dándole más peso en el sorteo a los que tengan menos "gravedad acumulada":
juzgado_sorteado = numpy.random.choice(juzgados, p=pesos_normalizados)
Esto se logra definiendo los pesos como la inversa de la cantidad de "gravedad acumulada" de cada juzgado hasta el momento (con una posterior normalización):
pesos = [1-juz.gravedad_acumulada/total_gravedades for juz in juzgados]