El problema de corte de valores es un problema NP-completo optimización, esencialmente se reduce al problema de la mochila. Específicamente, es un problema de programación lineal con números enteros. Surge de muchas aplicaciones en la industria. Imagine que usted trabaja en una fábrica de papel y tiene un número de rollos de papel de ancho fijo a la espera de ser cortado, pero diferentes clientes quieren diferentes números de rollos de distintos tipos de anchos. ¿Cómo se van a cortar los rollos de manera que minimiza los residuos (cantidad de sobras)?
De acuerdo con la Confederación Europeas de Industrias Papeleras,[1] en 2012 las 1,331 máquinas de papel en la región, producen cada una un promedio € 56 millones (aproximadamente $ 73 millones US.) de la facturación. Ahorrar incluso fracciones de 1% es, por tanto, significativo.
La formulación estándar para el problema de corte de valores (pero no la única) comienza con una lista de m órdenes, cada una requiriere piezas. A continuación se construye una lista de todas las combinaciones posibles de los recortes (a menudo llamados "patrones"), asociando a cada patrón una variable entera positiva que representa cuántas veces será utilizado cada patrón. El programa entero lineal es entonces:
donde es el número de veces que la orden aparece en el patrón y es el costo (a menudo los residuos) del patrón . La naturaleza precisa de la cantidad de restricciones puede llevar a características matemáticas diferentes. Las mismas constituyen la cantidad de restricciones mínimas(por lo menos la cantidad que cada orden debe producir, pero posiblemente más). Cuando el objetivo minimiza el número de elementos maestros utilizados y, si la restricción de la cantidad a producir se sustituye por la igualdad, se llama la problema de embalaje Bin. La formulación más general tiene restricciones de dos lados (y en este caso una solución de conversión de residuos mínimo puede consumir más que el número mínimo de elementos maestros):
Esta formulación se aplica no sólo a los problemas de una sola dimensión. Muchas variaciones son posibles, incluyendo uno en el que el objetivo no es reducir al mínimo los desechos, si no maximizar el valor total de los artículos producidos, permitiendo que cada orden tenga un valor diferente.
En general, el número de posibles patrones crece exponencialmente en función del número de órdenes m. A medida que el número de pedidos aumenta, puede no ser práctico enumerar los posibles patrones de corte.
Un enfoque alternativo utiliza generación-retrasada de columnas. Este método resuelve el problema del corte de valores comenzando con unos pocos patrones. Genera patrones adicionales cuando se necesitan. Para el caso unidimensional, los nuevos patrones se introducen mediante la resolución de un problema de optimización auxiliar llamado el problema de la mochila, utilizando información de variables duales desde el programación lineal. El problema de la mochila tiene métodos de solución, como el conocido ramificación y acotación y programación dinámica. El método de generación de columnas retardada puede ser mucho más eficiente que el enfoque original, en particular como el tamaño del problema crece. El enfoque de generación de columna aplicado al problema de corte fue iniciado por Gilmore y Gomory en una serie de artículos publicados en la década de 1960.[2][3] Gilmore y Gomory demostraron que este enfoque garantiza la convergencia a la solución óptima (fraccionada), sin necesidad de enumerar todos los posibles patrones de antemano.
Una limitación del método original de Gilmore y Gomory es que no maneja integralidad, por lo que la solución puede contener fracciones, por ejemplo, un patrón particular se debe producir 3,67 veces. El redondeo al entero más próximo a menudo no funciona, en el sentido de que puede llevar a una solución subóptima y/o inviabilidad sub- o sobre-producción de algunas de las órdenes (y posible en presencia de restricciones de demanda de dos caras ). Esta limitación se supera en los algoritmos modernos, que pueden resolver óptimamente (en el sentido de encontrar soluciones con un mínimo de desperdicio) muy grandes instancias del problema (generalmente mayor de la habitual en la práctica[4][5]).
El problema de corte de valores es a menudo degenerado, en que son posibles varias soluciones con el mismo residuos. Esta degeneración se debe a que es posible mover los elementos alrededor, creando nuevos patrones, sin afectar a los residuos. Esto da lugar a toda una colección de problemas afines que se ocupan de algún otro criterio, como el siguiente:
Una máquina de papel puede producir un número ilimitado de rollos maestros (jumbo), cada uno mide 5600 mm de ancho. Los siguientes 13 artículos deben ser cortados:
Width | Rolls |
---|---|
1380 | 22 |
1520 | 25 |
1560 | 12 |
1710 | 14 |
1820 | 18 |
1880 | 18 |
1930 | 20 |
2000 | 10 |
2050 | 12 |
2100 | 14 |
2140 | 16 |
2150 | 18 |
2200 | 20 |
Hay 308 patrones posibles para este pequeño ejemplo. La respuesta óptima requiere 73 rollos maestros y tiene 0,401% de residuos; se puede demostrar computacionalmente que en este caso el número mínimo de patrones con este nivel de residuos es 10. También se puede calcular que existen 19 diferentes soluciones, cada una con 10 patrones y una pérdida de 0,401%, de las que una solución se muestra a continuación:
Repetition | Contents |
---|---|
2 | 1820 + 1820 + 1820 |
3 | 1380 + 2150 + 1930 |
12 | 1380 + 2150 + 2050 |
7 | 1380 + 2100 + 2100 |
12 | 2200 + 1820 + 1560 |
8 | 2200 + 1520 + 1880 |
1 | 1520 + 1930 + 2150 |
16 | 1520 + 1930 + 2140 |
10 | 1710 + 2000 + 1880 |
2 | 1710 + 1710 + 2150 |
73 |
Los problemas de corte de acciones se pueden clasificar de varias maneras.[9] Una forma es la dimensionalidad del corte: el ejemplo anterior ilustra un problema unidimensional (1D); otras aplicaciones industriales de 1D se producen al cortar los tubos, cables y barras de acero. Problemas de dos dimensiones (2D) se encuentran en los muebles, la ropa y la producción de vidrio. No se conocen muchas aplicaciones tridimensionales (3D) que implican el corte; sin embargo, el estrechamente relacionados problema de empaquetamiento 3D tiene muchas aplicaciones industriales, tales como el empaquetamiento de objetos en los contenedores de transporte (ver por ejemplo contenerización - el relacionado Empaquetamiento de esferas problema que ha sido estudiado desde el siglo XVII (Conjetura de Keplerr )).
Las aplicaciones industriales de los problemas de corte por acciones de altos volúmenes de producción surgen sobre todo cuando el material de base se produce en grandes rollos que se cortan en unidades más pequeñas (véase rollo rajar). Esto se hace, por ejemplo, no solo en las industrias de película de plástico y papel, sino también en la producción de metales planos, como el acero o el latón. Hay muchas variantes y restricciones adicionales derivadas de las limitaciones de producción especiales debido a la maquinaria y procesos límites, los requisitos del cliente y los problemas de calidad; Algunos ejemplos son:
Proveedores de software que solucionan el problema de corte de valores para la industria del papel incluyen ABB Group, Greycon, Honeywell y Tieto.
Un algoritmo cutstock para la industria siderúrgica más tarde fue formulada por Robert Gongorra en 1998 and SONS (Software de Optimización de anidamiento de Acero) fue desarrollado para la industria del acero para mejorar el uso de acero y reducir al mínimo los residuos.
El problema guillotina es un problema de cortar láminas de vidrio en rectángulos de tamaños especificados, utilizando sólo los cortes que siguen todo el camino a través de cada hoja.
El problema relacionado de determinar, para el caso unidimensional, el mejor tamaño de master que se reunirá dada la demanda se conoce como el problema variedad.[10]
El problema de corte de valores fue formulada por primera vez por Kantorovich en 1939.[11] En 1951 antes de que se dispusiera de los ordenadores, L. V. Kantorovich y VA Zalgaller sugirieron[12] resolver el problema de la utilización económica de material en la etapa de corte con la ayuda de la programación lineal. La técnica propuesta más tarde se llamó el método de generación de columnas.
Nombre | Licencia | Breve información |
---|---|---|
VPSolver | GPL | Vector Solución de Código Abierto (VPSolver) que se puede utilizar para resolver los problemas de corte optimalidad unidimensional como problema de embalaje de vector unidimensional. El método de solución se basa en una formulación de arco de flujo con compresión gráfico. |