Difference between revisions of "Ro/Sintaxa Limbajului Rodin"

From HaskellWiki
Jump to navigation Jump to search
 
 
(8 intermediate revisions by the same user not shown)
Line 1: Line 1:
  +
[[Category:Ro]][[Category:Ub.Ro]]
==.Ce este Rodin ? ==
 
  +
Un limbaj de programare imperativ, asemanator cu C-ul, destinat rularii de programe in pseudocod. Doriti un software care sa execute, pentru elevii dumneavoastra , programele scrise de ei in pseudocod ? Daca Da, Rodin este pentru dumneavoastra. Limbajul '''Rodin este foarte bun pentru invatat o serie de notiuni de algoritmistica''', dupa parerea beta-testerilor nostri. Limbajul Rodin raspunde la intrebarea "Cum sa rulez pseudocod scris in limba româna, pe calculator, la lectiile de informatica de la liceu sau scoala generala, ori chiar la facultate ?" Limbajul pseudocod Rodin este rezultatul a 7 ani de studiu si cercetare universitara in teoria limbajelor modulare.
 
  +
== Download-ul limbajul pseudocod gratuit Rodin ==
  +
  +
[[Image:download2.gif|left|http://www.haskell.org/haskellwiki/Rodin/Download]]Mergeti inapoi la inceputul paginii Rodin: <br> http://www.haskell.org/haskellwiki/Rodin. <br> Sau direct la pagina de <DOWNLOAD> : <br> http://www.haskell.org/haskellwiki/Rodin/Download
  +
<br>
  +
<br>
  +
  +
== Sintaxa Limbajului Pseudocod Rodin ==
  +
  +
*Cel mai bine o gasiti in directorul de documentatii din arhiva programului din pagina [[Rodin/Download]].
  +
*http://www.haskell.org/haskellwiki/Ro/Sintaxa_Limbajului_Rodin
  +
  +
Limbajele din clasa C-ului, fie ca este vorba de limbaje pentru software de proiectare (Solid Works ??) fie ca este vorba de limbaje de programare sau limbaje de (web-)scripting au in general o sintaxa asemanatoare. Necazul este ca un incepator trebuie sa invete SIMULTAN si semnificatia instructiunilor - impreuna cu acele concepte fundamentale ascunse in spatele lor - si cuvintele englezesti cu care se scriu programele. Si asta stiind uneori doar romana, franceza sau rusa. Greselile devin in acest caz mult mai usor de facut.
  +
  +
<center> [[Image:Engleza3.JPG]] </center>
  +
  +
Pentru a nu ajunge in situatia proiectantilor din imaginea de mai sus este recomandabil sa se predea intai conceptele in limba romana (sub forma de pseudocod), urmate de cuvintele cheie englezesti. Deoarece studentii si elevii pot protesta (pe drept cuvant) ca vin in laboratorul de infoprmatica si fac pseudocod la tabla fara sa puna mina pe calculatoare (voi adauga link-ul ...)
  +
am realizat Limbajul Pseudocod Rodin, care rezolva aceasta problema. Si, bineinteles produce altele :)
  +
  +
  +
Cuvinte cheie folosite, instructiuni, operatori, primele exemple:
  +
  +
== RodinV082c-Ro -- 23/11/2008 ==
  +
Nou: Am introdus instructiunea de citire pentru vectori.
  +
  +
citeste v[e]; unde v e vectorul si e este expresia.
  +
  +
== RodinV08-Ro -- 9/11/2008 ==
  +
  +
Nota: Am introdus 'text' iar 'tasteaza' a devenit 'citeste'.
  +
  +
Nou: Am introdus vectori liniari oricat de lungi.
  +
  +
Dar sa fie initializati.
  +
  +
  +
  +
  +
  +
'''Atribuirea pentru vectori'''
  +
  +
<idvector>[<exp>]=<exp>;
  +
  +
  +
  +
'''Expresie element de vector'''
  +
  +
<idvector>[<exp>]
  +
  +
  +
  +
'''Secventa de instructiuni'''
  +
  +
{ <expr>; .... <expr> ; }
  +
  +
  +
'''Atribuirea'''
  +
  +
fie <name> = <expr>
  +
  +
  +
'''Alternativa/Conditionala'''
  +
  +
daca <expr> atunci <expr> altfel <expr>
  +
  +
  +
'''Bucla cu test initial'''
  +
  +
cat timp (<expr>) <expr>
  +
  +
  +
'''Bucla cu test final'''
  +
  +
executa <expr> atat cat (<expr>)
  +
  +
  +
'''Bucla cu test de succes final'''
  +
  +
repeta <expr> pana cand <expr>
  +
  +
  +
'''Bucla cea mai generala'''
  +
  +
pentru (<exp>; <exp>; <exp>) <exp>
  +
  +
Atentie: Unele programe scrise corect dau o eroare de sintaxa la aceste bucle,
  +
ba cerand ba necerand spatiu dupa "pentru". Biblioteca de combinatori de parsere a avut un defect ?
  +
  +
  +
'''Tastarea unui nr (op de citire)'''
  +
  +
citeste <ident>
  +
  +
  +
  +
'''Scrierea'''
  +
  +
scrie <expr>
  +
  +
text "string de afisat"
  +
  +
  +
  +
'''Functii anonime nerecursive'''
  +
  +
(\ <name> . <expr>)
  +
  +
  +
  +
'''Aplicarea (asociaza la dreapta)'''
  +
  +
<functie anonima> <expr>
  +
  +
  +
  +
Operatori: + - * / %
  +
  +
Comparatii: > , < , == , !=
  +
  +
  +
Lipsesc: ! negatia, op logici ,op logici pe biti, cond-ul...
  +
  +
  +
'''Atribuirea are valoare'''
  +
  +
{ fie y =2;
  +
  +
fie x=100;
  +
  +
cat timp (x>10)
  +
  +
fie x=x-(fie y = 1);
  +
  +
scrie x;
  +
  +
scrie y;
  +
  +
}
  +
  +
  +
  +
'''Program 1:'''
  +
  +
{scrie 1;}
  +
  +
  +
  +
'''Program 2:'''
  +
  +
{ citeste x;
  +
  +
scrie x;}
  +
  +
  +
  +
'''Program 3'''
  +
  +
  +
{ citeste x;
  +
  +
fie x=x+1;
  +
  +
scrie x;
  +
  +
}
  +
  +
  +
  +
'''Program 4:cmmdc'''
  +
  +
{ citeste a;
  +
  +
citeste b;
  +
  +
fie undeimp=a;
  +
  +
fie unimp=b;
  +
  +
repeta
  +
  +
{ fie unrest=undeimp%unimp;
  +
  +
fie undeimp=unimp;
  +
  +
fie unimp=unrest;
  +
  +
}
  +
  +
pana cand (unimp==0);
  +
  +
scrie undeimp;
  +
  +
};
  +
  +
  +
  +
  +
  +
'''Program 5: bucla cu nr cunoscut de pasi'''
  +
  +
{pentru(fie x=1;x<10;fie x=x+1) scrie x;};
  +
  +
  +
  +
  +
  +
'''Program 6: numere pitagoreice'''
  +
  +
{ pentru (fie x=1; x<3; fie x=x+1)
  +
  +
pentru (fie y=x+1; y<3; fie y=y+1)
  +
  +
{
  +
  +
scrie x*x+y*y;
  +
  +
scrie y*y-x*x;
  +
  +
scrie 2*x*y;
  +
  +
};
  +
  +
};
  +
  +
  +
  +
'''Program 7: maximul unui sir de numere terminat cu zero'''
  +
  +
{ text " Maximul elementelor unui sir de numere ";
  +
  +
text "pozitive distincte terminat cu numarul zero. ";
  +
  +
fie xmaxpp = 0;
  +
  +
text "Dati y ";
  +
  +
citeste y;
  +
  +
executa {
  +
  +
{daca (y>xmaxpp) atunci fie xmaxpp=y altfel fie xmaxpp=xmaxpp;};
  +
  +
text "Dati urmatorul y ";
  +
  +
citeste y;
  +
  +
}atat cat (y!=0);
  +
  +
text "maximul este ";
  +
  +
scrie xmaxpp;
  +
  +
};
  +
  +
Cuvinte cheie folosite, instructiuni, operatori, primele exemple:
  +
  +
== RodinV07-Ro -- 10/9/2008 ==
  +
  +
'''Secventa de instructiuni:'''
  +
{ <expr>; .... <expr> ; }
  +
  +
'''Atribuirea'''
  +
fie <name> = <expr>
  +
  +
'''Alternativa/Decizia/Conditionala:'''
  +
daca <expr> atunci <expr> altfel <expr>
  +
  +
'''Bucla cu test initial:'''
  +
cat timp (<expr>) <expr>
  +
  +
'''Bucla cu test final:'''
  +
executa <expr> atat cat (<expr>)
  +
  +
'''Bucla cu test de succes final:'''
  +
repeta <expr> pana cand <expr>
  +
  +
'''Bucla cea mai generala:'''
  +
pentru (<exp>; <exp>; <exp>) <exp>
  +
  +
'''Tastarea unui nr (op de citire):'''
  +
tasteaza <ident>
  +
  +
'''Scrierea:'''
  +
scrie <expr>
  +
  +
'''Functii anonime nerecursive:'''
  +
(\ <name> . <expr>)
  +
unde name e numele variabilei parametru formal
  +
  +
'''Aplicarea (asociaza la dreapta):'''
  +
<functie anonima> <expr>
  +
  +
'''Atribuirea are valoare: valoarea atribuita e si valoarea ei'''
  +
<haskell>
  +
{ fie y =2;
  +
fie x=100;
  +
cat timp (x>10)
  +
fie x=x-(fie y = 1);
  +
scrie x;
  +
scrie y;
  +
}
  +
  +
Operatori: + - * / %
  +
  +
Comparatii: > , < , == , !=
  +
  +
Lipsesc: ! negatia, op logici ,op logici pe biti ...
  +
  +
</haskell>
  +
  +
----
  +
<center> [[Image:Rodin-Banner.gif]] </center>
  +
----
  +
Pagina proiectului Rodin este in dezvoltare. Vizitati-o regulat pentru a gasi update-urile, noutatile precum si programele si exercitiile noi adaugate.
  +
----
  +
Inapoi la inceputul paginii Rodin: http://www.haskell.org/haskellwiki/Rodin. (pe care o gasiti imediat folosind un motor de cautare binecunoascut.)
  +
<center> [[Image:FindOnYahoo.jpg]] </center>
  +
----

Latest revision as of 09:42, 29 January 2010


Download-ul limbajul pseudocod gratuit Rodin

http://www.haskell.org/haskellwiki/Rodin/Download

Mergeti inapoi la inceputul paginii Rodin:
http://www.haskell.org/haskellwiki/Rodin.
Sau direct la pagina de <DOWNLOAD> :
http://www.haskell.org/haskellwiki/Rodin/Download



Sintaxa Limbajului Pseudocod Rodin

Limbajele din clasa C-ului, fie ca este vorba de limbaje pentru software de proiectare (Solid Works ??) fie ca este vorba de limbaje de programare sau limbaje de (web-)scripting au in general o sintaxa asemanatoare. Necazul este ca un incepator trebuie sa invete SIMULTAN si semnificatia instructiunilor - impreuna cu acele concepte fundamentale ascunse in spatele lor - si cuvintele englezesti cu care se scriu programele. Si asta stiind uneori doar romana, franceza sau rusa. Greselile devin in acest caz mult mai usor de facut.

Engleza3.JPG

Pentru a nu ajunge in situatia proiectantilor din imaginea de mai sus este recomandabil sa se predea intai conceptele in limba romana (sub forma de pseudocod), urmate de cuvintele cheie englezesti. Deoarece studentii si elevii pot protesta (pe drept cuvant) ca vin in laboratorul de infoprmatica si fac pseudocod la tabla fara sa puna mina pe calculatoare (voi adauga link-ul ...) am realizat Limbajul Pseudocod Rodin, care rezolva aceasta problema. Si, bineinteles produce altele :)


