-
Data: 2012-09-26 12:53:21
Temat: Re: zadanie optymalizacyjne
Od: Piotr Chamera <p...@p...onet.pl> szukaj wiadomości tego autora
[ pokaż wszystkie nagłówki ]W dniu 2012-09-25 14:15, M.M. pisze:
> W dniu wtorek, 25 września 2012 13:30:44 UTC+2 użytkownik bartekltg napisał:
>> Ten zapis jest bez sensu.
>> Rozumiem, że chodzi o max_{zi} (min(f1,f2,f3))
>
> Trzeba zmaksymalizowac funkcje ff zmieniajac wartosci x.
> http://pastebin.com/papzUzaL
> Wartosci w p[j] sa losowe z przedzialu od 1 do P. Wartosci w z[i][j]
> sa rowne albo zero, albo jeden, albo p[j]. Suma wartosci x[i]
> msui byc rowna 1, ponadto kazdy x[i] >= 0.
>
Po przeczytaniu, co napisali przedpiścy, spróbowałem napisać
proste rozwiązanie iteracyjne (w Common Lispie).
W założeniu zaczynam z wektorem x na wierzchołku hiperkostki
jednostkowej i poruszam się w jej wnętrzu po płaszczyźnie
wyznaczonej przez jej narożniki ruchami w kierunku tego wierzchołka
kostki, który daje aktualnie największy gradient funkcji celu.
Kiedy nie ma już możliwości ruchu zmniejszam krok o połowę
(a la szukanie binarne). To chyba powinno działać? - możecie
zweryfikować czy się gdzieś nie machnąłem?
Znaczące są funkcje ,,move" i ,,maxff" reszta jest analogiczna jak
w zadaniu w C++.
Szybkościowo mieści się w założonym 0,03 s nawet w nieoptymalizowanym
lispie chociaż robi dużo nadmiarowych obliczeń :) - pytanie tylko czy
jest poprawne?
(defconstant +N+ 3)
(defconstant +M+ 8)
;;;; pomocnicze działania na wektorach
(defun add (va vb) ; suma
(let ((vr (make-array +M+ :element-type 'float)))
(dotimes (i +M+)
(setf (aref vr i) (+ (aref va i) (aref vb i))))
vr))
(defun sub (va vb) ; różnica
(let ((vr (make-array +M+ :element-type 'float)))
(dotimes (i +M+)
(setf (aref vr i) (- (aref va i) (aref vb i))))
vr))
(defun smul (va s) ; mnożenie ze skalarem
(let ((vr (make-array +M+ :element-type 'float)))
(dotimes (i +M+)
(setf (aref vr i) (* (aref va i) s)))
vr))
(defun check-in-1-box (vx) ; sprawdzenie czy wektor mieści się kostce
(every (lambda (x) (and (<= x 1.0)
(>= x 0)))
vx))
;;;; inicjalizacje parametrów zadania
(defun frand ()
(random 1.0))
(defun initP ()
"Utwóż wektor losowych p takich, że p >=1 i p <= 5"
(let ((p (make-array +M+ :element-type 'float)))
(dotimes (i +M+)
(setf (aref p i) (+ 1.0 (* (frand) 5.0))))
p))
(defun initZ (vp)
"Utwóż losową tablicę współczynników dla funkcji f na podstawie vp"
(let ((mz (make-array +N+)))
(dotimes (i +N+)
(let ((mzi (make-array +M+ :element-type 'float)))
(dotimes (j +M+)
(setf (aref mzi j) (ecase (random 3)
(0 0)
(1 1)
(2 (aref vp j)))))
(setf (aref mz i) mzi)))
mz))
(defun initX (&optional (vx nil))
"Utwórz wektor losowych x takich, że x >= 0 i sum(x) = 1"
(when (null vx)
(setf vx (make-array +M+ :element-type 'float)))
(dotimes (i +M+)
(setf (aref vx i) (random 1.0)))
(let ((sum (reduce #'+ vx)))
(dotimes (i +M+)
(setf (aref vx i) (/ (aref vx i) sum))))
vx)
(defun initDir ()
"Utwórz zbiór narożników hiperkostki"
(let ((dir (make-array +M+)))
(dotimes (i +M+)
(let ((vdir (make-array +M+ :element-type 'float :initial-element
0.0)))
(setf (aref vdir i) 1.0)
(setf (aref dir i) vdir)))
dir))
(defun asert (vx)
"Sprawdz czy vx spełnia warunki x >= 0 i sum(x) = 1"
(when (some (lambda (x) (< x 0))
vx)
(error "x mniejsze od zera"))
(when (> (abs (- 1.0 (reduce #'+ vx)))
0.00001)
(error "błąd sumy x większy od 0.00001"))
t)
;;;; zadanie
(defun f (z x &aux (sum 0.0))
(dotimes (i +M+)
(setf sum (+ sum
(* (aref z i) (aref x i)))))
sum)
(defun ff (mz x)
(asert x)
(let ((min nil))
(dotimes (i +N+)
(let ((tmp (f (aref mz i) x)))
(when (or (null min)
(> min tmp))
(setf min tmp))))
min))
;;;; rozwiązanie
(defun move (mz vx step dir)
(let ((max (ff mz vx))
(max-vx vx))
(dolist (s (list step (- step))) ; sprawdz ruchy w obu kierunkach
(dotimes (i +M+) ; po wszystkich osiach układu
współrzędnych
(let ((v (add vx (smul (sub (aref dir i) vx) s)))) ; idziemy po linii
vx - dir o współczynnik s
(when (check-in-1-box v)
(let ((p-max (ff mz v)))
(when (> p-max max) ; zapisz najlepszy znaleziony ruch
(setf max p-max
max-vx v)))))))
(values max-vx max)))
(defun maxff (mz)
(let* ((vx (let ((v (make-array +M+ :element-type 'float
:initial-element 0.0)))
(setf (aref v 0) 1.0)
v)) ; początkowy x i aktualizowny na bieżąco najlepszy
(max 0.0) ; początkowe maksimum i aktualizowne na bieżąco najlepsze
(dir (initDir)) ; tablica wierzchołków kostki (wektory typu [1 0 0 ... 0])
(step 0.5) ; aktualny krok modyfikacji
(epsilon 0.00001)) ; żądana dokładność maksimum
(do () ((< step epsilon) ())
(multiple-value-bind (p-vx p-max) (move mz vx step dir)
(if (> (- p-max max) epsilon)
(setf max p-max
vx p-vx)
(setf step (/ step 2.0)))))
(values vx max)))
; // TODO: zmaksymalizować funkcję ff( z , x ) zmiejąc x (nie zmieniając z)
Można tego użyć np tak: (maxff (initZ (initP)))
Następne wpisy z tego wątku
- 26.09.12 14:35 bartekltg
- 26.09.12 14:42 M.M.
- 26.09.12 14:48 Edek Pienkowski
- 26.09.12 14:55 Edek Pienkowski
- 26.09.12 15:15 bartekltg
- 26.09.12 15:18 bartekltg
- 26.09.12 16:21 bartekltg
- 26.09.12 17:18 Piotr Chamera
- 26.09.12 17:51 bartekltg
- 26.09.12 20:15 Miroslaw Kwasniak
- 27.09.12 06:32 M.M.
- 28.09.12 13:34 M.M.
- 28.09.12 14:13 M.M.
- 28.09.12 16:00 bartekltg
Najnowsze wątki z tej grupy
- Rosjanie chwalą się prototypem komputera kwantowego. "Najważniejszy projekt naukowy Rosji"
- A Szwajcarzy kombinują tak: FinalSpark grows human neurons from stem cells and connects them to electrode arrays
- Re: Najgorszy język programowania
- NOWY: 2025-09-29 Alg., Strukt. Danych i Tech. Prog. - komentarz.pdf
- Na grupie comp.os.linux.advocacy CrudeSausage twierdzi, że Micro$lop używa SI do szyfrowania formatu dok. XML
- Błąd w Sofcie Powodem Wymiany 3 Duńskich Fregat Typu Iver Huitfeldt
- Grok zaczął nadużywać wulgaryzmów i wprost obrażać niektóre znane osoby
- Can you activate BMW 48V 10Ah Li-Ion battery, connecting to CAN-USB laptop interface ?
- We Wrocławiu ruszyła Odra 5, pierwszy w Polsce komputer kwantowy z nadprzewodzącymi kubitami
- Ada-Europe - AEiC 2025 early registration deadline imminent
- John Carmack twierdzi, że gdyby gry były optymalizowane, to wystarczyły by stare kompy
- Ada-Europe Int.Conf. Reliable Software Technologies, AEiC 2025
- Linuks od wer. 6.15 przestanie wspierać procesory 486 i będzie wymagać min. Pentium
- ,,Polski przemysł jest w stanie agonalnym" - podkreślił dobitnie, wskazując na brak zamówień.
- Rewolucja w debugowaniu!!! SI analizuje zrzuty pamięci systemu M$ Windows!!!
Najnowsze wątki
- 2026-01-01 Najbogatsi ludzie na świecie są jeszcze bogatsi. Bezprecedensowa skala zysków
- 2026-01-01 Najbogatsi ludzie na świecie są jeszcze bogatsi. Bezprecedensowa skala zysków
- 2026-01-01 Wszystkiego najlepszego
- 2025-12-31 Czy potrafisz wskazać różnice? [TVN v. RMF]
- 2025-12-31 I kolejny jebnięty
- 2025-12-31 Myślenice => Specjalista ds. kontrolingu <=
- 2025-12-31 Ostróda szlachetnie walczy
- 2025-12-31 Pierwsza mapa kosmosu w 102 długościach fal podczerwieni! To początek nowej ery w astronomii
- 2025-12-31 Rosjanie chwalą się prototypem komputera kwantowego. "Najważniejszy projekt naukowy Rosji"
- 2025-12-31 Rosjanie chwalą się prototypem komputera kwantowego. "Najważniejszy projekt naukowy Rosji"
- 2025-12-31 Pieniadze-cuchna-oddechem-nawalonego-tatusia
- 2025-12-31 Iran na skraju gospodarczego upadku. Na ulicach Teheranu (znów) wrze. To może być cios dla reżimu
- 2025-12-30 zasilacz
- 2025-12-30 Teraz System Plików PFS z sys. op. Amiga OS będziesz mógł zamontować pod sys. op. Linuks i Jabłoko Makintosz
- 2025-12-30 Aeor2 i ciągły internet 512kb




5 Najlepszych Programów do Księgowości w Chmurze - Ranking i Porównanie [2025]