Das deutsche QBasic- und FreeBASIC-Forum Foren-Übersicht Das deutsche QBasic- und FreeBASIC-Forum
Für euch erreichbar unter qb-forum.de, fb-forum.de und freebasic-forum.de!
 
FAQFAQ   SuchenSuchen   MitgliederlisteMitgliederliste   BenutzergruppenBenutzergruppen  RegistrierenRegistrieren
ProfilProfil   Einloggen, um private Nachrichten zu lesenEinloggen, um private Nachrichten zu lesen   LoginLogin
Zur Begleitseite des Forums / Chat / Impressum
Aktueller Forenpartner:

geschwindigkeitsprobleme bei verschlüsselungsprog

 
Neues Thema eröffnen   Neue Antwort erstellen    Das deutsche QBasic- und FreeBASIC-Forum Foren-Übersicht -> Allgemeine Fragen zu FreeBASIC.
Vorheriges Thema anzeigen :: Nächstes Thema anzeigen  
Autor Nachricht
Feenfleisch



Anmeldungsdatum: 11.08.2005
Beiträge: 15

BeitragVerfasst am: 09.04.2008, 22:17    Titel: geschwindigkeitsprobleme bei verschlüsselungsprog Antworten mit Zitat

hallo,

ich arbeite gerade an einen verschlüsselungprog, das auf permutation bassiert. das klappt eigentlich ziemlich gut, jedoch, happert es gewaltig bei der geschwindigkeit wenn es um größere datei geht. zuerst vielleicht den ganzen code damit ihr überhaupt wisst was ich möchte und darunter mein problemkind:

Code:
dim as string  dateiname, passwort, passwort_dummy, inhalt, inhalt_dummy
dim as integer x, y, schluessel(), zufallszahl, ende

hauptprogramm:

do
   
    cls

    locate 2,2
    ? "feenfleisch 0.1"
    locate 5,2
    ? "(1) verschluesseln"
    locate 6,2
    ? "(2) entschluesseln"
    locate 7,2
    ? "(3) ende"

    locate 9,3
    input "", x

    if x = 1 then goto verschluesseln
    if x = 2 then goto entschluesseln
    if x = 3 then end

loop

verschluesseln:

locate 11, 2
input "dateiname: ", dateiname
locate 13,2
input "passwort : ", passwort

for x = 1 to len(passwort)
   
    passwort_dummy = passwort_dummy + str(asc(passwort, x))

next x

open dateiname for binary as #1
inhalt = space(lof(1))
get #1, 1, inhalt

redim schluessel(len(inhalt)) as integer

zufallszahl = rnd - 1
randomize val(passwort_dummy)

for x = 0 to len(inhalt) - 1
   
    locate 16, 2
    print "schluessel wird erstellt  ->"; int (100 / len(inhalt) * (x + 1)) ; " %"
   
    do

        zufallszahl = rnd *len(inhalt)
       
        ende = 1
       
        for y = 0 to x
            if schluessel(y) = zufallszahl then
                ende = 0
                exit for
            end if
        next y
       
    loop until ende = 1

    schluessel(x) = zufallszahl

next x

inhalt_dummy = space(len(inhalt))

for x = 0 to len(inhalt) -1
   
    locate 18, 2
    print "datei wird verschluesselt ->"; int (100 / len(inhalt) * (x + 1)) ; " %"
   
    mid(inhalt_dummy, schluessel(x), 1) = mid(inhalt, x + 1, 1)

next x

put #1, 1, inhalt_dummy
close #1

locate 21, 2
print "verschluesselung abgeschlossen"
sleep

goto hauptprogramm

entschluesseln:

locate 11, 2
input "dateiname: ", dateiname
locate 13,2
input "passwort : ", passwort

for x = 1 to len(passwort)
   
    passwort_dummy = passwort_dummy + str(asc(passwort, x))

next x

open dateiname for binary as #1
inhalt = space(lof(1))
get #1, 1, inhalt

redim schluessel(len(inhalt)) as integer

zufallszahl = rnd - 1
randomize val(passwort_dummy)

for x = 0 to len(inhalt) - 1
   
    locate 16, 2
    print "schluessel wird erstellt  ->"; int (100 / len(inhalt) * (x + 1)) ; " %"
   
    do

        zufallszahl = rnd *len(inhalt)
       
        ende = 1
       
        for y = 0 to x
            if schluessel(y) = zufallszahl then
                ende = 0
                exit for
            end if
        next y
       
    loop until ende = 1

    schluessel(x) = zufallszahl

next x

inhalt_dummy = space(len(inhalt))

for x = 0 to len(inhalt) -1
   
    locate 18, 2
    print "datei wird verschluesselt ->"; int (100 / len(inhalt) * (x + 1)) ; " %"
   
    mid(inhalt_dummy, x + 1, 1) = mid(inhalt, schluessel(x), 1)