Cuvinte cheie folosite, instructiuni, operatori, primele exemple:

RodinV082c-Ro -- 23/11/2008

Nou: Am introdus instructiunea de citire pentru vectori.

citeste v[e]; unde v e vectorul si e este expresia.

RodinV08-Ro -- 9/11/2008

Nota: Am introdus 'text' iar 'tasteaza' a devenit 'citeste'.

Nou: Am introdus vectori liniari oricat de lungi.

Dar sa fie initializati.



Atribuirea pentru vectori

<idvector>[<exp>]=<exp>;


Expresie element de vector

<idvector>[<exp>]


Secventa de instructiuni

{ <expr>; .... <expr> ; }


Atribuirea

fie <name> = <expr>


Alternativa/Conditionala

daca <expr> atunci <expr> altfel <expr>


Bucla cu test initial

cat timp (<expr>) <expr>


Bucla cu test final

executa <expr> atat cat (<expr>)


Bucla cu test de succes final

repeta <expr> pana cand <expr>


Bucla cea mai generala

pentru (<exp>; <exp>; <exp>) <exp>

Atentie: Unele programe scrise corect dau o eroare de sintaxa la aceste bucle, ba cerand ba necerand spatiu dupa "pentru". Biblioteca de combinatori de parsere a avut un defect ?


