-
Data: 2019-08-08 22:04:47
Temat: Re: "Najbardziej imponujący kod, jaki widziałem"
Od: Maciej Sobczak <s...@g...com> szukaj wiadomości tego autora
[ pokaż wszystkie 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
- Popr. 14. Nauka i Praca Programisty C++ w III Rzeczy (pospolitej)
- Arch. Prog. Nieuprzywilejowanych w pełnej wer. na nowej s. WWW energokod.pl
- 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
Najnowsze wątki
- 2025-01-06 Jeździ, skręca, hamuje
- 2025-01-06 Białystok => System Architect (Java background) <=
- 2025-01-06 Gliwice => Specjalista ds. public relations <=
- 2025-01-06 Białystok => Solution Architect (Java background) <=
- 2025-01-06 Zielona GĂłra => Konsultant WdroĹźeniowy Comarch XL/Optima (KsiÄgowoĹ
- 2025-01-06 Popr. 14. Nauka i Praca Programisty C++ w III Rzeczy (pospolitej)
- 2025-01-06 Ostrów Wielkopolski => Area Sales Manager OZE <=
- 2025-01-06 Do IO i innych elektrooszolomow, tu macie prawdziwe smrody
- 2025-01-06 Białystok => Full Stack .Net Engineer <=
- 2025-01-06 Kraków => Business Development Manager - Network and Network Security
- 2025-01-06 Katowice => Regionalny Kierownik Sprzedaży (OZE) <=
- 2025-01-06 Warszawa => Spedytor Międzynarodowy <=
- 2025-01-06 Lublin => Programista Delphi <=
- 2025-01-06 Gdańsk => Specjalista ds. Sprzedaży <=
- 2025-01-06 śnieg