Sunteți pe pagina 1din 12

Captulo

Aritmtica

3.1.
3.1.1.

Trabajando con distintos tipos de nmeros


Nmeros enteros

Maxima (y wxMaxima) pueden trabajar con nmeros enteros con cualquier nmero de dgitos. Pero por defecto, cuando la representacin decimal de un nmero es demasiado larga como para que quepa en una sola lnea, wxMaxima corrige esta representacin eliminando la mayor parte de los dgitos intermedios. Por ejemplo, ante la entrada
ENTRADA: 100!

wxMaxima nos devolvera el siguiente resultado: ( %o1) 933262154439441526816992388562[98 digits]916864000000000000000000000000 Esto no signica que los 98 dgitos intermedios se hayan perdido, simplemente no aparecen en pantalla. Si realmente estamos interesados en obtener todos los dgitos, simplemente tenemos que seleccionar Maxima Cambiar pantalla 2D y elegir el algoritmo ascii para las salidas numricas. De esta forma, el formato de salida ser exactamente el mismo que el utilizado por Maxima y por otras interfaces grcas como xmaxima, en particular se presentarn todos los dgitos intermedios, obteniendo en el ejemplo anterior:
ENTRADA: 100!

( %o2) 933262154439441526816992388562667004907159682643816214685929638952175999 932299156089414639761565182862536979208272237582511852109168640000000000000000 00000000 La funcin is se puede utilizar para comprobar si una proposicin lgica es cierta true o falsa false. Por ejemplo: ( %i1) is(10! = 9! * 10); ( %o1) true

2 Ejercicios resueltos y actividades

Aritmtica

Se propondr una tarea en el campus virtual consistente en realizar ejercicios o actividades didcticas relacionadas con este apartado. Un ejemplo muy sencillo podra ser el siguiente ejercicio: Pregunta: Con las operaciones suma y producto, obtener el nmero 100 empleando las nueve cifras 1, 2, 3, 4, 5, 6, 7, 8, 9, sin omitir ni repetir ninguna. Solucin: ( %i2) 2*(3*5+1+4+6+7+8+9); ( %o2) 100 Seguramente hay ms soluciones...

3.1.2.

Nmeros racionales

Como se ha comentado, Maxima es un programa de clculo simblico, capaz de operar con aritmtica racional: ( %i1) 95!/100!; ( %o1) 1 9034502400

Como se aprecia en el ejemplo anterior, Maxima simplican de forma automtica las fracciones numricas. Podemos operar utilizando los operadores +,-,*,/, pero siempre teniendo en cuenta que las dos producto y divisin tienen mayor prioridad que la suma y la resta. En aquellas ocasiones en que deseemos efectuar sumas o rectas antes que divisiones o productos, ser necesario utilizar los parntesis, como se muestra en los siguientes ejemplos: ( %i2) 3+1/2; ( %o2) 7 2 ( %i3) ( %o3) (3+1)/2; 2 ( %i4) ( %o4) 1/2+3; 7 2

3.1 Trabajando con distintos tipos de nmeros

( %i5) ( %o5)

1/(2+3); 1 5

( %i6) ( %o6)

1+2*3+4; 11

( %i7) ( %o7)

1+2*(3+4); 15

( %i8) ( %o8)

(1+2)*(3+4); 21

Ejercicios resueltos y actividades Se propondr una tarea en el campus virtual consistente en realizar ejercicios o actividades didcticas relacionadas con este apartado.

3.1.3.

Nmeros reales

Existen algunos nmeros reales predenidos como %pi, %e, otros nmeros irracionales se obtienen como resultado de funciones como sqrt (raz cuadrada). ( %i1) ( %o1) (%pi+sqrt(2))/%e+1; e1 + 2 +1

Existen dos formas de representarlos decimalmente:

4 Nmeros en coma otante de precisin ja (oat)

Aritmtica

Para obtener una representacin decimal de un nmero real1 podemos optar por una de las siguientes posibilidades: Utilizar la funcin float Aadir una coma (,) seguida de la orden numer. En el men de wxMaxima, seleccionar Numerico A real (oat) El nmero resultante tendr 16 cifras decimales: ( %i2) %pi-%e; ( %o2) e ( %i3) ( %o3) float(%); 0,42331082513074803 ( %i4) ( %o4) %pi/6,numer; 0,52359877559829882