Tastarea unui nr (op de citire)

citeste <ident>


Scrierea

scrie <expr>

text "string de afisat"


Functii anonime nerecursive

(\ <name> . <expr>)


Aplicarea (asociaza la dreapta)

<functie anonima> <expr>


Operatori: + - * / %

Comparatii: > , < , == , !=


Lipsesc: ! negatia, op logici ,op logici pe biti, cond-ul...


Atribuirea are valoare

{ fie y =2;

 fie x=100;
 cat timp (x>10)
   fie x=x-(fie y = 1);
 scrie x;
 scrie y;

}


Program 1:

{scrie 1;}


Program 2:

{ citeste x;

 scrie x;}


Program 3


{ citeste x;

 fie x=x+1;
 scrie x;

}


Program 4:cmmdc

{ citeste a;

 citeste b;
 fie undeimp=a;
 fie unimp=b;
 repeta
   { fie unrest=undeimp%unimp;
     fie undeimp=unimp;
     fie unimp=unrest;
    }
 pana cand (unimp==0);
 scrie undeimp;

};



Program 5: bucla cu nr cunoscut de pasi

{pentru(fie x=1;x<10;fie x=x+1) scrie x;};



Program 6: numere pitagoreice

{ pentru (fie x=1; x<3; fie x=x+1)

  pentru (fie y=x+1; y<3; fie y=y+1)
    {
     scrie x*x+y*y;
     scrie y*y-x*x;
     scrie 2*x*y;
    };

};


