eGospodarka.pl
eGospodarka.pl poleca

eGospodarka.plGrupypl.comp.programmingPisanie programów do obliczeń symbolicznychRe: Pisanie program?w do oblicze? symbolicznych
  • 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

Podziel się

Poleć ten post znajomemu poleć

Wydrukuj ten post drukuj

Najnowsze wątki z tej grupy


Najnowsze wątki

Szukaj w grupach

Eksperci egospodarka.pl

1 1 1

Wpisz nazwę miasta, dla którego chcesz znaleźć jednostkę ZUS.

Wzory dokumentów

Bezpłatne wzory dokumentów i formularzy.
Wyszukaj i pobierz za darmo: