Stellen Sie sich ein CSP-Modell vor, bei dem das Ändern des Werts einer bestimmten Variablen teuer ist. Gibt es Arbeiten, bei denen die Zielfunktion auch die Anzahl der Änderungen des Werts der Variablen während des Suchvorgangs berücksichtigt?
Ein Beispiel: Die Variable, deren Änderung teuer ist, kann von einem anderen Agenten gesteuert werden, und es besteht ein gewisser Aufwand, diesen Agenten in die Änderung der Variablen einzubeziehen. Ein weiteres Beispiel: Die Variable nimmt an einer der Einschränkungen teil, und die Erfüllung dieser Einschränkung beinhaltet das Aufrufen einer teuren Funktion (z. B. eines Simulators), z. B. ist die Einschränkung, und ist eine teure Funktion. zu berechnende Funktion. Daher sind und teuer zu ändernde Variablen.
Antworten:
Es hört sich so an, als ob Sie eine kostensensitive (kostenbewusste, budgetierte) Optimierungstechnik wünschen . Das Minimieren von zwei Werten (z. B. die Lösung Ihres Ziels und die Betriebskosten für und ) ist ein Optimierungsproblem mit mehreren Kriterien , und diese sind in der Regel sehr schwer zu lösen. Ein üblicher Ansatz besteht darin, ein Budget für die maximal zulässigen Kosten anzugeben und dann die Zielfunktion in Bezug auf die minimieren . Diese Formulierung passt als zusätzliche Einschränkung gut in vorhandene Frameworks. Natürlich kann es schwierig sein, die Kostenfunktion und das zulässige Budget so anzugeben, dass Sie aussagekräftige Lösungen erhalten - dies hängt von dem spezifischen Problem ab, das Sie lösen möchten.x y costs(x,y)≤Budget
quelle