-
Data: 2012-09-26 14:35:32
Temat: Re: zadanie optymalizacyjne
Od: bartekltg <b...@g...com> szukaj wiadomości tego autora
[ pokaż wszystkie nagłówki ]W dniu 2012-09-26 10:32, M.M. pisze:
> W dniu wtorek, 25 września 2012 22:35:35 UTC+2 użytkownik bartekltg napisał:
>> W dniu 2012-09-25 22:11, bartekltg pisze:
>> Rozwiązujemy następujące zadnienie zmodyfikowane:
>> [programowanie liniowe]
>> x*z1 > = 1
>> x*z2 > = 1
>> x*z3 > = 1
>> x*zn > = 1
>> z minimalizowaną funkcją celu sum(x)
>> (czy jak kto woli x*[1,1,....1] )
>> Za standardowym warunkiem x_i > 0
>
> Tego potrzebowalem zeby zrozumiec :)
:)
> A co do dowodu poprawnosci. Czy nie wystarczy ze:
> 1) jest to poprawnie zefiniowane zadanie z programowania,
> 2) podczas odtworzenia warunku suma x_i = 1 funkcje skaluja
> sie liniowo (bo sa liniowe), a wiec wszystkie inne warunki
> liniowe nadal beda obowiazywaly?
No, musisz jeszcze pokazać, że to nadal najlepsze rozwiązanie.
Tak, to oczywiste;), ale wolałem dopisać dowód (zresztą, dowodząc
tego znalazłem błąd w pierwszej wersji).
Sprawdziłem przerobioną wersję na oo calc. Nie tylko
znalazł rozwiązanie, ale i okazało się, że fminsearch
zaplątał się i był gorszy o parę %.
Wpadłem rano, jak w miarę prosto 'algebraicznie'
rozwiązywać pierwotny problem, ale algorytm
jest dość podobny, w pewnym momencie radośnie sobie
rzutujemy na jądro pewnej macierzy ograniczeń;)
a do simpleksu jeśli nawet nie masz juz biblioteki,
to łatwiej znaleźć gotowca czy materiały.
W każdym razie szłoby to tak (szkic i nieprzetestowane):
Mamy jakąś propozycję dla x.
Uaktualniamy ją. Nawet o gradeint g = pi, gdzie
pi odpowiada najmniejszej funkcji w x. Tylko teraz
wrzucamy ograniczenia. Pierwszym jest
równość g[1] +.. +g[8] = 0 - to gwarantuje
pozostanie na naszej płaszczyźnie.
Jeśli mamy pi*x == pj*x i jest to najmniejsza
wartość ze wzyctkich pk*x, dodajemy równania
pi[1]*g[1] +.. +pi[8]*g[8]==0
pj[1]*g[1] +.. +pj[8]*g[8]==0
Rzutujemy nasz gradient na jądro mcierzy opisującej
te warunki (kod wygląda lepiej niż to brzmi:).
Dzięki temu nie uciekamy z płaszczyzny oraz nie
zmnijeszamy fi kosztem innych równych co do wartości fj.
Dalej, dla każdej współrzędnej x[i]==0
i g (już ten nowy gradient) g[i]<0
dodajemy warunek g[i]==0.
Powiększamy naszą macierz warunków i powtarzamy operację.
Teraz gorsza część.
patrzymy na wetkro x'=x + t*g. t to skalr.
Rozwiązujemy wszystkie kolizje ze ściankami,
oraz potójne równości pi*x' == pj*x' == pk*x'
Wybieramy najmniejsze dodatnie t, podstawiamy
x< x+t*g
goto start:)
Da się. Jest upierdliwe. Nadal polecam przepisać
simplex z wiki;)
pzdr
bartekltg
Następne wpisy z tego wątku
- 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
- 7. Raport Totaliztyczny: Sprawa Qt Group wer. 424
- TCL - problem z escape ostatniego \ w nawiasach {}
- Nauka i Praca Programisty C++ w III Rzeczy (pospolitej)
- testy-wyd-sort - Podsumowanie
- Tworzenie Programów Nieuprzywilejowanych Opartych Na Wtyczkach
- Do czego nadaje się QDockWidget z bibl. Qt?
- Bibl. Qt jest sztucznie ograniczona - jest nieprzydatna do celów komercyjnych
- Co sciaga kretynow
- AEiC 2024 - Ada-Europe conference - Deadlines Approaching
- Jakie są dobre zasady programowania programów opartych na wtyczkach?
- sprawdzanie słów kluczowych dot. zła
- Re: W czym sie teraz pisze programy??
- Re: (PDF) Surgical Pathology of Non-neoplastic Gastrointestinal Diseases by Lizhi Zhang
- CfC 28th Ada-Europe Int. Conf. Reliable Software Technologies
- Młodzi programiści i tajna policja
Najnowsze wątki
- 2024-12-11 SEP 1 kV E
- 2024-12-11 DNS restrictions are on
- 2024-12-11 wielkie bu
- 2024-12-11 Białystok => Inżynier bezpieczeństwa aplikacji <=
- 2024-12-11 Aku LiPo źródło dostaw - ktoś poleci ?
- 2024-12-11 Warszawa => Specjalista Bezpieczeństwa Informacji <=
- 2024-12-11 Wrocław => Application Security Engineer <=
- 2024-12-11 Warszawa => Analyst in the Trade Development department (experience wi
- 2024-12-11 Lublin => Programista Delphi <=
- 2024-12-11 Motodziennik #305 Nowy ELEKTRYK za 350 złotych miesięcznie? Kreatywne kredytowanie problemów
- 2024-12-11 Warszawa => Spedytor Międzynarodowy <=
- 2024-12-11 Katowice => Key Account Manager (ERP) <=
- 2024-12-11 Katowice => Regionalny Kierownik Sprzedaży (OZE) <=
- 2024-12-11 Idzie zima...czyli zaczynamy TETRIS :)
- 2024-12-11 Warszawa => Analityk w dziale Trade Development (doświadczenie z Powe