solexjuny.mws

Tipus 86183

1.

Feu un procediment o busqueu una funcio que aplicada a una llista que tingui entre els seus elements altres llistes.....

> restart;

> with(ListTools);

Warning, the assigned name Group now has a global binding

[BinaryPlace, BinarySearch, Categorize, DotProduct,...
[BinaryPlace, BinarySearch, Categorize, DotProduct,...

> ?Flatten

> llis:=[[[a,[s]],[d,[f,g]]],[h,j],[k,l]];

llis := [[[a, [s]], [d, [f, g]]], [h, j], [k, l]]

> Flatten(llis);

[a, s, d, f, g, h, j, k, l]

A ma es pot fer

> elems:= proc(l)
local ll,lll;
ll:=l;
lll:=map(op,l);
while ll<> lll do
ll:=lll;
lll:=map(op,ll);
end do;
end proc;

elems := proc (l) local ll, lll; ll := l; lll := ma...

> elems(llis);

[a, s, d, f, g, h, j, k, l]

2.

> restart;

a)

Feu un grafic de la funcio f(x) = 1/(x^2-4) per a ...

> f:=x->1/(x^2-4);

f := proc (x) options operator, arrow; 1/(x^2-4) en...

> plot(f(x),x=-5..5,-6..6,discont=true, scaling=constrained);

[Maple Plot]

b)

Determineu una primitiva g(x) de f(x) i dibuixeu-ne el grafic....

> int(f(x),x);

1/4*ln(x-2)-1/4*ln(x+2)

> g:=x->1/4*ln(x-2)-1/4*ln(x+2);

g := proc (x) options operator, arrow; 1/4*ln(x-2)-...

> plot(g(x),x=-5..5,-4..4,scaling=constrained);

[Maple Plot]

Si volem que funcioni, s'ha de definir g(x) d'una altra manera.

> g1:=x->1/4*ln(abs((x-2)/(x+2)));