Program 7: maximul unui sir de numere terminat cu zero

{ text " Maximul elementelor unui sir de numere ";

 text "pozitive distincte terminat cu numarul zero. ";
 fie xmaxpp = 0;
 text "Dati y ";
 citeste y;
 executa {
   {daca (y>xmaxpp) atunci fie xmaxpp=y altfel fie xmaxpp=xmaxpp;};
   text "Dati urmatorul y ";
   citeste y; 
 }atat cat (y!=0);
 text "maximul este ";
 scrie xmaxpp;

};

Cuvinte cheie folosite, instructiuni, operatori, primele exemple:

RodinV07-Ro -- 10/9/2008

Secventa de instructiuni: { <expr>; .... <expr> ; }

Atribuirea fie <name> = <expr>

Alternativa/Decizia/Conditionala: daca <expr> atunci <expr> altfel <expr>

Bucla cu test initial: cat timp (<expr>) <expr>

Bucla cu test final: executa <expr> atat cat (<expr>)

Bucla cu test de succes final: repeta <expr> pana cand <expr>

Bucla cea mai generala: pentru (<exp>; <exp>; <exp>) <exp>

Tastarea unui nr (op de citire): tasteaza <ident>

Scrierea: scrie <expr>

Functii anonime nerecursive: (\ <name> . <expr>) unde name e numele variabilei parametru formal

Aplicarea (asociaza la dreapta): <functie anonima> <expr>

Atribuirea are valoare: valoarea atribuita e si valoarea ei

{ fie y =2;
  fie x=100;
  cat timp (x>10)
    fie x=x-(fie y = 1);
  scrie x;
  scrie y;
}

Operatori: + - * / %

Comparatii: > , < , == , !=

Lipsesc: ! negatia, op logici ,op logici pe biti ...

Rodin-Banner.gif

Pagina proiectului Rodin este in dezvoltare. Vizitati-o regulat pentru a gasi update-urile, noutatile precum si programele si exercitiile noi adaugate.


Inapoi la inceputul paginii Rodin: http://www.haskell.org/haskellwiki/Rodin. (pe care o gasiti imediat folosind un motor de cautare binecunoascut.)

FindOnYahoo.jpg