Verständnis Problem bei Rucksack Problem

Kirby.exe

Top Contributor
Also in der letzten Serie sollten wir das 0-1 Rucksack Problem auf eine gegebene Instanz anwenden (mit Branch and Bound). Dies habe ich auch soweit verstanden.

Jedoch sollen wir jetzt das "normale" Rucksack Problem in einen Branch und Bound Algorithmus überführen. Sprich jedes Element aus der Menge darf mehrfach in den Rucksack. Ich zerbreche mir jetzt schon seit Stunden wie ich das machen soll xD Ich würde es mir ja gerne visualisieren, aber der Baum wird sehr schnell sehr groß xD

Vielleicht hat ja einer von euch einen Tipp :)
 

Kirby.exe

Top Contributor
Also im Prinzip wird bei jedem Knoten (bei eine 5 Elemente in der gegebenen Menge) 10 mal gebranched. Also 5 mal Knoten ist drin und 5 mal Knoten ist nicht drin.

Als Relaxation habe ich mir die LP - Relaxation gewählt.

Sei das folgende ein Beispiel:
Die Mengen C (Wert) und A (Gewicht) laufen auf gleichem Index.

Maximal Gewicht = 1800
C := [509, 599, 499, 699, 329]
A := [341, 478, 603, 900 , 680]

Hier sind die Elemente schon nach Kosten/Nutzen absteigend sortiert.

Als upper Bound nehme ich das Element mit dem besten Kosten/Nutzen aufwand. Das wäre das Tupple (509,341). Dieses passt ganzzahlig 5 mal in den Rucksack. Mittels der Relaxation kommt heraus, dass noch 27% des selben Elements herein passen. Somit kommt man auf einen Wert von 2682 als upper Bound.

Als lower Bound wähle ich mir eine beliebige Belegung in diesem Fall 5 mal das Element mit dem besten Kosten/Nutzen Aufwand. Somit kommt man auf einen Wert von 2545.

Weiter muss ich noch überlegen xD
 

Kirby.exe

Top Contributor
Update:

Also ich habe eine Idee :) Ich könntes es mit einem Rekursiv lösen.

Die Abbruch bedigungen wären die Pruning Regeln:

- pruned by bound, wenn die lower Bound die upper Bound überschreitet.
- pruned by optimality, wenn eine Lösung gefunden wurde
 
Zuletzt bearbeitet:

Kirby.exe

Top Contributor
So würde jetzt meine Base Node aussehen also mit der relaxierten Upper Bound und einer beliebigen Belegung als Lower Bound:

Java:
private static int knapsack(int capacity, Element[] arr) {
        TreeNode elem = new TreeNode(-1, 0, 0, 0, 0.0, arr);
        Arrays.sort(arr, new ElementComparator());
        int weight = 0;
        int numberFit = 0;
        double upperBound = 0;
        double lowerBound = 0;
        while(weight <= capacity) {
            if((weight + arr[0].weight) <= capacity) {
                upperBound += arr[0].value;
                weight += arr[0].weight;
                numberFit++;
            }else {
                break;
            }
        }
        double percent = (capacity-weight)/arr[0].weight;
        upperBound += arr[0].value*percent;
        lowerBound = arr[0].value*numberFit;
        
        elem.lowerBound = (int) lowerBound;
        elem.upperBound = (int) upperBound;
        System.out.println(percent);
        System.out.println("Upper Bound: " + (int) upperBound + ", Lower Bound: " + (int) lowerBound);
        return knapsackSolver(elem, capacity);
    }

Über die knapsackSolver() Methode zerbreche ich mir immernoch den Kopf xD
 

Kirby.exe

Top Contributor
Also ich sitze immernoch an der scheiße und weiß langsam nicht mehr weiter...Ich bekomme zwar keine Exceptions mehr, dafür läuft mein Code in einer Endlosschleife....

Ich kann ja mal alles reinschicken, vielleicht sieht einer von euch den Fehler:

Java:
import java.io.BufferedReader;
import java.io.File;
import java.io.FileNotFoundException;
import java.io.FileReader;
import java.io.IOException;
import java.util.ArrayList;
import java.util.Arrays;
import java.util.Comparator;
import java.util.LinkedList;
import java.util.Queue;
import java.util.Stack;