Si alguno de los nmeros que interviene en una operacin se encuentra en representacin decimal, el resultado se convertir automticamente a este formato: ( %i5) 22/7-3.0; ( %o5) 0,14285714285714279

Del mismo modo, si a una funcin se le pasa un argumento en formato de coma otante, devolver el resultado en el mismo formato: ( %i6) cos(1); ( %o6) cos 1 ( %i7)
1

cos(1.0);

En realidad, obtenemos un nmero de coma otante y precisin ja (IEE 754) en doble precisin (64 bits)

3.1 Trabajando con distintos tipos de nmeros ( %o7) 0,54030230586813977

Nmeros en coma otante de precisin no ja (real largo o boat) Existen nmeros reales de precisin arbitraria, que podemos jar con la variable fpprec (oat point precision) o mediante el men Numerico Establecer precisin... . Para representar un nmero real en este formato, podemos optar por una de las siguientes posibilidades: Utilizar la funcin bfloat En el men de wxMaxima, seleccionar Numerico A real grande (bigoat) Estos nmeros terminan con los caracteres bN (siendo N un nmero entero), que indican que los dgitos anteriores se deben multiplicar por 10N . Ejemplos: ( %i8) fpprec:50; ( %o8) 50

( %i9) ( %o9)

bfloat(%pi); 3,1415926535897932384626433832795028841971693993751b0

( %i10) ( %o10)

1000+cos(1b0);

1,0005403023058681397174009366074429766037323104206b3

Ejercicios resueltos y actividades Se propondr una tarea en el campus virtual consistente en realizar ejercicios o actividades didcticas relacionadas con este apartado.

Aritmtica

Nmeros complejos
En Maxima se puede acceder a la unidad imaginaria a travs de la constante %i. El resto de los nmeros complejos se representan mediante expresiones de la forma a + b %i, donde a y b son nmeros reales. Las funciones realpart e imagpart nos devuelven, respectivamente, la parte real e imaginaria de un nmero complejo. A estas funciones (y a otras relacionadas con los nmeros complejos, como demoivre), se puede acceder a travs del men Simplicar Simplicacin compleja Ejemplos ( %i1) ( %o1) c: 1/2+3*%i; 3i + ( %i2) ( %o2) realpart(c); 1 2 ( %i3) ( %o3) imagpart(c); 3 ( %i4) ( %o4) exp(c); e3 i+ 2 ( %i5) ( %o5) demoivre(%); e (i sin 3 + cos 3)
1

1 2

Ejercicios resueltos y actividades Se propondr una tarea en el campus virtual consistente en realizar ejercicios o actividades didcticas relacionadas con este apartado.

3.2 Potencias, races y logaritmos. Otras funciones predenidas

3.2.

Potencias, races y logaritmos. Otras funciones predenidas

Para calcular potencias en Maxima podemos utilizar el operador , que se puede obtener: o bien pulsando las teclas Maysculas + y a continuacin Espacio, o bien manteniendo pulsada la tecla Maysculas y pulsando dos veces la tecla . En el caso de potencias de base e, podemos utilizar la funcin exp. ( %i1) 1/2+(1/2)^2+(1/2)^3; ( %o1) 7 8 ( %i2) ( %o2) is(10^7=5^7*2^7); true ( %i3) ( %o3) is(10^7=5^7+5^7); false ( %i4) ( %o4) (9/2)^3; 729 8 ( %i5) ( %o5) is((a/b)^3=a^3/b^3); true ( %i6) ( %o6) exp(2)-%e^2; 0

Las races cuadradas se pueden escribir utilizando la funcin sqrt o bien elevan1 1 do a 2 . En general, para calcular cualquier raz n-sima, elevamos a n . ( %i7) r:sqrt(2);

8 ( %o7)

Aritmtica

( %i8) ( %o8)

fpprec:25; 25

( %i9) ( %o9)

bfloat(r); 1,414213562373095048801689b0

( %i10) ( %o10)

2197^(1/3); 13

( %i11) ( %o11)

is(sqrt(4)=sqrt(2)+sqrt(2)); false

( %i12) ( %o12)

is(sqrt(4)=sqrt(2)*sqrt(2)); true

