-
Path: news-archive.icm.edu.pl!agh.edu.pl!news.agh.edu.pl!news.cyf-kr.edu.pl!news.task
.gda.pl!not-for-mail
From: zażółcony <r...@c...pl>
Newsgroups: pl.comp.programming
Subject: Re: zaawansowane ai
Date: Tue, 17 Apr 2012 16:14:38 +0200
Organization: CI TASK http://www.task.gda.pl/
Lines: 117
Message-ID: <jmjtsa$4pb$1@news.task.gda.pl>
References: <jmhnji$fi6$1@inews.gazeta.pl> <jmi22j$19n$1@inews.gazeta.pl>
<jmj41g$euf$1@inews.gazeta.pl> <jmj8cs$poh$1@inews.gazeta.pl>
<jmjk3l$rd8$1@inews.gazeta.pl> <jmjmm3$5aq$1@inews.gazeta.pl>
<jmjnm0$7ua$1@inews.gazeta.pl> <jmjp8b$c8l$1@inews.gazeta.pl>
<jmjs0a$ke8$1@inews.gazeta.pl>
NNTP-Posting-Host: efp194.internetdsl.tpnet.pl
Mime-Version: 1.0
Content-Type: text/plain; charset=ISO-8859-2; format=flowed
Content-Transfer-Encoding: 8bit
X-Trace: news.task.gda.pl 1334672074 4907 83.14.249.194 (17 Apr 2012 14:14:34 GMT)
X-Complaints-To: a...@n...task.gda.pl
NNTP-Posting-Date: Tue, 17 Apr 2012 14:14:34 +0000 (UTC)
User-Agent: Mozilla/5.0 (Windows NT 6.1; WOW64; rv:11.0) Gecko/20120327
Thunderbird/11.0.1
In-Reply-To: <jmjs0a$ke8$1@inews.gazeta.pl>
Xref: news-archive.icm.edu.pl pl.comp.programming:196813
[ ukryj nagłówki ]W dniu 2012-04-17 15:42, f...@N...gazeta.pl pisze:
> M.M.<m...@N...gazeta.pl> napisał(a):
>
>> <f...@N...gazeta.pl> napisał(a):
>>
>>> M.M.<m...@N...gazeta.pl> napisał(a):
>>>
>>>> <f...@N...gazeta.pl> napisał(a):
>>>>
>>>>>>>>
>>>>>>>> Boty tu, boty tam? ;)
>>>>>>>>
>>>>>>>
>>>>>>> bot botem pogania,
>>>>>>>
>>>>>>> próbuję zrobić podstawowe 'scenariusze' typu 'coward',
>>>>>
>>>>> na przykład taki przykład/problem - maly konkurs:
>>>>>
>>>>> chce oprogramowac walasajaca sie swobodnie pozatym ze tchorzliwa
>>>>> postac, (w moim wydaniu jest to krowa)
>>>>>
>>>>> postac normalnie poruszalaby sie np randem
>>>>>
>>>>> {
>>>>> skierujPostac( kto, (rand()%3) -1, (rand()%3) -1);
>>>>>
>>>>> ( kto to id postaci, a dwa kolejne pola to dx dy - poprawki
>>>>> do pozycji na mapie)
>>>>> ]
>>>>
>>>>
>>>> Za bardzo drga, za malo się porusza. Prosto chyba sie nie da.
>>>> To poniżej ma taką wadę że nagle zmienia kierunek i się odbija
>>>> od krawędzi zamiast płynnie hamować, albo zmieniać tor na
>>>> równoległy do krawędzi.
>>>>
>>>> if( rand() % 16 == 0 ) {
>>>> if( rand() % 2 ) kto.dx = rand()%3-1;
>>>> if( rand() % 2 ) kto.dy = rand()%3-1;
>>>> }
>>>> if( kto.y + kto.dy> max_y || kto.y + kto.dy< min_y )
>>>> kto.dx = -kto.dx;
>>>> if( kto.x + kto.dx> max_x || kto.x + kto.dx< min_x )
>>>> kto.dy = -kto.dy;
>>>> kto.x += kto.dx;
>>>> kto.y += kto.dy;
>>>>
>>>
>>> spox, tyle ze nie o procedure na ruch mi chodzi, ruch moze byc
>>> przypadkowy to zalezy od konwencji - niektore turowki rpg albo
>>> strategie zachaczaja o planszowki - tam ruch pionka rypu rand()%3-1
>>> nie razi
>>>
>>> chodzi mi o oprogramowanie ruchu 'pionka' (np krowy na pastwisku)
>>> tak by walesala sie ale nie zblizala za nadto do np walesajacych sie
>>> tam przeciwnikow ktore moglyby ja kopnac - robie to na swoj sposob ale
>>> jestem ciekaw innych podejsc - przy tym zalezy mi na prostocie kodu
>>> bo sam pomysl mozna podac jednym zdaniem ale tu chodzi o prostote
>>> kodu
>>
>> Nie wiem... zasymulować to może magnesami i tarciem? Wrogowie to
>> magnesy odpychające, zielone pastwiska to magnesy przyciągające. Do
>> tego uwzględnić tarcie (wystarczy statyczne) aby krowa nie rozpędzała
>> się do prędkości ponaddźwiękowych. No i chaos, od czasu do czasu jakiś
>> rand do dx i dy. Albo zamiast rand dać dwa magnesy przyciągające krowę
>> które poruszają się całkowicie przypadkowo. Wtedy będzie wyglądało tak,
>> jakby krowa miała jakiś wyimaginowany cel i zanim magnes zmieni położenie
>> to będzie się gramoliła w miarę w jednym kierunku.
>
>
> niestety widze ze wylozenie o co mi chodzi zajeloby mi
> wiecej nizbym chcial na to przeznaczac,
>
> w zadnym razie nie chodzi mi o algorytm na ruch - to jest
> skwantowane na siatce kwadratowych pol, na niektorych stoja
> drzewa, inne sa puste, jest tez tam krowa, krowa moze
> przejsc sobie w jeden z osmiu kierunkow (lewo-prawo-gora-dol
> i na ukosy), krowa spokojnie moze sie poruszac ruchami
> browna bo nie jest glowna postacia (postac glowna jest
> poruszana przez gracza z klawiatury i moze byc akurat o
> kilometr alej) tylko epizodycznym botem, a cala gra jest
> skwantowana na kwadratowej siatce
>
> chodzi tylko o to by krowa nie zblizala sie w swoim brownowskim
> ruchu do niektorych innych postaci typu np goblin i inne
> (ten system relacji miedzy krowa a innymi tez trzeba jakos
> okreslic oprogramowac, moze byc na intach floatacjh albo enumach
> - i tez jestem ciekaw jak ktos by to zrobil,
>
> chodzi o algorytm (procedure) po jakiej krowa wybieralaby gdzie
> isc a gdzie nie, pierwsza wersja zakladala ze krowa sie rozejrzy
> w promieniu 10 pol, znajdzie najblizsza postac (co niesie ze soba
> trudnosc zwiazana z tym ze rownie odleglych postaci moze byc>1
> -( i co wtedy budowac liste i losowac jedna znich - to na maksa
> klopotliwe )- dlatego wlasnie pytam o kwestie dokladnej implementacji)
> - jesli ta postac budzi krowia nieufnosc skierowac sie w przeciwnym
> kierunku niz ta postac - ale jest to algorytm niezbyt dobry teraz
> klepie troche lepszy ale nie wiem czy i jego nie da siepoprawic
Skoro twoja plansza wygląda jak taka z gier typu
BoulderDash/Rockford/Rocks'n'Diamonds/EmeraldMine
to proponuję algorytm 'zapachu' zrobiony na automatach
komórkowych. Wróg krowy daje zapach o sile np. 10
a wszystkie pola planszy bez zapachu aktualizują
swój zapach do wielkości maksymalnego zapachu
swoich sąsiadów - 1. Uzyskujesz wtedy jakiś gradient
rozsiewany wokół 'pachnących' obiektów i mozesz np.
łatwo zaimplementować, by się on nie roznosił
przez mury, krzaki czy co tam. Zakładasz, że zapach 0
to minimum, czyli w odległości >10 pól od źródła
zanika całkowicie.
Natomiast jak losujesz te brownowe ruchy krowy
w różnych kierunkach to bierzesz pod uwagę zapach
i np. mocno zmniejszasz prawdopodobieństwo
wylosowania pól, które pachną mocniej, niż pozostałe.
Następne wpisy z tego wątku
- 17.04.12 16:19 zażółcony
- 17.04.12 16:38
- 17.04.12 16:39 M.M.
- 17.04.12 16:44
- 17.04.12 16:52 M.M.
- 17.04.12 16:56 M.M.
- 17.04.12 17:00 Jordan Szubert
- 17.04.12 17:01
- 17.04.12 17:06
- 17.04.12 17:09 M.M.
- 17.04.12 17:34 M.M.
- 17.04.12 17:36
- 17.04.12 17:52
- 17.04.12 18:02 M.M.
- 17.04.12 18:11
Najnowsze wątki z tej grupy
- 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!!!
- Brednie w wiki - hasło Dehomag
- Perfidne ataki krakerów z KRLD na skrypciarzy JS i Pajton
- Instytut IDEAS może zacząć działać: "Ma to być unikalny w europejskiej skali ośrodek badań nad sztuczną inteligencją."
- Instytut IDEAS może zacząć działać: "Ma to być unikalny w europejskiej skali ośrodek badań nad sztuczną inteligencją."
Najnowsze wątki
- 2025-08-06 Gdynia => Konsultant wdrożeniowy (systemy controlingowe) <=
- 2025-08-06 Białystok => Inżynier oprogramowania .Net <=
- 2025-08-06 "[...] sejmowe wystąpienie posłanki Klaudii Jachiry, która zakończyła je słowami ,,Sława Ukrainie"."
- 2025-08-05 "Chiny przekraczają w wydobyciu 4 mld ton węgla, Indie i USA ponad 1 mld, a Rosja 500 mln ton [...]"
- 2025-08-05 Panuje się 181 159,42 zł./mies. na posła w 2026r.
- 2025-08-05 "Chiny przekraczają w wydobyciu 4 mld ton węgla, Indie i USA ponad 1 mld, a Rosja 500 mln ton [...]"
- 2025-08-05 Czy cos fi przechodzi przez trafo separujące?
- 2025-08-05 kajaki i promile
- 2025-08-05 Re: Tesla jest bezpieczna, wczoraj spaliła się doszczętnie na Ursynowie i nikomu się nic nie stało
- 2025-08-05 Gdynia => Przedstawiciel handlowy / KAM (branża TSL) <=
- 2025-08-05 Re: Atak na lekarza w Oławie. Policja zatrzymała sprawcę na lotnisku Polska Agencja Prasowa 4 sierpnia 2025, 12:16 FACEBOOK X E-MAIL KOPIUJ LINK W szpitalu w Oławie 37-letni pacjent zaatakował lekarza, po tym, jak ten odmówił mu wypisania długoterminowego
- 2025-08-05 B2B i książka przychodów i rozchodów
- 2025-08-04 Re: Atak na lekarza w Oławie. Policja zatrzymała sprawcę na lotnisku Polska Agencja Prasowa 4 sierpnia 2025, 12:16 FACEBOOK X E-MAIL KOPIUJ LINK W szpitalu w Oławie 37-letni pacjent zaatakował lekarza, po tym, jak ten odmówił mu wypisania długoterminowego
- 2025-08-04 Na grupie comp.os.linux.advocacy CrudeSausage twierdzi, że Micro$lop używa SI do szyfrowania formatu dok. XML
- 2025-08-04 Na grupie comp.os.linux.advocacy CrudeSausage twierdzi, że Micro$lop używa SI do szyfrowania formatu dok. XML