next x

put #1, 1, inhalt_dummy
close #1

locate 21, 2
print "entschluesselung abgeschlossen"
sleep

goto hauptprogramm


mein problemkind:
Code:
for x = 0 to len(inhalt) - 1
   
    locate 16, 2
    print "schluessel wird erstellt  ->"; int (100 / len(inhalt) * (x + 1)) ; " %"
   
    do

        zufallszahl = rnd *len(inhalt)
       
        ende = 1
       
        for y = 0 to x
            if schluessel(y) = zufallszahl then
                ende = 0
                exit for
            end if
        next y
       
    loop until ende = 1

    schluessel(x) = zufallszahl

next


an dieser stelle wird mein schlüssel befüllt. jede zahl soll nur einmal vergeben werden, da sie die neue stelle angibt, wohin das zeichen verschoben werden soll. die zweite schleife durchsucht den besherigen schlüssel ob die zahl schon vorhanden ist, wenn ja wird eine neue zahl generiert. das geht so lange bis das programm mit dem inhalt der datei durch ist. das funbktioniert alles gut, jedoch dauert es viel zu lange inbesondere bei größeren dateien. hat jemand eine idee wie man es vielleicht eleganter lösen könnte? ich danke im voraus.

grüße,

feenfleisch

Editiert durch Moderator: Code-Tags hinzugefügt. (Sebastian)
Nach oben
Benutzer-Profile anzeigen Private Nachricht senden
dreael
Administrator


Anmeldungsdatum: 10.09.2004
Beiträge: 2529
Wohnort: Hofen SH (Schweiz)

BeitragVerfasst am: 10.04.2008, 08:57    Titel: Antworten mit Zitat

Kurz Deine Idee mit der Verschlüsselung analysiert: Zeitlicher Aufwand für eine n Bytes lange Datei: O(n^2) RAM-Komplexität: O(n). Einfach ausgedrückt: Bei Deinem Algorithmus nimmt der zeitliche Aufwand bei wachsender Dateigrösse quadratisch zu, der RAM-Bedarf immerhin linear.

Der zeitliche Aufwand lässt sich problemlos auf O(n), d.h. linear reduzieren, in dem Du für Deine Tauschtabelle einen Mischalgorithmus wie in meinem Kartenaufdeckspiel verwendest.

Gleichzeitig würde ich meinen, sollte es auch möglich sein, den Aufwand an RAM ebenfgalls zu reduzieren, in dem wir im Prinzip die SWAP-Operation direkt auf Deinen String bzw. sogar Direktzugriffsdatei anwenden würden (Denke immer ans Beispiel, eine ISO-Datei für eine DVD auf diese Weise zu chiffrieren!) wobei letzteres die Herausforderung besitzt, Diskzugriffe zu minimieren. Für letzteres Problem sehe ich sonst bereits einen Weg: Statt direkt einzelne Bytes vertauschen dieselbe Operation auf ganze Blöcke (Chunks) anwenden und innerhalb eines Chunks ein zusätzlicher "Durchmischer" im RAM durchführen.

Evtl. schreibe ich Dir am Wochenende noch einen Beispielcode zum Ganzen.
_________________
Teste die PC-Sicherheit mit www.sec-check.net
Nach oben
Benutzer-Profile anzeigen Private Nachricht senden E-Mail senden Website dieses Benutzers besuchen
Feenfleisch



Anmeldungsdatum: 11.08.2005
Beiträge: 15

BeitragVerfasst am: 12.04.2008, 13:05    Titel: Antworten mit Zitat

danke für deine antwort. ich werde mir mal deinen misch-code anschauen. das mit den blöcken hatte ich mir auch schon überlegt. die frage die sich mir aber stellt: welche blockgroße wäre denn vernüftig, man müßte sie ja am besten der jeweiligen dateigröße anpassen?
Nach oben
Benutzer-Profile anzeigen Private Nachricht senden
Beiträge der letzten Zeit anzeigen:   
Neues Thema eröffnen   Neue Antwort erstellen    Das deutsche QBasic- und FreeBASIC-Forum Foren-Übersicht -> Allgemeine Fragen zu FreeBASIC. Alle Zeiten sind GMT + 1 Stunde
Seite 1 von 1

 
Gehe zu:  
Du kannst keine Beiträge in dieses Forum schreiben.
Du kannst auf Beiträge in diesem Forum nicht antworten.
Du kannst deine Beiträge in diesem Forum nicht bearbeiten.
Du kannst deine Beiträge in diesem Forum nicht löschen.
Du kannst an Umfragen in diesem Forum nicht mitmachen.

 Impressum :: Datenschutz