Maxima mantiene una losofa muy conservadora desde el punto de vista de la simplicacin de expresiones, en el sentido de que solamente en los casos ms evidentes se aplicarn las propiedades de las operaciones aritmticas, potencias y races, etc. En el resto de los casos, el usuario deber solicitar explcitamente el tipo de accin que desee efectuar. En wxMaxima, el men Simplicar contiene varias de estas acciones, entre ellas Simplicar expresin , Simplicar radicales (que como indica su nombre, aplicar las propiedades de potencias y radicales), Factorizar expresin y Expandir expresin , a las que tambin existen accesos rpidos mediante en los botones [Simplicar], [Simplicar (r)], [Factorizar] y [Expandir]. En el siguiente ejemplo, se dene una expresin (a la que se llama expr), que se simplica mediante los dos algoritmos (Simplicar y simplicar radicales) y despus se vuelve a expandir. ( %i13) expr:a/b+sqrt(a/b); ( %o13) a a + b b

3.2 Potencias, races y logaritmos. Otras funciones predenidas

( %i14) ( %o14)

ratsimp(expr);
a b

b+a b

( %i15) ( %o15)

radcan(expr); a b+a b expand(expr); a + b a b

( %i16) ( %o16)

Otro ejemplo: ( %i17) (a^b)^c; ( %o17) ab ( %i18) ( %o18) ratsimp(%); ab ( %i19) ( %o19) radcan(%); ab c

Para calcular logaritmos neperianos disponemos de la funcin log. ( %i20) x:%e^10; ( %o20) e10 ( %i21) ( %o21) log(x); 10

10

Aritmtica

Maxima no dispone de ninguna funcin para calcular logaritmos en base arbitraria, aunque la podemos denir de la siguiente forma: ( %i22) logb(x,b):=log(x)/log(b)$ ( %i23) /* Calculamos \log_{10}(1000) */ logb(256,2); ( %o23) log 256 log 2 ( %i24) ( %o24) bfloat(%); 8,0b0

Esta funcin sera una buena candidata para ser incorporada en nuestra biblioteca de funciones particular, de manera que la tengamos disponible en todas las sesiones de Maxima. Esto se estudiar con ms detalle en el tema 6. Tambin nos puede resultar interesante contar con una funcin especca para logaritmos en base 10 o en base 2: ( %i25) log2(x):=logb(x,2)$ ( %i26) log10(x):=logb(x,10)$ ( %i27) log10(100)+log2(4),numer; ( %o27) 4,0

En el contexto de los logaritmos, nos pueden resultar tiles las siguientes entradas del men de wxMaxima: SimplicarExpandir logaritmos y Simplicar Contraer logaritmos , cuyos resultados se ilustran en el siguiente ejemplo: ( %i28) log(a*b); ( %o28) log (a b) ( %i29) /* Resultado de expandir logaritmos */ %, logexpand=super; ( %o29) log b + log a ( %i30) /* Resultado de contraer logaritmos */ logcontract(%);

3.3 Divisibilidad ( %o30) log (a b)

11

Maxima cuenta con las funciones trigonomtricas habituales: sin, cos, tan (seno, coseno, tangente), asin, acos, atan (arco seno, arco coseno, arco tangente), csc, sec, cot (cosecante, secante, cotangente), etc. ( %i31) cos(%pi/2); ( %o31) 0 ( %i32) ( %o32) acos(%); 2

wxMaxima dispone, dentro del men Simplicar Simplicacin trigonomtrica , de varias entradas relacionadas con estas funciones: Simplicar trigonometra , Reducir trigonometra , Expandir trigonometra y Forma cannica . Estas funciones se encuentran tambin en los botones [Simplcar (tr)], [Expandir (tr)], [Reducir (tr)], y [FormaCart]. Otras funciones interesantes: abs, valor absoluto. binomial: binomial(m,n) = ... Ejercicios resueltos y actividades Se propondr una tarea en el campus virtual consistente en realizar ejercicios o actividades didcticas relacionadas con este apartado. m n

3.3.

Divisibilidad

La entrada de men Simplicar Factorizar expresin (tambin accesible a travs del botn [Factorizar]) se puede utilizar para descomponer nmeros enteros como producto de nmeros primos. Se puede utilizar la funcin primep para com-

12

Aritmtica

probar si un entero es primo o no. He aqu un ejemplo del resultado de utilizar estas funciones: ( %i33) factor(83421); ( %o33) 32 13 23 31 ( %i34) ( %o34) primep(521); true

Ejercicios resueltos y actividades Se propondr una tarea en el campus virtual consistente en realizar ejercicios o actividades didcticas relacionadas con este apartado.

S-ar putea să vă placă și