def shrani_pravokotnik(polmeri, st_tock, ponovitve, mapa=None, ime_datoteke=None, shrani_txt=False): '''Funkcija zgenerira tocke v pravokotniku, izracuna dolzine, najde minimalno drevo in vsoto. Poskus ponovi, kolikor dano, rezultate pa spravi v datoteko (ce vrednost dana na True).''' stranici = [ploscine.ploscina(k, "pravokotnik") for k in polmeri] sez_pravokotnik = [] for i in range(len(stranici)): ax = stranici[i][0] by = stranici[i][1] for tocke in st_tock: maksimum = 0 for i in range(ponovitve): a = generator_tock.pravokotnik(ax, by, tocke) b = dolzina.dolzina_med_tockami(a) c = minimalno_vpeto_drevo.prim(a, b)[1] if maksimum > c: pass else: maksimum = c sez_pravokotnik.append(maksimum) if shrani_txt: shrani.shrani(mapa, ime_datoteke, sez_pravokotnik) return sez_pravokotnik
def vsota_6(seznam): '''Funkcija sprejme seznam tock in izracuna razdalje med njimi in najde minimalno vpeto drevo. Krog tudi narisemo.''' dolzine = dolzina.dolzina_med_tockami(seznam) drevo = minimalno_vpeto_drevo.prim(seznam, dolzine) vsota = drevo[1] narisi.narisi_krog(1, seznam, drevo[0], "drevo") return vsota
def shrani_kvadrat(polmeri, st_tock, ponovitve, mapa=None, ime_datoteke=None, shrani_txt=False): '''Funkcija zgenerira tocke v kvadratu, izracuna dolzine, najde minimalno drevo in vsoto. Poskus ponovi, kolikor dano, rezultate pa spravi v datoteko (ce vrednost na True).''' stranice = [ploscine.ploscina(k, "kvadrat") for k in polmeri] sez_kvadrat = [] for stranica in stranice: for tocke in st_tock: maksimum = 0 for i in range(ponovitve): a = generator_tock.kvadrat(stranica, tocke) b = dolzina.dolzina_med_tockami(a) c = minimalno_vpeto_drevo.prim(a, b)[1] if maksimum > c: pass else: maksimum = c sez_kvadrat.append(maksimum) if shrani_txt: shrani.shrani(mapa, ime_datoteke, sez_kvadrat) return sez_kvadrat
def shrani_elipsa(polmeri, st_tock, ponovitve, mapa=None, ime_datoteke=None, shrani_txt=False): '''Funkcija zgenerira tocke v elipsi, izracuna dolzine, najde minimalno drevo in vsoto. Poskus ponovi, kolikor dano, rezultate pa spravi v datoteko (ce vrednost dana na True).''' stranice_ax = [ploscine.ploscina(k, "elipsa")[0] for k in polmeri] stranice_by = [ploscine.ploscina(k, "elipsa")[1] for k in polmeri] sez_elipsa = [] for i in range(len(stranice_ax)): for tocke in st_tock: maksimum = 0 for k in range(ponovitve): a = generator_tock.elipsa(stranice_ax[i], stranice_by[i], tocke) b = dolzina.dolzina_med_tockami(a) c = minimalno_vpeto_drevo.prim(a, b)[1] if maksimum > c: pass else: maksimum = c sez_elipsa.append(maksimum) if shrani_txt: shrani.shrani(mapa, ime_datoteke, sez_elipsa) return sez_elipsa
def cas_glede_st_tock(tocke, polmer=1, shrani_txt=True, mapa=mapa_rezultatov, ime="cas.txt"): '''Funkcija sprejme stevilo tock in vrne ter shrani seznam s casi, potrebnimi za generiranje, izracun dolzine in iskanje minimalnega vpetega drevesa. Graf narisan v R.''' cas = [] for i in tocke: stevilo = 0 for k in range(100): start_time = time.time() a = generator_tock.krog(polmer, i) b = dolzina.dolzina_med_tockami(a) minimalno_vpeto_drevo.prim(a, b)[1] elapsed_time = time.time() - start_time stevilo += elapsed_time cas.append(stevilo / 100) if shrani_txt: shrani.shrani(mapa, ime, cas) return cas
def shrani_krog(polmeri, st_tock, ponovitve, mapa=None, ime_datoteke=None, shrani_txt=False): '''Funkcija zgenerira tocke, izracuna dolzine med njimi in minimalno vpeto drevo in vsoto kvadratov, in to ponavlja ter shrani rezultate v datoteko (ce dano na True).''' sez_krog = [] for polmer in polmeri: for tocke in st_tock: maksimum = 0 for i in range(ponovitve): a = generator_tock.krog(polmer, tocke) b = dolzina.dolzina_med_tockami(a) c = minimalno_vpeto_drevo.prim(a, b)[1] if maksimum < c: maksimum = c sez_krog.append(maksimum) if shrani_txt: shrani.shrani(mapa, ime_datoteke, sez_krog) return sez_krog
def vsote_glede_polmer(mapa_rezultatov, ime_datoteke2, polmeri, st_tock, ponovitve): '''Funkcija za klicanje vseh ostalih funkcij za vse like, ki vrne seznam maksimalne vsote, ter rezultat spravi v tekstovno datoteko.''' # maksimalne vrednosti po točkah za polmere # krog seznam_krog = [] for polmer in polmeri: maksimum1 = 0 for tocke in st_tock: maksimum2 = 0 for i in range(ponovitve): a = generator_tock.krog(polmer, tocke) b = dolzina.dolzina_med_tockami(a) c = minimalno_vpeto_drevo.prim(a, b)[1] if maksimum2 < c: maksimum2 = c if maksimum2 > maksimum1: maksimum1 = maksimum2 seznam_krog.append(maksimum1) shrani.shrani(mapa_rezultatov, ime_datoteke2, seznam_krog) # kvadrat stranice = [ploscine.ploscina(k, "kvadrat") for k in polmeri] seznam_kvadrat = [] for stranica in stranice: maksimum3 = 0 for tocke in st_tock: maksimum4 = 0 for i in range(ponovitve): a = generator_tock.kvadrat(stranica, tocke) b = dolzina.dolzina_med_tockami(a) c = minimalno_vpeto_drevo.prim(a, b)[1] if maksimum4 < c: maksimum4 = c if maksimum4 > maksimum3: maksimum3 = maksimum4 seznam_kvadrat.append(maksimum3) shrani.shrani(mapa_rezultatov, ime_datoteke2, seznam_kvadrat) # pravokotnik stranici = [ploscine.ploscina(k, "pravokotnik") for k in polmeri] seznam_pravokotnik = [] for i in range(len(stranici)): maksimum5 = 0 ax = stranici[i][0] by = stranici[i][1] for tocke in st_tock: maksimum6 = 0 for i in range(ponovitve): a = generator_tock.pravokotnik(ax, by, tocke) b = dolzina.dolzina_med_tockami(a) c = minimalno_vpeto_drevo.prim(a, b)[1] if maksimum6 < c: maksimum6 = c if maksimum6 > maksimum5: maksimum5 = maksimum6 seznam_pravokotnik.append(maksimum5) shrani.shrani(mapa_rezultatov, ime_datoteke2, seznam_pravokotnik) # elipsa stranice_ax = [ploscine.ploscina(k, "elipsa")[0] for k in polmeri] stranice_by = [ploscine.ploscina(k, "elipsa")[1] for k in polmeri] seznam_elipsa = [] for i in range(len(stranice_ax)): maksimum7 = 0 for tocke in st_tock: maksimum8 = 0 for k in range(ponovitve): a = generator_tock.elipsa(stranice_ax[i], stranice_by[i], tocke) b = dolzina.dolzina_med_tockami(a) c = minimalno_vpeto_drevo.prim(a, b)[1] if maksimum8 < c: maksimum8 = c if maksimum8 > maksimum7: maksimum7 = maksimum8 seznam_elipsa.append(maksimum7) shrani.shrani(mapa_rezultatov, ime_datoteke2, seznam_elipsa) # trikotnik stranica_a = [ploscine.ploscina(k, "trikotnik") for k in polmeri] seznam_trikotnik = [] for stranica in stranica_a: maksimum9 = 0 for tocke in st_tock: maksimum10 = 0 for i in range(ponovitve): a = generator_tock.trikotnik(stranica, tocke) b = dolzina.dolzina_med_tockami(a) c = minimalno_vpeto_drevo.prim(a, b)[1] if maksimum10 > c: pass else: maksimum10 = c if maksimum10 > maksimum9: maksimum9 = maksimum10 seznam_trikotnik.append(maksimum9) shrani.shrani(mapa_rezultatov, ime_datoteke2, seznam_trikotnik) return
def vsota_glede_st_tock(mapa_rezultatov, ime_datoteke1, polmer1, st_tock, ponovitve): '''Funkcija, ki izracuna vsote vseh likov s ploscino π za razlicno stevilo danih tock.''' # KROG tocke_krog = [] for polmer in polmer1: for tocke in st_tock: vsota1 = 0 for i in range(ponovitve): a = generator_tock.krog(polmer, tocke) b = dolzina.dolzina_med_tockami(a) vsota2 = minimalno_vpeto_drevo.prim(a, b)[1] if vsota2 > vsota1: vsota1 = vsota2 tocke_krog.append(vsota1) shrani.shrani(mapa_rezultatov, ime_datoteke1, tocke_krog) # KVADRAT stranice = [ploscine.ploscina(k, "kvadrat") for k in polmer1] tocke_kvadrat = [] for stranica in stranice: for tocke in st_tock: vsota3 = 0 for i in range(ponovitve): a = generator_tock.kvadrat(stranica, tocke) b = dolzina.dolzina_med_tockami(a) vsota4 = minimalno_vpeto_drevo.prim(a, b)[1] if vsota4 > vsota3: vsota3 = vsota4 tocke_kvadrat.append(vsota3) shrani.shrani(mapa_rezultatov, ime_datoteke1, tocke_kvadrat) # PRAVOKOTNIK stranici = [ploscine.ploscina(k, "pravokotnik") for k in polmer1] tocke_pravokotnik = [] for i in range(len(stranici)): ax = stranici[i][0] by = stranici[i][1] for tocke in st_tock: vsota5 = 0 for i in range(ponovitve): a = generator_tock.pravokotnik(ax, by, tocke) b = dolzina.dolzina_med_tockami(a) vsota6 = minimalno_vpeto_drevo.prim(a, b)[1] if vsota6 > vsota5: vsota5 = vsota6 tocke_pravokotnik.append(vsota5) shrani.shrani(mapa_rezultatov, ime_datoteke1, tocke_pravokotnik) # ELIPSA stranice_ax = [ploscine.ploscina(k, "elipsa")[0] for k in polmer1] stranice_by = [ploscine.ploscina(k, "elipsa")[1] for k in polmer1] tocke_elipsa = [] for i in range(len(stranice_ax)): for tocke in st_tock: vsota7 = 0 for k in range(ponovitve): a = generator_tock.elipsa(stranice_ax[i], stranice_by[i], tocke) b = dolzina.dolzina_med_tockami(a) vsota8 = minimalno_vpeto_drevo.prim(a, b)[1] if vsota8 > vsota7: vsota7 = vsota8 tocke_elipsa.append(vsota7) shrani.shrani(mapa_rezultatov, ime_datoteke1, tocke_elipsa) # TRIKOTNIK stranica_a = [ploscine.ploscina(k, "trikotnik") for k in polmer1] tocke_trikotnik = [] for stranica in stranica_a: for tocke in st_tock: vsota9 = 0 for i in range(ponovitve): a = generator_tock.trikotnik(stranica, tocke) b = dolzina.dolzina_med_tockami(a) vsota10 = minimalno_vpeto_drevo.prim(a, b)[1] if vsota10 > vsota9: vsota9 = vsota10 tocke_trikotnik.append(vsota9) shrani.shrani(mapa_rezultatov, ime_datoteke1, tocke_trikotnik) return