public class KnappsackProblem {
    
    private static int K = 0;
    private static int N = 0;

    public static void main(String[] args) {
        String file = "example.txt";
        Element [] arr = readInstances("Directory To Instances" + file);//new Element[N];
        
        System.out.println(knapsack(K, arr));
    }
    
    private static int knapsack(int capacity, Element[] arr) {
        TreeNode elem = new TreeNode(0, 0, null, 0, 0.0, null);
        Arrays.sort(arr, new ElementComparator());
        
        elem.items = arr;
        
        int weight = 0;
        int numberFit = 0;
        double upperBound = 0;
        double lowerBound = 0;
        while(weight <= capacity) {
            if((weight + arr[0].weight) <= capacity) {
                upperBound += arr[0].value;
                weight += arr[0].weight;
                numberFit++;
            }else {
                break;
            }
        }
        
        UpperBound bound = new UpperBound((int) upperBound, 0, weight, 0);
        
        double percent = (capacity-weight)/arr[0].weight;
        upperBound += arr[0].value*percent;
        weight += arr[0].weight*percent;
        lowerBound = arr[0].value*numberFit;
        
        elem.lowerBound = (int) lowerBound;
        bound.filledBound = (int) Math.ceil(upperBound);
        bound.filledBoundWeight = weight;
                
        elem.upperBound = bound;
        return knapsackSolver(elem, capacity);
    }
    
    private static int knapsackSolver(TreeNode elem, int capacity) {
        
        if(elem.lowerBound > elem.upperBound.filledBound) {
            System.out.println(elem);
            System.out.println("Youre a bitch...Pruned by Bound!");
            return 0;
        }
        
        if(elem.profit > elem.upperBound.filledBoundWeight) {
            System.out.println(elem);
            System.out.println("Bitch goodbye...Pruned by Infeasability");
            return 0;
        }
        
        if(elem.upperBound.filledBound == elem.lowerBound) {
            System.out.println("Optimal Result");
            return elem.lowerBound;
        }
        
        TreeNode[] arr = new TreeNode[elem.items.length*2];
        int indexer = 0;
        for(int i = 0; i < elem.items.length; i++) {
            UpperBound boundIn = findBound(i, capacity, elem.profit + elem.items[i].value,
                                            elem.weight + elem.items[i].weight, true, elem.items, elem.upperBound);
            
            TreeNode in = new TreeNode(elem.level + 1,
                                        elem.profit + elem.items[i].value,
                                        boundIn,
                                        boundIn.normalBound,
                                        elem.weight + elem.items[i].weight,
                                        elem.items);
            
            Element[] itemsArr = new Element[elem.items.length-1];
            for(int j = 0, k = 0; j < elem.items.length; j++) {
                if(j != i) {
                    itemsArr[k] = elem.items[j];
                    k++;
                }
            }
            
            UpperBound boundOut = findBound(i, capacity, elem.profit, elem.weight, false, itemsArr, elem.upperBound);
            TreeNode out = new TreeNode(elem.level + 1,
                                        elem.profit,
                                        boundOut,
                                        boundOut.normalBound,
                                        elem.weight,
                                        itemsArr);
            
            arr[indexer] = in;
            arr[indexer+1] = out;
            indexer += 2;
        }
        
        Arrays.sort(arr, new TreeNodeComparator());
        int var = 0;
        int result = 0;
        for(int i = 0; i < arr.length; i++) {
            result = knapsackSolver(arr[i], capacity);
            var += result > var ? result : 0;
        }
        return var;
    }
        
    private static UpperBound findBound(int item, int capacity, int profit, double inputWeight, boolean bounding, Element[] arr, UpperBound oldBound) {
        double value = profit;
        double weight = inputWeight;
        
        if(arr.length > 0) {
            if(bounding){
                value += arr[item].value;
                weight += arr[item].weight;
            }
            
            UpperBound result = new UpperBound((int) value, 0, weight, 0);
            
            double percent = (capacity-weight)/arr[0].weight;
            System.out.println("Percent: " + percent);
            value = Math.ceil(value + (arr[0].value*percent));
            weight = Math.ceil(weight + (arr[0].weight*percent));
            
            result.filledBound = (int) value;
            result.filledBoundWeight = (int) weight;
            return result;
        }
        
        return oldBound;
    }
    
