Zum Inhalt springen
  • 0

[C#] Palettenbeladung


Frage

Geschrieben

Hallo Zusammen,

ich hab von meinem Ausbilder die Aufgabe bekommen, ein Beladungsprogramm zu erstellen, welches Paletten in LKWs stapelt. (Soll natürlich im Programm angezeigt werden wie die Paletten gestapelt werden)

Mein Problem:   Mir ist keine Funktion/Rechenweg eingefallen um die Paletten richtig zu stapeln sodass es am wenigsten Platz verbraucht.

Hoffentlich kann mir hier jemand einen Tipp oder ein Rechenbeispiel zeigen.

 

11 Antworten auf diese Frage

Empfohlene Beiträge

  • 1
Geschrieben (bearbeitet)

Klingt so ein bisschen nach dem Rucksackproblem - eine wirklich optimale Lösung ist da eher schwierig. Für den Normalfall reicht ja aber eine Näherung.

Eine naive Lösung wäre etwas in der folgenden Art:

var lkw = nächsterLkw;

for(Palette p in allePaletten.SortiereNachGroesse())
  if p.Verladen:
	continue
  if PalettePasstInLkw(lkw, p):
    lkw.Paletten.Add(p)
    lkw.Platz -= p.Groesse
    p.Verladen = true      

Gegebenenfalls dann eben eine Schleife außen drum, die die LKW durchgeht.

So bekommst du natürlich keine gleichmäßige Verteilung auf die Fahrzeuge hin, wenn das gewünscht ist. Und es ist auch keine optimale Platznutzung in den einzelnen LKW gewährleistet.

Bearbeitet von arlegermi
  • 0
Geschrieben

Ich weiß nicht ob ich gerade zu einfach denke... ich würde einfach Anhand der Grundfläche die Paletten aufteilen? Die Darstellung würde ich mit einer einfachen Variablen machen die jeweils für den "Stack" an Paletten hochzählt. Auch denkbar wäre ein drei Dimensionales Array mit Position X, Position Y und Höhe (Anzahl).

  • 0
Geschrieben

Hallo NTC_Baumi,

die Idee hatte ich auch, ist natürlich einfach wenn die Paletten alle gleich groß sind. Hab aber vergessen zu erwähnen das das Programm die Paletten mit unterschiedlichen Größen stapeln können soll. ( Bsp: Europalette: L: 1,2 cm B: 0,8cm. Industriepalette: L: 1,0cm B: 1,2cm. Testpalette(Palette mit ausgedachter Länge und Breite): L: 1,3cm B: 1,4cm) Die Höhe ist fürs erste mal egal.

  • 0
Geschrieben
vor 1 Minute schrieb danieljess88:

die Idee hatte ich auch, ist natürlich einfach wenn die Paletten alle gleich groß sind. Hab aber vergessen zu erwähnen das das Programm die Paletten mit unterschiedlichen Größen stapeln können soll. ( Bsp: Europalette: L: 1,2 cm B: 0,8cm. Industriepalette: L: 1,0cm B: 1,2cm. Testpalette(Palette mit ausgedachter Länge und Breite): L: 1,3cm B: 1,4cm) Die Höhe ist fürs erste mal egal.

ich würde die Paletten sortiert abstellen, damit es sich besser auf dem LKW sichern lässt :D (ich fürchte das war nicht hilfreich)

  • 0
Geschrieben
vor 18 Minuten schrieb danieljess88:

Ne ist nicht wirklich Hilfreich gewesen

Zu meiner verteidigung, ich bin kein Entwickler.

Hab noch eine sehr sehr "dreckige" Lösung. Errechne mit einem Zufallsalgo. ein paar tausend Lösungen für deine aktuelle Paletten konfiguration und teste durch, welche am besten ist. Solange die Anzahl deiner Paletten im Rahmen bleibt, und du Eingrenzungen machst (z.B. gleiche Paletten übereinander), sollte das zu einem effektiven Ergebnis führen.

  • 0
Geschrieben
vor 3 Minuten schrieb KeeperOfCoffee:

Ist das alles an Vorgaben? Gibt es da nix zu beachten? Vorschriften? Irgendwas von ner Seite zu scannen? Kommt mir jetzt sehr wenig vor die Problembeschreibung

Natürlich existiert da noch mehr, aber da möchte ich mich dann auch selber noch dransetzten.

Wichtig für mich wäre im Moment nur ein guter Rechenweg/Funktion. Wenn ich die habe kann ich zumindest weitermachen und mich bei weiteren Problemen wieder hier melden.

 

vor 31 Minuten schrieb Minerva/8:

Wie soll das dargestellt werden ? Als 3D Model, 2D mit Top Down View?

Als 3D Model welches man noch drehen kann in jede beliebige Richtung.

  • 0
Geschrieben
vor einer Stunde schrieb danieljess88:

Mein Problem:   Mir ist keine Funktion/Rechenweg eingefallen um die Paletten richtig zu stapeln sodass es am wenigsten Platz verbraucht. 

Es gibt nun mal nicht für alles einen vorgefertigten Lösungsweg. ;)

vor 3 Minuten schrieb danieljess88:

Natürlich existiert da noch mehr, aber da möchte ich mich dann auch selber noch dransetzten.

Die sind aber essentiell für die Lösung. z.B. ist überhaupt nicht klar, ob die Paletten gedreht oder sogar gestapelt werden können oder ob auch die Last im LKW verteilt werden muss, also z.B. ob schwere Paletten unten liegen und dann leichtere Paletten oben drauf?

vor 4 Minuten schrieb danieljess88:

Wichtig für mich wäre im Moment nur ein guter Rechenweg/Funktion. Wenn ich die habe kann ich zumindest weitermachen und mich bei weiteren Problemen wieder hier melden.

