-
Path: news-archive.icm.edu.pl!news.icm.edu.pl!plix.pl!newsfeed1.plix.pl!goblin2!gobli
n.stu.neva.ru!xlned.com!feeder7.xlned.com!transit4.hitnews.eu!feeder1.cambriumu
senet.nl!feed.tweaknews.nl!postnews.google.com!d8g2000yqf.googlegroups.com!not-
for-mail
From: Mariusz Marszałkowski <m...@g...com>
Newsgroups: pl.comp.programming
Subject: Re: Algorytm do rozstrzygania problemu stopu dowolnej MT
Date: Fri, 20 Aug 2010 12:50:46 -0700 (PDT)
Organization: http://groups.google.com
Lines: 101
Message-ID: <6...@d...googlegroups.com>
References: <7...@y...googlegroups.com>
<b...@t...googlegroups.com>
NNTP-Posting-Host: 89.229.34.123
Mime-Version: 1.0
Content-Type: text/plain; charset=ISO-8859-2
Content-Transfer-Encoding: quoted-printable
X-Trace: posting.google.com 1282333847 11577 127.0.0.1 (20 Aug 2010 19:50:47 GMT)
X-Complaints-To: g...@g...com
NNTP-Posting-Date: Fri, 20 Aug 2010 19:50:47 +0000 (UTC)
Complaints-To: g...@g...com
Injection-Info: d8g2000yqf.googlegroups.com; posting-host=89.229.34.123;
posting-account=xjvq9QoAAAATMPC2X3btlHd_LkaJo_rj
User-Agent: G2/1.0
X-HTTP-UserAgent: Mozilla/5.0 (Windows; U; Windows NT 5.1; pl; rv:1.9.2.8)
Gecko/20100722 Firefox/3.6.8,gzip(gfe)
Xref: news-archive.icm.edu.pl pl.comp.programming:186623
[ ukryj nagłówki ]On 20 Sie, 08:43, "Marcin 'Qrczak' Kowalczyk" <q...@k...org.pl>
wrote:
> Automat skończony ma nie tylko stan, ale i konsumuje wejście. Jeśli
> nawet stan się powtórzył, to nie wynika z tego, że automat się
> zapętlił, bo na wejściu może być dalej coś innego.
Z konsumpcją stałego wejścia też można, z konsumpcją
dowolnego... hmmm nie wyobrażam sobie jakby to mogło
wyglądać.
>
> > Algorytm rozstrzygający problem stopu po każdym wykonaniu
> > instrukcji zapamiętuje w tablicy szóstkę:
> > (P_o,P_n,S_o,S_n,V_o,_V_n)
> > P_o - pozycja głowicy (względem poz. startowej) przed wykonaniem
> > instrukcji
> > P_n - pozycja głowicy po wykonaniu instrukcji
> > S_o - stan maszyny przed wykonaniem instrukcji
> > S_n - stan maszyny po wykonaniu instrukcji
>
> Czy przez stan maszyny rozumiesz również zawartość taśmy?
Myślę że nie trzeba zawartości całej taśmy. Wystarczą dwie
wartość z taśmy: z komórki na której jest głowica przed i
po wykonaniu instrukcji.
> Czyli zakładam, że przez stan maszyny rozumiesz również zawartość
Nie, chodzi po prostu o dwie wartości: stan maszyny przed i po
wykonaniu
instrukcji. Całej taśmy nie trzeba. Wystarczy szóstka którą
przytoczyłem.
Jeśli pojawią się obok siebie dwie identyczne permutacje szóstek
oznacza
to że maszyna się zapętliła.
> > 2) Zakres komórek odwiedzanych przez głowicę poszerzył się
> > w lewo lub w prawo (tzn głowica ustawiła się na komórce pierwszy
> > raz), a istnieje zapamiętany identyczny ciąg względnych zmian przed
> > poprzednim poszerzeniem.
>
> Nie rozumiem tego sformułowania. Czy do stanu wciąż włączasz zawartość
> taśmy? Co to znaczy "identyczny ciąg względnych zmian"?
Może na przykładzie.
Głowica przed instrukcją numer X poruszała się w zakresie komórek
<start,end>. W wyniku wykonania instrukcji numer X+1 głowica
wychodzi za dotychczasowy zakres i przesuwa się na komórkę nr end+1.
Zapamiętujemy ten fakt przesunięcia się na end+1. Następnie głowica
wykonuje kolejne instrukcje od <X+2,Y> i pracuje np. w zakresie
<end-10,end+1>,
po czym w instrukcji Y+1 znów rozszerza zakres odwiedzonych komórek end
+2.
Decyzja o tym na jaką komórkę głowica ma się przesunąć jest zawsze
względna komórki bieżącej: o jeden w lewo lub o jeden w prawo,
ewentualnie
w tym samym miejscu. Głowica odwiedziła komórki z przykładowego
zakresu
<end-10,end+1>, więc decyzja wpływająca na kolejne rozszerzenie na end
+2
zależy tylko od tego co się działo na komórkach <end-10,end+1>, czyli
na
11-tu komórkach obok tej o którą się rozszerzyła. Te 11 komórek to
komórki
względne. Ilość możliwych szóstek w instrukcjach wykonanych na
komórkach
względnych jest skończona i w trakcie rozszerzania się maszyny na
coraz
większy zakres musi dojść do ich powtórzenia. Jeśli dojdzie do
powtórzenia
to znaczy że maszyna wpisując okresowe dane w kolejne komórki będzie
w
nieskończoność rozszerzała swój zakres, czyli nigdy się nie zatrzyma.
Przyznam że nie jestem pewien na 100% czy to jest poprawne
rozumowanie.
> Co to znaczy "trywialnie rozszerzać"? Po czym rozpoznasz, że
> rozszerzanie zaczęło być trywialne?
No właśnie po tym, że wpływ na rozszerzenie mogą mieć tylko szóstki
zapamiętane w komórkach które zostały odwiedzone pomiędzy kolejnymi
rozszerzeniami. Szóstek jest skończona ilość, więc cykl szóstek
pomiędzy
rozszerzeniami w końcu się powtórzy. Przy czym liczymy względne adresy
komórek, względem komórki o którą się rozszerzył zakres odwiedzonych
komórek.
Pozdrawiam
Następne wpisy z tego wątku
- 21.08.10 07:52 Marcin 'Qrczak' Kowalczyk
- 21.08.10 09:53 Segmentation Fault
- 21.08.10 11:10 bartekltg
- 21.08.10 14:40 Mariusz Marszałkowski
Najnowsze wątki z tej grupy
- 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
- Ada 2022 Language Reference Manual to be Published by Springer
- Press Release - AEiC 2023, Ada-Europe Reliable Softw. Technol.
- Ada-Europe - AEiC 2023 early registration deadline approaching
- Ada-Europe Int.Conf. Reliable Software Technologies, AEiC 2023
- Ile cykli zajmuje mnożenie liczb 64-bitowych?
Najnowsze wątki
- 2024-07-02 Realme 7 Na co zmienić?
- 2024-06-27 Prywatny parking? Pierwsze 10 minut bezplatnie
- 2024-07-02 znalazłem samochód ;)
- 2024-07-02 Pierwszeństwo łamane
- 2024-07-02 zamek
- 2024-07-02 Akumulatory VRLA
- 2024-07-03 Białystok => Inżynier DevOps Conexa First (Kontraktor) <=
- 2024-07-03 MĂźnchen => Test Development Engineer (m/w/d) <=
- 2024-07-03 Warszawa => Full Stack web developer (obszar .Net Core, Angular6+) <=
- 2024-07-03 Warszawa => Programista Full Stack (.Net Core) <=
- 2024-07-02 Kraków => Spedytor międzynarodowy <=
- 2024-07-02 Poznań => Senior React Native Developer <=
- 2024-07-02 Rzeszów => Frontend Developer (React) <=
- 2024-07-02 Warszawa => Fullastack (Java) Developer <=
- 2024-07-02 reparacje