    @SuppressWarnings("resource")
    private static Element [] readInstances(String filepath) {
        try{
            File s = new File(filepath);
            BufferedReader in = new BufferedReader(new FileReader(s));
            
            ArrayList<Element> list = new ArrayList<>();
            
            String temp = "";
            temp = in.readLine();
            String [] part = temp.split(" ");
            N = Integer.parseInt(part[0]);
            K = Integer.parseInt(part[1]);
            
            int weight = 0;
            int value = 0;
            
            while((temp = in.readLine()) != null) {
                part = temp.split(" ");
                weight = Integer.parseInt(part[0]);
                value = Integer.parseInt(part[1]);
                list.add(new Element(weight, value));
            }
            return convertListToArray(list);
        }catch(NumberFormatException|IOException ex){
            ex.printStackTrace();
        }
        
        return null;
    }
    
    private static Element[] convertListToArray(ArrayList<Element> list) {
        Element[] result = new Element[list.size()];
        for(int i = 0; i < list.size(); i++) {
            result[i] = list.get(i);
        }
        return result;
    }
}

class ElementComparator implements Comparator<Element>{
    @Override
    public int compare(Element o1, Element o2) {
        if (!(o1 instanceof Element) || !(o2 instanceof Element))
            throw new ClassCastException();
        
        Element item1 = (Element) o1;
        Element item2 = (Element) o2;
        
        double value1 = (double) item1.value/item1.weight;
        double value2 = (double) item2.value/item2.weight;
        
        if(value1 < value2) return 1;
        else if(value1 > value2) return -1;
        
        return 0;
    }
}

class TreeNodeComparator implements Comparator<TreeNode>{

    @Override
    public int compare(TreeNode o1, TreeNode o2) {
        if (!(o1 instanceof TreeNode) || !(o2 instanceof TreeNode))
            throw new ClassCastException();
        
        TreeNode item1 = (TreeNode) o1;
        TreeNode item2 = (TreeNode) o2;
        
        if(item1.profit > item2.profit) return -1;
        else if(item1.profit < item2.profit) return 1;
        
        return 0;
    }
    
}

class Element{
    
    public double weight;
    public int value;
    
    public Element(double weight, int value) {
        this.weight = weight;
        this.value = value;
    }
    
    public String toString() {
        return "(Weigth: " + weight + ", Value: " + value + ")";
    }
}

class UpperBound{
    
    public int normalBound;
    public int filledBound;
    public double normalBoundWeight;
    public double filledBoundWeight;
    
    public UpperBound(int normalBound, int filledBound, double normalBoundWeight, double filledBoundWeight) {
        this.normalBound = normalBound;
        this.filledBound = filledBound;
        this.normalBoundWeight = normalBoundWeight;
        this.filledBoundWeight = filledBoundWeight;
    }
    
    public String toString() {
        return "(Normal Bound: " + this.normalBound + ", Weight: " + this.normalBoundWeight
                                + " | Filled Bound: " + this.filledBound
                                + ", Weight: " + this.filledBoundWeight + ")";
    }
}

class TreeNode {
    
    public int level;
    public int profit;
    public UpperBound upperBound;
    public int lowerBound;
    public double weight;
    public Element[] items;
    
    public TreeNode(int level, int profit, UpperBound upperBound, int lowerBound, double weight, Element[] items) {
        this.level = level;
        this.profit = profit;
        this.upperBound = upperBound;
        this.lowerBound = lowerBound;
        this.weight = weight;
        this.items = items;
    }
    
    public TreeNode(TreeNode old) {
        this.level = old.level;
        this.profit = old.profit;
        this.upperBound = old.upperBound;
        this.lowerBound = old.lowerBound;
        this.weight = old.weight;
        this.items = old.items;
    }
    