Davon war bis jetzt nie die Rede und erfordert mehr als hier bekannt war, denn es muss nicht nur ausgerechnet werden, welche Paletten nun dazu führen, dass die Ladung optimal verteilt werden, sondern es müssen ja noch die Positionen der einzelnen Paletten bestimmt werden, wo sie sich dann im LKW befinden. 

Ich denke auch nicht, dass es hier einen einfachen Rechenweg gibt, sondern hier muss man wohl mit Kombinatorik ran. Sprich, man muss alle Kombinationen durchspielen und überprüfen, was die beste Kombination ist. Ich würde also die Liste der Paletten nehmen und mir die erste Palette schnappen und über ein Interationsverfahren alle Kombinationen mit allen anderen Paletten raussuchen, die die Fläche des LKWs bzw. das Volumen des LKWs, sofern Paletten stapelbar sind, nicht überschreiten, denn das sind die Kandidaten, die in den LKW reinpassen könnten. Nun muss man mit der Liste der Kombinationen rumspielen und schauen, welche der Kombinationen tatsächlich in den LKW passen. Dafür muss dann die Länge, Breite und sofern Stapelbar die Höhe berücksichtigen. Hier steckt der meiste Gehirnschmalz drinnen. Wenn man dann mögliche LKW-Beladungen gefunden hat, wählt man die mit der größten Fläche bzw. mit dem größten Volumen und streicht diese Paletten aus der Gesamtliste und fängt von Vorne an.

  • 0
Geschrieben
vor 19 Minuten schrieb Whiz-zarD:

Es gibt nun mal nicht für alles einen vorgefertigten Lösungsweg. ;)

Die sind aber essentiell für die Lösung. z.B. ist überhaupt nicht klar, ob die Paletten gedreht oder sogar gestapelt werden können oder ob auch die Last im LKW verteilt werden muss, also z.B. ob schwere Paletten unten liegen und dann leichtere Paletten oben drauf?

Davon war bis jetzt nie die Rede und erfordert mehr als hier bekannt war, denn es muss nicht nur ausgerechnet werden, welche Paletten nun dazu führen, dass die Ladung optimal verteilt werden, sondern es müssen ja noch die Positionen der einzelnen Paletten bestimmt werden, wo sie sich dann im LKW befinden. 

Ich denke auch nicht, dass es hier einen einfachen Rechenweg gibt, sondern hier muss man wohl mit Kombinatorik ran. Sprich, man muss alle Kombinationen durchspielen und überprüfen, was die beste Kombination ist. Ich würde also die Liste der Paletten nehmen und mir die erste Palette schnappen und über ein Interationsverfahren alle Kombinationen mit allen anderen Paletten raussuchen, die die Fläche des LKWs bzw. das Volumen des LKWs, sofern Paletten stapelbar sind, nicht überschreiten, denn das sind die Kandidaten, die in den LKW reinpassen könnten. Nun muss man mit der Liste der Kombinationen rumspielen und schauen, welche der Kombinationen tatsächlich in den LKW passen. Dafür muss dann die Länge, Breite und sofern Stapelbar die Höhe berücksichtigen. Hier steckt der meiste Gehirnschmalz drinnen. Wenn man dann mögliche LKW-Beladungen gefunden hat, wählt man die mit der größten Fläche bzw. mit dem größten Volumen und streicht diese Paletten aus der Gesamtliste und fängt von Vorne an.

Danke für deine Antwort. Um fürs erste mal die Fragen geklärt zu haben.

- Die Paletten können nicht aufeinander gestapelt werden.

- Die Gewichtsverteilung ist nicht wichtig, wichtig ist nur durch die Flächen bzw. durch die Länge und Breite angaben, die Paletten passend zu sortieren.

- Die Paletten kann man drehen wie man will, halt so drehen damit es Platzsparend ist

 

Die Möglichkeit mit den Kombinationen habe ich schon mal Probiert. (da habe ich mir auch schon ein paar ausgedacht, die auch schon Funktionieren. Ich schaffe aber mit meinen Kombinationen Max. 3 verschiedene Paletten zu beladen).

Ich kann euch ja mal ein Beispiel geben, welches mit dem Programm platzsparend beladen werden soll.

LKW-Ladefläche: 13,6 x 2,4m

Europalette: 1,2 x 0,8m   Anzahl an Paletten: 2

Industriepalette: 1,0 x 1,2m   Anzahl an Paletten: 9

Testpalette: 1,3 x 1,4m     Anzahl an Paletten: 10

Dein Kommentar

Du kannst jetzt schreiben und Dich später registrieren. Wenn Du ein Konto hast, melde Dich jetzt an, um unter Deinem Benutzernamen zu schreiben.

Gast
Diese Frage beantworten...

×   Du hast formatierten Text eingefügt.   Formatierung wiederherstellen

  Nur 75 Emojis sind erlaubt.

×   Dein Link wurde automatisch eingebettet.   Einbetten rückgängig machen und als Link darstellen

×   Dein vorheriger Inhalt wurde wiederhergestellt.   Editor leeren

×   Du kannst Bilder nicht direkt einfügen. Lade Bilder hoch oder lade sie von einer URL.

Fachinformatiker.de, 2024 by SE Internet Services

fidelogo_small.png

Schicke uns eine Nachricht!

Fachinformatiker.de ist die größte IT-Community
rund um Ausbildung, Job, Weiterbildung für IT-Fachkräfte.

Fachinformatiker.de App

Download on the App Store
Get it on Google Play

Kontakt

Hier werben?
Oder sende eine E-Mail an

Social media u. feeds

Jobboard für Fachinformatiker und IT-Fachkräfte

×
×
  • Neu erstellen...