-
X-Received: by 2002:ae9:ef48:: with SMTP id d69mr15047506qkg.313.1565294687455; Thu,
08 Aug 2019 13:04:47 -0700 (PDT)
X-Received: by 2002:ae9:ef48:: with SMTP id d69mr15047506qkg.313.1565294687455; Thu,
08 Aug 2019 13:04:47 -0700 (PDT)
Path: news-archive.icm.edu.pl!news.icm.edu.pl!newsfeed.pionier.net.pl!3.eu.feeder.erj
e.net!2.eu.feeder.erje.net!4.us.feeder.erje.net!feeder.erje.net!weretis.net!fee
der6.news.weretis.net!feeder.usenetexpress.com!feeder-in1.iad1.usenetexpress.co
m!border1.nntp.dca1.giganews.com!border2.nntp.dca1.giganews.com!nntp.giganews.c
om!b26no1308852qtq.0!news-out.google.com!e17ni2994qtg.1!nntp.google.com!b26no13
08846qtq.0!postnews.google.com!glegroupsg2000goo.googlegroups.com!not-for-mail
Newsgroups: pl.comp.programming
Date: Thu, 8 Aug 2019 13:04:47 -0700 (PDT)
In-Reply-To: <qihg0f$6g7$1@gioia.aioe.org>
Complaints-To: g...@g...com
Injection-Info: glegroupsg2000goo.googlegroups.com; posting-host=213.108.152.51;
posting-account=bMuEOQoAAACUUr_ghL3RBIi5neBZ5w_S
NNTP-Posting-Host: 213.108.152.51
References: <e...@g...com>
<1...@g...com>
<c...@g...com>
<0...@g...com>
<b...@g...com>
<d...@g...com>
<2...@g...com>
<qi33uq$16s3$1@gioia.aioe.org>
<0...@g...com>
<qifk8k$26s$1@gioia.aioe.org>
<3...@g...com>
<qihg0f$6g7$1@gioia.aioe.org>
User-Agent: G2/1.0
MIME-Version: 1.0
Message-ID: <0...@g...com>
Subject: Re: "Najbardziej imponujący kod, jaki widziałem"
From: Maciej Sobczak <s...@g...com>
Injection-Date: Thu, 08 Aug 2019 20:04:47 +0000
Content-Type: text/plain; charset="UTF-8"
Content-Transfer-Encoding: quoted-printable
Lines: 62
Xref: news-archive.icm.edu.pl pl.comp.programming:213781
[ ukryj nagłówki ]> No niekoniecznie. Tzn "metodycznie" masz racje, ale wydajnosciowo
> juz mniej. W Pythonie istnieje standardowa struktura typu tablice
> - array() - o okreslonym i i stalym (w przeciwienstwie do list) -
> typie danych, czyli zdecydowanie wydajniejsza ok (linked)list,
> Oczywiscie obluga obu jest taka sama/bardzo podobna.
OK. Dla porównania, Wolfram oferuje tablice przeznaczone do pracy z typami
numerycznymi:
https://reference.wolfram.com/language/ref/NumericAr
ray.html
oraz ByteArray.
Służą do optymalizacji czasu obliczeń, zajętości pamięci (są zawsze spakowane) i do
komunikacji z modułami napisanymi w C. Te tablice to naprawdę tablice, takie jak w C,
żadnych dekoracji. Ale zestaw dostępnych typów jest z góry ograniczony.
To są jednak niskopoziomowe narzędzia, chociaż ich interfejs jest taki sam jak
normalnej listy.
W Wolframie chodzi jednak o coś szerszego - lista to nie tylko {a,b,c}. Wszystko ma
wewnętrznie taką samą postać, więc skoro {a,b,c} to w rzeczywistości List[a,b,c], to
podobnie np. a+b+c to w rzeczywistości Plus[a,b,c]. I taki Plus ma te same mechanizmy
dostępu co List, bo z punktu widzenia indeksowania to jest taka sama struktura
danych. Czyli np.:
{a, b, c}[[2]]
b
(a + b + c)[[2]]
b
whatever[a, b, c][[2]]
b
Ciekawostka - indeksowanie tych struktur jest od 1, natomiast 0 jest indeksem
specjalnym, który oznacza "głowę" całej konstrukcji:
{a, b, c}[[0]]
List
(a + b + c)[[0]]
Plus
whatever[a, b, c][[0]]
whatever
Wszystko działa tak samo i to jest ta "nieortodoksyjna LISPowatość" Wolframa, która
ułatwia metaprogramowanie i przetwarzanie symboliczne. Nie ma natomiast żadnych
gwarancji co do wewnętrznej implementacji tych struktur. Czy to są tablice, czy listy
z dodatkowym indeksem czy jeszcze jakieś inne hashmapy - nie wiemy.
--
Maciej Sobczak * http://www.inspirel.com
Następne wpisy z tego wątku
- 24.09.21 01:11 Bischoop
Najnowsze wątki z tej grupy
- 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ą."
- Instytut IDEAS może zacząć działać: "Ma to być unikalny w europejskiej skali ośrodek badań nad sztuczną inteligencją."
- U nas propagują modę na SI, a w Chinach naukowcy SI po kolei umierają w wieku 40-50lat
- C++. Podróż Po Języku - komentarz
Najnowsze wątki
- 2025-07-07 Re: Ząbki się spaliły jak wiejskie, drewniane stodoły sprzed 50 lat
- 2025-07-06 Kup szybko nową ładowarkę do smartfona
- 2025-07-07 TV z Play (dawniej UPC) -- potrzebny dekoder?
- 2025-07-06 Kup szybko nową ładowarkę do smartfona
- 2025-07-07 mija rok jeżdzenia po lewej
- 2025-07-06 Elektryki jednak są NIEBEZPIECZNE
- 2025-07-08 Fajny film widziałem...
- 2025-07-07 Re: Ząbki się spaliły jak wiejskie, drewniane stodoły sprzed 50 lat
- 2025-07-06 Kup szybko nową ładowarkę do smartfona
- 2025-07-07 Gdańsk => Programista Kotlin <=
- 2025-07-07 Białystok => Mainframe (z/OS, Assembler) Developer <=
- 2025-07-07 Warszawa => Asystent ds. Sprzedaży i Rozwoju Klienta <=
- 2025-07-07 Warszawa => International Freight Forwarder <=
- 2025-07-07 Warszawa => Java Developer <=
- 2025-07-07 Białystok => Software Engineer .Net <=