    public String toString() {
        return "(Level: " + level + ", Profit: " + profit + ", Lower Bound: " + lowerBound + ", Upper Bound: " + upperBound + ", Weight: " + weight + ")";
    }
}
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
D (Verständnis-)Problem mit Unterklasse Allgemeine Java-Themen 4
S Verständnis Problem - Classpath Allgemeine Java-Themen 5
berserkerdq2 Threads, wie genau läuft das in Java ab? (Ich kann Threads erstellen und nutzen, nur das Verständnis) Allgemeine Java-Themen 6
H Mathematisch fehlendes Verständnis (3D-Denken) Allgemeine Java-Themen 14
A Hilfe beim Verständnis Allgemeine Java-Themen 16
parrot Verständnis des Codes Allgemeine Java-Themen 3
L Vererbung Verständnis Probleme Vererbung Allgemeine Java-Themen 2
M True or false Verständnis Allgemeine Java-Themen 5
J Josephus Verständnis Allgemeine Java-Themen 1
J Verständnis Frage zur Instanz, Objekte, Instanzierung, Referenz Allgemeine Java-Themen 14
H Erste Schritte Beispiele zum Verständnis Allgemeine Java-Themen 3
T Input/Output Verständnis: Wo wird das File auf die Festplatte gepackt? Allgemeine Java-Themen 4
B Hilfe beim Verständnis von Mergesort Allgemeine Java-Themen 5
C int zu byte cast - verständnis Allgemeine Java-Themen 3
M Verständnis enum - switch Allgemeine Java-Themen 2
M Verständnis "synchronized" Allgemeine Java-Themen 4
C Verständnis zur Strukturierung von Java-Projekten/Interfaces Allgemeine Java-Themen 2
C Autoboxing Verständnis Allgemeine Java-Themen 4
S Probleme mit dem allgemeinen Verständnis zuverrebung usw. Allgemeine Java-Themen 6
krgewb Problem mit Umlauten und Eszett bei InputStream Allgemeine Java-Themen 3
Max246Sch Backtracking Problem Box Filler Allgemeine Java-Themen 6
NightVision402 VisualVM Startskript Problem Allgemeine Java-Themen 3
javaBoon86 Email Server Connection Problem Allgemeine Java-Themen 1
F Problem mit PDFBOX Library Allgemeine Java-Themen 1
A Java modul Problem Allgemeine Java-Themen 4
D Read JSON File Problem Allgemeine Java-Themen 9
urmelausdemeis Exception in thread "main" java.lang.Error: Unresolved compilation problem: Allgemeine Java-Themen 7
J Problem mit JasperReports Allgemeine Java-Themen 8
M log4j Problem mit jlink Allgemeine Java-Themen 19
8u3631984 Problem beim Mocken von Record Klassen Allgemeine Java-Themen 4
torresbig Website login Problem - Jsoup, wie bisher, klappt nicht! Allgemeine Java-Themen 31
P Selenium . getText Problem Allgemeine Java-Themen 9
A Jar zu Exe Problem Allgemeine Java-Themen 13
sserio Variablen Liste erstellt und ein Problem mit dem Index Allgemeine Java-Themen 6
S Folgendes Problem bei einem Programm Allgemeine Java-Themen 1
stormyark Problem beim Klassen erstellen Allgemeine Java-Themen 1
A Thread.sleep Problem Allgemeine Java-Themen 2
A Problem bei der Nachbarschafttest Allgemeine Java-Themen 11
Splayfer Problem: no main manifest attribute Allgemeine Java-Themen 3
G javamail Problem beim Empfangen von Nachrichten Allgemeine Java-Themen 3
Splayfer JDA Problem mit MessageCounter Allgemeine Java-Themen 0
Splayfer Problem mit BufferedWriter Allgemeine Java-Themen 3
F Streams als Alternative für dieses Problem ? Allgemeine Java-Themen 15
N Maven Problem mit Datenbanktreiber (H2 Embedded) Allgemeine Java-Themen 12
T Problem beim Umwandeln in eine Jar-Datei Allgemeine Java-Themen 3
B Einfach Elemente zweier Arraylisten kreuz und quer vergleichen, min und max Problem? Allgemeine Java-Themen 16
C ArrayList Problem Allgemeine Java-Themen 3
kev34 nim-Spiel problem Allgemeine Java-Themen 1
D Firebase retrieve data Problem, Child Element wird nicht angesprochen Allgemeine Java-Themen 0
G Welches Problem besteht bei den Typparametern? Allgemeine Java-Themen 5
temi Problem mit Aufrufreihenfolge bei Vererbung Allgemeine Java-Themen 3
Sumo_ow "ArrayIndexOutofBoundsException: 2" Array Problem Allgemeine Java-Themen 6
T PIM basierend auf netbeans via AnyDesk Problem Allgemeine Java-Themen 3
xGh0st2014 Problem mit Java Array Allgemeine Java-Themen 1
B Eclipse-Lombok-Problem Allgemeine Java-Themen 19
I Input/Output ObjectOutputStream - Problem Allgemeine Java-Themen 7
1 Multiple Choice Knapsack- Problem Allgemeine Java-Themen 2
kodela Problem mit strukturiertem Array Allgemeine Java-Themen 18
E Problem mit Gridlayout und Button Allgemeine Java-Themen 2
A Array Problem Allgemeine Java-Themen 8
bueseb84 Problem Allgemeine Java-Themen 0
S Problem mit Arrays Allgemeine Java-Themen 1
D Nullpointer Exception Problem Allgemeine Java-Themen 5
B Problem mit meinen Klassen Allgemeine Java-Themen 6
A HashMap Methode "get()"-Problem Allgemeine Java-Themen 28
J Problem beim Umstellen auf Java jdk 13 Allgemeine Java-Themen 3
J Problem bei Install java 13 Allgemeine Java-Themen 3
X Profitable Reise Problem Allgemeine Java-Themen 32
A Problem beim öffnen von Java-Installern Allgemeine Java-Themen 1
Dann07 Problem mit JavaMail API Allgemeine Java-Themen 26
J Problem beim Generischen Klassen und Interfaces Allgemeine Java-Themen 2
L Klassen Algorithmus für das folgende Problem entwickeln? Allgemeine Java-Themen 30
J Clear-Problem Allgemeine Java-Themen 10
B Problem zu einem Java Projekt Allgemeine Java-Themen 6
S JFileChooser Problem Allgemeine Java-Themen 4
M Traveling Salesman - MST Heuristik Problem Allgemeine Java-Themen 4
J Traveling Salesman Problem Allgemeine Java-Themen 14
E Java Editor Problem mit 2er Exceptions Allgemeine Java-Themen 12
C code oder Bibliotheken für 2-Center Problem Allgemeine Java-Themen 4
M Salesman Problem - Bruteforce Algorithmus Allgemeine Java-Themen 23
S Methoden Problem mit NullPointerException Allgemeine Java-Themen 9
Javafan02 Problem mit if-clause Allgemeine Java-Themen 17
J Lombok Problem mit Konstruktoren bei Verberbung Allgemeine Java-Themen 1
kodela Event Handling Problem mit der Alt-Taste Allgemeine Java-Themen 16
W Threads Problem Allgemeine Java-Themen 15
S Problem mit Generic bei unmodifiableCollection Allgemeine Java-Themen 4
S jserialcomm Problem Allgemeine Java-Themen 1
Flynn Thread-Problem... Allgemeine Java-Themen 2
J Generische Interface - Problem Allgemeine Java-Themen 3
G Problem beim GUI Allgemeine Java-Themen 9
L Applet Problem "security: Trusted libraries list file not found" ? Allgemeine Java-Themen 7
A OOP Problem beim Berechnen der größten Fläche eines Ringes Allgemeine Java-Themen 19
T Problem mit externen Datenbankzugriff über SSH Tunnel Allgemeine Java-Themen 4
F Problem beim Einlesen einer Textdatei Allgemeine Java-Themen 12
S Java OpenOffice Problem mit Windows-Benutzerwechsel Allgemeine Java-Themen 19
K Threads RAM Problem Allgemeine Java-Themen 20
P Operatoren Problem mit Zähler in recursiver Schleife Allgemeine Java-Themen 2
C Int Problem Allgemeine Java-Themen 8
C J2V8 NodeJs Java Bride Problem und Frage!?!? Allgemeine Java-Themen 1
J Problem bei Hashmap Key-Abfrage Allgemeine Java-Themen 4

Ähnliche Java Themen

Neue Themen


Oben