-
Path: news-archive.icm.edu.pl!news.icm.edu.pl!newsfeed.pionier.net.pl!pwr.wroc.pl!new
s.wcss.wroc.pl!not-for-mail
From: a...@m...uni.wroc.pl
Newsgroups: pl.comp.programming
Subject: Re: Pisanie program?w do oblicze? symbolicznych
Date: Sun, 2 Oct 2016 00:27:45 +0000 (UTC)
Organization: Politechnika Wroclawska
Lines: 60
Message-ID: <nspka1$nsc$1@z-news.wcss.wroc.pl>
References: <nrlldd$6km$1@node2.news.atman.pl>
NNTP-Posting-Host: hera.math.uni.wroc.pl
X-Trace: z-news.wcss.wroc.pl 1475368065 24460 156.17.86.1 (2 Oct 2016 00:27:45 GMT)
X-Complaints-To: a...@n...pwr.wroc.pl
NNTP-Posting-Date: Sun, 2 Oct 2016 00:27:45 +0000 (UTC)
Cancel-Lock: sha1:scK0yrZZwnjXDQcg5JDNGcPQF+o=
User-Agent: tin/2.2.1-20140504 ("Tober an Righ") (UNIX) (Linux/4.6.4 (x86_64))
Xref: news-archive.icm.edu.pl pl.comp.programming:209843
[ ukryj nagłówki ]Borneq <b...@a...hidden.pl> wrote:
> By? kiedy? taki program Derive. Maxima jest napisana w Lispie czy j?zyku
> lispopodobnym. S? koby?y jak Matematica czy Wolfram.
> Nic nie powinno by? przeszkod?, aby pisa? to nie w j?zykach
> lispopodobnych ale og?lnego przeznaczenia C++ czy Javie.
Jak chcesz to wygodnie pisac to pojawia sie troche wymagan:
- elastyczne struktury danych (zaczynajac od list)
- odsmiecanie (garbage collection). Np. jak piszesz
a := f(g(x))
i g zwraca dynamicznie zaalokowana strukture danych to chesz
zeby ona znikenla kiedy jest niepotrzebna
- elastyczne przeciazanie lub beztypowosc. Np.
x * y
moze oznaczac mnozenie funkcji, wyrazen, macierzy lub wektorow.
Aby miec zgodnosc z tradycyjna notacja dobrze uzywac ten sam
symbol (czyli '*') na oznaczanie mnozenia.
Jesli podchodzisz do problemu powaznie to pewnie chcesz zeby
program szybko dzialal a wtedy potrzebujesz szybkie procedury
arytmetyki wielokrotnej precyzji, co na dzis oznacza wstawki
w asemblerze.
Ludzie pisali programy obliczen symbolicznych w roznych
jezykach, np. Pari-GP w C, giac, ginac i Yacas w C++, jest pare
w Javie. Jak sobie popatrzysz na Pari-GP to bedziesz wiedzial
dlaczego C slabo sie nadaje do obliczen symbolicznych: kod
jest dluzszy i malo czytelny w porownaniu z lepiej dobranym
jezykiem. Java i C++ sa troche lepsze, ale praktyce tez
maja problemy (teoretycznie templates + biblioteki wsparcia
daja odpowiednia elastycznosc w C++).
> Ale jak napisa?
> nawet najprostsze narz?dzie do przekszta?cania wzor?w? Raczej nie
> stosuje si? algorytm?w lecz pewne regu?y przekszta?ce?, kt?re program
> musi wiedzie? jak kt?re u?y?.
"Reguly przeksztalcen" to bylo 40 lat temu. Teraz kluczem
sa algorytmy. Na wstepie mozesz zajrzec do ksiazki
J.H. Davenport, Y. Siret, E. Tournier, "Computer Algebra -- Systems
and Algorithms for Algebraic Computation" dostepnej pod:
http://staff.bath.ac.uk/masjhd/masternew.pdf
Jako wskazowka: jedna z najprostszych operacji jest "skracanie"
ulamkow. Zwylke to sie robi obliczajac najwiekszy spolny dzielnik
(GCD). Dla liczb dobrze dziala algorytm Euklidesa. Dla
wielomianow wielu zmiennych tez mozna uzyc algorytm Euklidesa.
Ale najpierw trzeba troche teorii. Potem okazuje sie
ze naiwna implementacja jest powolna. Szybka implementacja
uzywa nowych pomyslow.
--
Waldek Hebisch
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-02-01 Śmierć mózgu a narządy do pobrania
- 2025-01-31 A niektórym to naprawdę zależy na ekologi w miastach LPG POWRACA ;-)
- 2025-01-31 Lublin => Programista Delphi <=
- 2025-01-31 Łódź => Programista NodeJS <=
- 2025-01-31 Wrocław => Senior SAP Support Consultant (SD) <=
- 2025-01-31 Warszawa => Full Stack web developer (obszar .Net Core, Angular6+) <=
- 2025-01-31 Gdańsk => iOS Developer (Swift experience) <=
- 2025-01-31 Kraków => UX Designer <=
- 2025-01-31 Warszawa => Data Engineer (Tech Leader) <=
- 2025-01-31 Gliwice => Business Development Manager - Dział Sieci i Bezpieczeńst
- 2025-01-31 Gliwice => Business Development Manager - Network and Network Security
- 2025-01-31 Warszawa => Architekt rozwiązań (doświadczenie w obszarze Java, AWS
- 2025-01-31 Warszawa => Full Stack .Net Engineer <=
- 2025-01-31 Warszawa => Programista Full Stack (.Net Core) <=
- 2025-01-31 Gdańsk => Programista Full Stack .Net <=