g1 := proc (x) options operator, arrow; 1/4*ln(abs(...

> plot(g1,-5..5,-3..3,discont=true);

[Maple Plot]

Les punxes en -2 i 2 son els infinits de la derivada de g1(x) !!!!!

c)

Calculeu l'area limitada pel grafic de f(x) i l'eix d'abscisses per a x entre -1.5 i 1.5

> int(f(x),x=-3/2..3/2);

-1/2*ln(7)

> g1(3/2)-g1(-3/2);

-1/2*ln(7)

> g(3/2)-g(-3/2);

-1/2*ln(2)-1/2*ln(7/2)

> simplify(%);

-1/2*ln(7)

3.

> restart;

Feu un procediment que tingui com arguments les coordenades de dos punts del pla i doni com a resultat.....

> quadrats:= proc(A,B)
local C1,C2,C3,D1,D2,D3,v,vp,vd;
v:=B-A;
vp:=[v[2],-v[1]];
C1:=B+vp;D1:=A+vp;
C2:=B-vp;D2:=A-vp;
vd:= 1/2*(C1-A);
C3:= A+vd;D3:=B-vd;
[[A,B,C1,D1],[A,B,C2,D2],[A,C3,B,D3]];
end proc;

quadrats := proc (A, B) local C1, C2, C3, D1, D2, D...
quadrats := proc (A, B) local C1, C2, C3, D1, D2, D...
quadrats := proc (A, B) local C1, C2, C3, D1, D2, D...
quadrats := proc (A, B) local C1, C2, C3, D1, D2, D...
quadrats := proc (A, B) local C1, C2, C3, D1, D2, D...
quadrats := proc (A, B) local C1, C2, C3, D1, D2, D...
quadrats := proc (A, B) local C1, C2, C3, D1, D2, D...
quadrats := proc (A, B) local C1, C2, C3, D1, D2, D...
quadrats := proc (A, B) local C1, C2, C3, D1, D2, D...
quadrats := proc (A, B) local C1, C2, C3, D1, D2, D...
quadrats := proc (A, B) local C1, C2, C3, D1, D2, D...
quadrats := proc (A, B) local C1, C2, C3, D1, D2, D...
quadrats := proc (A, B) local C1, C2, C3, D1, D2, D...

Provant-ho amb dos punts qualssevol

> qq:=quadrats([1,2],[-2,3]);

qq := [[[1, 2], [-2, 3], [-1, 6], [2, 5]], [[1, 2],...

> plot([[op(qq[1]),[1,2]],[op(qq[2]),[1,2]],[op(qq[3]),[1,2]]],scaling=constrained);

[Maple Plot]

Tipus 39051

1.

> restart;

Sigui R la regio del pla determinada per les desigualtats.....

a)

> with(plots):

Warning, the name changecoords has been redefined

> desigs:={x>=0,y>=0,x-y<=3/2,x+3*y<=2,x+y>=1};

desigs := {0 <= x, 0 <= y, x-y <= 3/2, x+3*y <= 2, ...

> inequal(desigs,x=-1..2,y=-1..2,
optionsexcluded=(color=white),
optionsclosed=(color=red));

[Maple Plot]

b)

Calculeu les coordenades dels vertexs de la regio R .

> s1:=solve({x+y=1,y=0});

s1 := {y = 0, x = 1}

> p1:=subs(s1,[x,y]);

p1 := [1, 0]

> s2:=solve({x+y=1,x+3*y = 2});

s2 := {x = 1/2, y = 1/2}

> p2:=subs(s2,[x,y]);

p2 := [1/2, 1/2]

> s3:=solve({y=0,x-y = 3/2});

s3 := {y = 0, x = 3/2}

> p3:=subs(s3,[x,y]);

p3 := [3/2, 0]

> s4:=solve({x-y = 3/2,x+3*y = 2});

s4 := {x = 13/8, y = 1/8}

> p4:=subs(s4,[x,y]);

p4 := [13/8, 1/8]

> plot([p1,p3,p4,p2,p1],0..2,0..1,scaling=constrained,style=line);

[Maple Plot]

2.

> restart;

a)

Feu un grafic de la funcio f(x) = 1/(x^2+7*x+12) per a x entre -5 i 0 .

> f:=x->1/(x^2+7*x+12);

f := proc (x) options operator, arrow; 1/(x^2+7*x+1...

> plot(f(x),x=-5..0,-10..6,discont=true);

[Maple Plot]

b)

Determineu una primitiva g(x) de f(x) i dibuixeu-ne el seu grafic....

> int(f(x),x);

-ln(x+4)+ln(x+3)

> g:= x-> -ln(x+4)+ln(x+3);

g := proc (x) options operator, arrow; -ln(x+4)+ln(...

> plot(g(x),x=-5..0,-5..5);

[Maple Plot]

Si es vol que funcioni s'ha de definir g(x) d'una altra forma

> g1:=x->ln(abs((x+3)/(x+4)));

g1 := proc (x) options operator, arrow; ln(abs((x+3...

> plot(g1(x),x=-5..0);

[Maple Plot]

Les punxes en -4 i -3 corresponen als valors on la derivada de g(x) es infinita

c)

Calculeu l'area ...... entre -3.2 i -3.6

> int(f(x),x=-36/10..-32/10);

-ln(2)-ln(3)

> simplify(g1(-32/10)-g1(-36/10));

-ln(2)-ln(3)

> simplify(g(-32/10)-g(-36/10));

-ln(2)-ln(3)

3.

> restart;

a)

Feu un procediment que determini si quatre punts ordenats del pla son els vertexs consecutius d'un quadrat

> sonquadrat:= proc(A,B,C,D)
local c1,c2,c3,v1,v2,v3,v4;
v1:=B-A;v2:=C-B;v3:=D-C;v4:=A-D;
c1:= evalb(v1=-v3);
c2:= evalb(v2=-v4);
c3:= evalb(v1[1]*v2[1]+v1[2]*v2[2]=0);
if (c1 and c2 and c3) then printf("Quadrat");return(true) else printf("No quadrat");return(false) end if;
end proc;

sonquadrat := proc (A, B, C, D) local c1, c2, c3, v...
sonquadrat := proc (A, B, C, D) local c1, c2, c3, v...
sonquadrat := proc (A, B, C, D) local c1, c2, c3, v...
sonquadrat := proc (A, B, C, D) local c1, c2, c3, v...
sonquadrat := proc (A, B, C, D) local c1, c2, c3, v...
sonquadrat := proc (A, B, C, D) local c1, c2, c3, v...
sonquadrat := proc (A, B, C, D) local c1, c2, c3, v...
sonquadrat := proc (A, B, C, D) local c1, c2, c3, v...
sonquadrat := proc (A, B, C, D) local c1, c2, c3, v...
sonquadrat := proc (A, B, C, D) local c1, c2, c3, v...
sonquadrat := proc (A, B, C, D) local c1, c2, c3, v...

> sonquadrat([0,0],[1,0],[0,1],[1,1]);

No quadrat

false

> sonquadrat([0,0],[0,1],[1,1],[1,0]);

Quadrat

true

> plot([[0,0],[1,0],[0,1],[1,1],[0,0]],scaling=constrained);

[Maple Plot]

> plot([[0,0],[0,1],[1,1],[1,0],[0,0]],scaling=constrained);

[Maple Plot]

b)

Utilitzant el procediment anterior com a punt de partida.....

> sonquadrat2:= proc(a,b,c,d)
local sonquadrat1;
sonquadrat1:=proc(A,B,C,D)
local c1,c2,c3,v1,v2,v3,v4;
v1:=B-A;v2:=C-B;v3:=D-C;v4:=A-D;
c1:= evalb(v1=-v3);
c2:= evalb(v2=-v4);
c3:= evalb(v1[1]*v2[1]+v1[2]*v2[2]=0);
if (c1 and c2 and c3) then return(true) else ;return(false) end if;
end proc;
if (sonquadrat1(a,b,c,d) or sonquadrat1(a,b,d,c) or sonquadrat1(a,c,b,d)) then
true else
false
end if;
end proc;

sonquadrat2 := proc (a, b, c, d) local sonquadrat1;...
sonquadrat2 := proc (a, b, c, d) local sonquadrat1;...
sonquadrat2 := proc (a, b, c, d) local sonquadrat1;...
sonquadrat2 := proc (a, b, c, d) local sonquadrat1;...
sonquadrat2 := proc (a, b, c, d) local sonquadrat1;...
sonquadrat2 := proc (a, b, c, d) local sonquadrat1;...
sonquadrat2 := proc (a, b, c, d) local sonquadrat1;...
sonquadrat2 := proc (a, b, c, d) local sonquadrat1;...
sonquadrat2 := proc (a, b, c, d) local sonquadrat1;...
sonquadrat2 := proc (a, b, c, d) local sonquadrat1;...
sonquadrat2 := proc (a, b, c, d) local sonquadrat1;...
sonquadrat2 := proc (a, b, c, d) local sonquadrat1;...
sonquadrat2 := proc (a, b, c, d) local sonquadrat1;...
sonquadrat2 := proc (a, b, c, d) local sonquadrat1;...
sonquadrat2 := proc (a, b, c, d) local sonquadrat1;...

> sonquadrat2([0,0],[1,1],[0,1],[1,0]);

true

c)

Representeu els quadrilaters determinats per les families de punts [[1, 3], [5, 0], [-2, -1], [2, -4]] , [[1, -1], [2, 3], [4, 1/2], [-1/2, 3/2]] , [[3, -1], [13/2, -3/2], [7, 2], [7/2, 5/2]] i comproveu el funcionament de les dues funcions de l'apartat anterior

> l1:= [1, 3], [5, 0], [-2, -1], [2, -4];
l2:= [1, -1], [2, 3], [4, 1/2], [-1/2, 3/2];
l3:= [3, -1], [13/2, -3/2], [7, 2], [7/2, 5/2];

l1 := [1, 3], [5, 0], [-2, -1], [2, -4]

l2 := [1, -1], [2, 3], [4, 1/2], [-1/2, 3/2]

l3 := [3, -1], [13/2, -3/2], [7, 2], [7/2, 5/2]

> plot([l1,l1[1]],scaling=constrained);
sonquadrat(l1);
sonquadrat2(l1);

[Maple Plot]

No quadrat

false

true

> plot([l2,l2[1]],scaling=constrained);
sonquadrat(l2);
sonquadrat2(l2);

[Maple Plot]

No quadrat

false

false

> plot([l3,l3[1]],scaling=constrained);
sonquadrat(l3);
sonquadrat2(l3);

[Maple Plot]

Quadrat

true

true

Tipus 47132

1.

Es el mateix que el 3. del tipus 86183

2.

Es exactament el mateix que el 2. del tipus 39051. L'unic canvi correspon als limits d'integracio de l'apartat c)

> int(f(x),x=-375/100..-325/100);

-2*ln(3)

3.

El problema coincideix amb el 1. del tipus 86183

Tipus 94264

1.

Es el mateix exercici que el 3. del tipus 39051. Nomes canviaran les dades dels punts en l'apartat c)

> l1:= [[1,-1],[2,3],[7/2,1/2],[-1/2,3/2]];
l2:= [[1,3],[5,0],[8,4],[4,7]];
l3:= [[2,3],[35/2,7/2],[17,19],[3/2,18]];

l1 := [[1, -1], [2, 3], [7/2, 1/2], [-1/2, 3/2]]

l2 := [[1, 3], [5, 0], [8, 4], [4, 7]]

l3 := [[2, 3], [35/2, 7/2], [17, 19], [3/2, 18]]

> plot([[op(l1),l1[1]]],scaling=constrained);

[Maple Plot]

> sonquadrat(op(l1));sonquadrat2(op(l1));

No quadrat

false

true

> plot([[op(l2),l2[1]]],scaling=constrained);

[Maple Plot]

> sonquadrat(op(l2));sonquadrat2(op(l2));

Quadrat

true

true

> plot([[op(l3),l3[1]]],scaling=constrained);

[Maple Plot]

> sonquadrat(op(l3));sonquadrat2(op(l3));

No quadrat

false

false

2.

Es el mateix exercici que el 2. del tipus 86183. Nomes canvien els limits d'integracio de l'apartat c)

> int(f(x),x=-7/4..7/4);

-1/2*ln(3)-1/2*ln(5)

3.

Es exactament el mateix problema que el 1. del tipus 39051 .