| Size: 10427 Comment: minor changes | Size: 10442 Comment:  | 
| Deletions are marked like this. | Additions are marked like this. | 
| Line 8: | Line 8: | 
| {{{ | {{{#!sagecell | 
| Line 69: | Line 69: | 
| {{{ @interact def linear_transformation(theta=slider(0, 2*pi, .1), r=slider(0.1, 2, .1, default=1)): A=matrix([[1,-1],[-1,1/2]]) | {{{#!sagecell @interact def linear_transformation(A=matrix([[1,-1],[-1,1/2]]),theta=slider(0, 2*pi, .1), r=slider(0.1, 2, .1, default=1)): | 
| Line 75: | Line 74: | 
| circles = sum([circle((0,0), radius=i, rgbcolor=(0,0,0)) for i in [1..2]]) print jsmath("v = %s,\; %s v=%s"%(v.n(4),latex(A),w.n(4))) show(v.plot(rgbcolor=(1,0,0))+w.plot(rgbcolor=(0,0,1))+circles,aspect_ratio=1) | circles = sum([circle((0,0), radius=i, color='black') for i in [1..2]]) html("$%s %s=%s$"%tuple(map(latex, [A, v.column().n(4), w.column().n(4)]))) show(v.plot(color='red')+w.plot(color='blue')+circles,aspect_ratio=1) | 
| Line 84: | Line 83: | 
| {{{ | {{{#!sagecell | 
| Line 132: | Line 131: | 
| {{{ | {{{#!sagecell | 
| Line 139: | Line 138: | 
| def svd_vis(a11=slider(-1,1,.05,1),a12=slider(-1,1,.05,1),a21=slider(-1,1,.05,0),a22=slider(-1,1,.05,1),ofs= selector(['Off','On'],label='offset image from domain')): | def svd_vis(a11=slider(-1,1,.05,1),a12=slider(-1,1,.05,1),a21=slider(-1,1,.05,0),a22=slider(-1,1,.05,1),ofs= ('offset image from domain',False)): | 
| Line 143: | Line 142: | 
| if ofs == 'On': | if ofs: | 
| Line 156: | Line 155: | 
| print jsmath("$A = %s  = %s %s %s$"%(latex(my_mat), latex(matrix(rf_low,u.tolist())), latex(matrix(rf_low,2,2,[s[0],0,0,s[1]])), latex(matrix(rf_low,vh.tolist())))) image_ell = parametric_plot(rotell(s,u,t, offset),0,2*pi) | html("$A = %s  = %s %s %s$"%(latex(my_mat), latex(matrix(rf_low,u.tolist())), latex(matrix(rf_low,2,2,[s[0],0,0,s[1]])), latex(matrix(rf_low,vh.tolist())))) image_ell = parametric_plot(rotell(s,u,t, offset),(0,2*pi)) | 
| Line 160: | Line 159: | 
| show(graph_stuff,frame = False,axes=False,figsize=[fsize,fsize]) }}} | show(graph_stuff,frame = False,axes=False,figsize=[fsize,fsize])}}} | 
| Line 166: | Line 164: | 
| {{{ | {{{#!sagecell | 
| Line 170: | Line 168: | 
| var('x') | |
| Line 174: | Line 171: | 
| show(plot(f, pbegin, pend, plot_points = 512), figsize = [4,3]) f_vals = [f(ind) for ind in srange(pbegin, pend,(pend-pbegin)/512.0)] | show(plot(f, (x,pbegin, pend), plot_points = 512), figsize = [4,3]) f_vals = [f(x=ind) for ind in srange(pbegin, pend,(pend-pbegin)/512.0)] | 
| Line 177: | Line 174: | 
| show(list_plot([abs(x) for x in my_fft], plotjoined=True), figsize = [4,3]) | show(list_plot([abs(i) for i in my_fft], plotjoined=True), figsize = [4,3]) | 
| Line 183: | Line 180: | 
| {{{ | {{{#!sagecell | 
Sage Interactions - Linear Algebra
goto interact main page
Contents
Numerical instability of the classical Gram-Schmidt algorithm
by Marshall Hampton (tested by William Stein, who thinks this is really nice!)
 
 
Linear transformations
by Jason Grout
A square matrix defines a linear transformation which rotates and/or scales vectors. In the interact command below, the red vector represents the original vector (v) and the blue vector represents the image w under the linear transformation. You can change the angle and length of v by changing theta and r.
 
 
Gerschgorin Circle Theorem
by Marshall Hampton. This animated version requires convert (imagemagick) to be installed, but it can easily be modified to a static version. The animation illustrates the idea behind the stronger version of Gerschgorin's theorem, which says that if the disks around the eigenvalues are disjoint then there is one eigenvalue per disk. The proof is by continuity of the eigenvalues under a homotopy to a diagonal matrix.
 
 
 
 
Singular value decomposition
by Marshall Hampton
 
 
Discrete Fourier Transform
by Marshall Hampton
 
 
The Gauss-Jordan method for inverting a matrix
by Hristo Inouzhe
 
 
...(goes all the way to invert the matrix)
