A recursive GCD in CAS
|
02-25-2014, 03:19 AM
Post: #1
|
|||
|
|||
A recursive GCD in CAS
CAS is a sort of functional language like LISP or F#. Functional languages often uses recursion in place of loops. Combining recursive and piecewise functions give us all the necessary tools to write powerful "CAS programs" without using HP-PPL.
To test these concepts I wrote a GCD function: \[ mgcdr(z,w):=z-w*IP(z/w) \] \[ mgcdi(z,w) := \begin{cases} {w \ \mbox{if} \ mgcdr(z,w)=0} \\ {mgcdi(w,mgcdr(z,w)) \ \mbox{if} \ mgcdr(z,w) \neq 0} \end{cases} \] \[ mgcd(a,b):=mgcdi(MAX(|a|,|b|),MIN(|a|,|b|)) \] Or in HP Prime syntax: Code:
Note that combining functions is often convenient. Sure it is less efficient than an HP-PPL equivalent program: Code:
but I find this approach very interesting (especially when you need to manage lists). Massimo from 34c to prime |
|||
02-25-2014, 07:42 PM
(This post was last modified: 02-25-2014 07:44 PM by Mic.)
Post: #2
|
|||
|
|||
RE: A recursive GCD in CAS
Very interesting.
http://mic.nic.free.fr - Youtube - Facebook |
|||
« Next Oldest | Next Newest »
|
User(s) browsing this thread: 2 Guest(s)