-
X-Received: by 2002:a37:a152:: with SMTP id k79mr79196159qke.411.1564592618568; Wed,
31 Jul 2019 10:03:38 -0700 (PDT)
X-Received: by 2002:a37:a152:: with SMTP id k79mr79196159qke.411.1564592618568; Wed,
31 Jul 2019 10:03:38 -0700 (PDT)
Path: news-archive.icm.edu.pl!news.icm.edu.pl!newsfeed.pionier.net.pl!3.eu.feeder.erj
e.net!feeder.erje.net!newsreader4.netcologne.de!news.netcologne.de!peer03.ams1!
peer.ams1.xlned.com!news.xlned.com!peer03.am4!peer.am4.highwinds-media.com!peer
01.iad!feed-me.highwinds-media.com!news.highwinds-media.com!b26no10325078qtq.0!
news-out.google.com!a5ni679qtd.0!nntp.google.com!b26no10325069qtq.0!postnews.go
ogle.com!glegroupsg2000goo.googlegroups.com!not-for-mail
Newsgroups: pl.comp.programming
Date: Wed, 31 Jul 2019 10:03:38 -0700 (PDT)
In-Reply-To: <1...@g...com>
Complaints-To: g...@g...com
Injection-Info: glegroupsg2000goo.googlegroups.com; posting-host=83.25.198.189;
posting-account=f7iIKQoAAAAkDKpUafc-4IXhmRAzdB5r
NNTP-Posting-Host: 83.25.198.189
References: <e...@g...com>
<1...@g...com>
User-Agent: G2/1.0
MIME-Version: 1.0
Message-ID: <c...@g...com>
Subject: Re: "Najbardziej imponujący kod, jaki widziałem"
From: g...@g...com
Injection-Date: Wed, 31 Jul 2019 17:03:38 +0000
Content-Type: text/plain; charset="UTF-8"
Content-Transfer-Encoding: quoted-printable
X-Received-Bytes: 11642
X-Received-Body-CRC: 2743467901
Xref: news-archive.icm.edu.pl pl.comp.programming:213731
[ ukryj nagłówki ]W dniu środa, 31 lipca 2019 14:59:28 UTC+2 użytkownik Maciej Sobczak napisał:
> > https://www.quora.com/Can-you-explain-to-non-coders-
the-most-impressive-code-youve-seen/answer/Panicz-Go
dek
> >
> > W ogólności pytanie "jaki jest najbardziej imponujący kod, jaki widziałeś" wydaje
mi się ciekawe, więc jeśli ktoś tu ma jakieś swoje obserwacje na ten temat, z chęcią
bym się dowiedział.
>
> Przeczytałem. Najpierw formalności - nie spodobały mi się dwie uwagi już na samym
początku tekstu:
>
> "Don't be surprised if understanding this answer would take you many days, weeks or
even months."
>
> Nikt nie będzie zaskoczony, bo jeśli ktoś miałby tego nie zrozumieć, to by po
prostu nie doczytał.
Podejrzewam, że większość osób może być zaskoczona, ponieważ taki format odpowiedzi
raczej rzadko zdarza się na Quorze.
> Czytanie długich tekstów jest niemodne, zwłaszcza takich, których się nie rozumie
od razu. Trochę też wygląda to na założenie, że czytelnik nie kuma bazy - otóż samo
pytanie do tego artykułu było skierowane do programistów (nie można być pod wrażeniem
jakiegokolwiek kodu, nie rozumiejąc go), więc zakładanie, że ktoś będzie potrzebował
miesięcy, żeby zrozumieć Twój wywód, jest aroganckie.
Aroganckie? Mnie napisanie tego tekstu zajęło kilka miesięcy, a zrozumienie
podstawowych rzeczy - co najmniej kilka lat. Daniel Friedman stwierdził kiedyś, że
zrozumienie opisanego przeze mnie silnika wnioskującego - kilkunastu linijek kodu -
zajęło mu ponad rok.
> Zwłaszcza ta część, że ktoś w ogóle poświęci miesiące swojego życia na tak
zaszczytne zadanie jak próba zrozumienia akurat Twojego wywodu, z 40+ innych w tej
samej dyskusji, spośród niezliczonej liczby takich dyskusji na niezliczonej liczbie
portali dyskusyjnych. Realia publikowania na portalach społecznościowych są takie, że
albo ktoś to od razu zrozumie, albo od razu oleje. Nikt nie będzie inwestował cennych
miesięcy życia na zrozumienie akurat Twojego artykułu. Bez jaj.
Tego nie mogę wiedzieć (i sądzę, że Ty też nie).
Ale dotychczasowe reakcje na artykuł były raczej przychylne, i wydają się sugerować,
że określenie "nikt" to raczej spore niedoszacowanie.
> "Frankly speaking, I've found most other answers here completely disappointing."
>
> W takim razie, frankly speaking, sam się podsumowałeś tym wstępem.
> I nie tylko dlatego, że dla wielu ludzi najbardziej imponujące są właśnie
najprostsze olśnienia, takie programistyczne Zen, jak wcześniejszy artykuł z wieżami
Hanoi w 3 linijkach. Poprzednim zdaniem postawiłeś się ponad swoimi czytelnikami a
tym zdaniem postawiłeś się ponad autorami innych postów.
Nie rozumiem, w jaki sposób "postawiłem się ponad swoimi czytelnikami".
Stwierdzając, że zrozumienie czegoś może zająć kilka miesięcy?
Pomijając kwestię, że owo "postawienie się ponad nimi" jest logicznie niewykonalne,
bo nie mogę a priori powiedzieć, kto ten tekst przeczyta.
Zaś co do "stawiania się ponad autorami innych postów", to owszem, ja sam nie
wyniosłem z ich lektury nic wartościowego. To mnie stawia w tym samym szeregu z
ewentualnymi innymi czytelnikami, którzy mieli podobne odczucia.
> A teraz konkretnie - technika faktycznie ciekawa, ale pomijając zupełnie podstawowy
wykład z LISPa dałoby się to zmieścić w kilku procentach objętości.
Chciałbym to zobaczyć.
> Czy to ma realne zastosowania? Nie wiem. Może mieć - obecnie żywe są dyskusje na
temat zastępowania różnych grup zawodowych przez AI i dla nas ciekawym pytaniem jest
to, czy można zastąpić programistę. Ale chyba trend jest w kierunku innych technik.
Ostatnio widziałem prezentację systemu asystenta programisty (w skrócie: podpowiadacz
w edytorze, czyli tak jak w Twoim artykule), który działał na zasadzie deep learning
z milionów plików źródłowych z GitHuba. Czyli "nauczył się" (cokolwiek to znaczy)
czytając istniejący już kod a potem podpowiada programiście całe garście kodu do tego
co chce zrobić. I mam wrażenie, że ML jest bardziej prawdopodobnym kierunkiem rozwoju
dla takich systemów.
No właśnie, wydaje mi się, że w owym dopowiedzeniu "cokolwiek to znaczy" jest
pogrzebany pies.
Nie traktuję programowania jako "produkowania kodu", tylko jako precyzyjną formę
wyrażania myśli. Żadne AI nie będzie raczej w stanie wyrazić moich myśli
precyzyjniej, niż ja sam.
> Zaletą takiego podejścia jest to, że ML działa jednakowo dobrze na każdym języku
programowania (w szczególności na tych najpopularniejszych), natomiast to co
pokazałeś w swoim artykule działa tylko w LISPie.
To co pokazałem w swoim artykule to po prostu idea, którą najwygodniej wyrazić w
Lispie. Kilka lat temu Will Byrd przyjechał do Poznania, gdzie na konferencji
PolyConf pokazał tę technikę zaimplementowaną dla prostego języka imperatywnego:
https://www.youtube.com/watch?v=eQL48qYDwp4
> Sam artykuł oczywiście, jak zwykle, zniechęca do LISPa.
Powiedz coś więcej na ten temat. W jaki sposób zniechęca?
> Jak ktoś już lubi ten język, to się będzie cieszył, ale też dla takiej publiczności
nie było sensu takich podstaw wykładać. A jak ktoś nie lubi, to nie polubi. Ile można
wciskać ludziom, że zagnieżdżone pary to dobra metoda na robienie list? Przecież to
absurd.
> W tym kontekście konsekwentnie bardziej podoba mi się podejście Wolframa, gdzie
lista jest podstawową konstrukcją wspieraną przez język:
>
> head[elem1, elem2, elem3, ...]
>
> bez sztucznego (!) ograniczenia na liczbę elementów. Nie ma zagnieżdżeń, jeśli nie
są potrzebne (ale mogą być, jeśli chcemy drzewa).
Nie rozumiem. Jakiego ograniczenia na liczbę elementów?
> W Wolframie fajny jest też pomysł na wbudowany symbol Nothing, który "znika" z
sekwencji elementów, jeśli się gdzieś pojawi. Wtedy funkcję filtrującą "only" można
zdefiniować tak:
>
> only[condition_, list_] := Map[
> Function[x,
> If[condition[x], x, Nothing]
> ],
> list
> ]
>
> czyli mapujemy elementy na siebie albo na Nothing jeśli nie spełniają warunku, i
wtedy, przykładowo:
>
> only[EvenQ, {1, 2, 3, 4, 5, 6, 7}]
>
> {2, 4, 6}
A co jeśli owa wartość Nothing miałaby zostać przekazana jako argument do funkcji?
> Oczywiście nikt by tak nie zrobił, bo są gotowe funkcje filtrujące, ale ten
przykład pokazuje, że o listach można myśleć prosto.
No bo o listach można myśleć prosto?
> I wtedy poprzeczka przetwarzania struktur danych jest konsekwentnie niżej - więc
zapewne Twoje przykłady z artykułu dałoby się zapisać dużo prościej, zamiast walczyć
ze sztucznymi ograniczeniami języka. Zagnieżdżone pary? No daj spokój. Palce można
połamać, zupełnie bez satysfakcji.
W kilku miejscach - tam, gdzie poziom zagnieżdżeń przesłaniał istotę rzeczy - użyłem
notacji Haskella.
>
> Inna rzecz - czy konstrukcja if musi być podstawową w LISPie? W Wolframie nie musi
być, bo podstawą całego przetwarzania i tak jest pattern matching, czyli mogę sobie
zdefiniować własnego ifa:
>
> myIf[True, x_, y_] := x
> myIf[False, x_, y_] := y
>
> Chociaż to nie jest właściwe technicznie określenie, można to rozumieć jako
przeciążanie funkcji na wartości pierwszego parametru.
> To działa tak samo jak standardowy If, więc ten standardowy If nie musi być
"magiczną" funkcją, tylko może być biblioteczną. I konsekwentnie można sobie tak
zdefiniować inne warunkowe konstrukcje sterujące. LISP też tak umie, czy może musi
mieć ifa jako "magiczną" funkcję interpretera, bez której niczego nie dało by się
zrobić?
To o co pytasz to absolutne podstawy lambda-rachunku.
If jest definiowalny w oparciu o lambda-wyrażenia. Zamieściłem go jako część
ekspozycji, ponieważ wydaje mi się łatwy do zrozumienia dla "nie-programistów".
https://www.cl.cam.ac.uk/teaching/Lectures/funprog-j
rh-1996/all.pdf
rozdział 3
Inna rzecz - czy pattern matching musi być podstawą w Wolframie? W LISPie nie musi
być, i jeśli chcesz, możesz sobie zdefiniować swój własny.
Następne wpisy z tego wątku
- 01.08.19 13:47 Maciej Sobczak
- 01.08.19 14:26 Maciej Sobczak
- 01.08.19 16:29 g...@g...com
- 02.08.19 10:32 Maciej Sobczak
- 02.08.19 14:10 g...@g...com
- 03.08.19 06:52 AK
- 03.08.19 09:55 g...@g...com
- 03.08.19 21:51 Maciej Sobczak
- 04.08.19 00:37 g...@g...com
- 04.08.19 22:57 Maciej Sobczak
- 05.08.19 12:44 g...@g...com
- 05.08.19 14:35 Roman Tyczka
- 05.08.19 14:58 g...@g...com
- 05.08.19 22:29 Maciej Sobczak
- 06.08.19 10:55 Maciej Sobczak
Najnowsze wątki z tej grupy
- 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
- Ada 2022 Language Reference Manual to be Published by Springer
Najnowsze wątki
- 2024-11-14 Dobra zmiana
- 2024-11-14 Czy prezydent może ułaskawić od zadośćuczynienia? [A. Lepper odszkodowania]
- 2024-11-14 Gliwice => Network Systems Administrator (IT Expert) <=
- 2024-11-14 Gliwice => Administrator Systemów Sieciowych (Ekspert IT) <=
- 2024-11-13 Filtr do pompy ruskiej
- 2024-11-12 Gdzie kosz?
- 2024-11-13 elektrycznie
- 2024-11-12 Jebane kurwa, kurwy.
- 2024-11-13 karta parkingowa
- 2024-11-13 Wl/Wyl (On/Off) bialy/niebieski
- 2024-11-12 I3C
- 2024-11-13 Kraków => DevOps Engineer (Junior or Regular level) <=
- 2024-11-13 Łódź => Senior SAP HANA Developer <=
- 2024-11-13 Zabrze => Senior PHP Symfony Developer <=
- 2024-11-13 Karlino => Konsultant wewnętrzny SAP (FI/CO) <=