mirror of
https://github.com/wassname/simpeg.git
synced 2026-06-30 23:12:05 +08:00
620 lines
79 KiB
Plaintext
620 lines
79 KiB
Plaintext
{
|
|
"metadata": {
|
|
"name": ""
|
|
},
|
|
"nbformat": 3,
|
|
"nbformat_minor": 0,
|
|
"worksheets": [
|
|
{
|
|
"cells": [
|
|
{
|
|
"cell_type": "code",
|
|
"collapsed": false,
|
|
"input": [
|
|
"import SimPEG\n",
|
|
"from SimPEG.mesh import TensorMesh\n",
|
|
"from SimPEG.regularization import Regularization\n",
|
|
"import SimPEG.inverse as inverse\n",
|
|
"from SimPEG.inverse import Minimize\n",
|
|
"import numpy as np\n",
|
|
"import scipy.sparse as sp"
|
|
],
|
|
"language": "python",
|
|
"metadata": {},
|
|
"outputs": [],
|
|
"prompt_number": 1
|
|
},
|
|
{
|
|
"cell_type": "code",
|
|
"collapsed": false,
|
|
"input": [
|
|
"from SimPEG.forward.LinearProblem import example as LinExample\n",
|
|
"\n",
|
|
"prob, m_true = LinExample(1000)\n",
|
|
"M = prob.mesh\n",
|
|
"\n",
|
|
"reg = Regularization(M)\n",
|
|
"opt = inverse.InexactGaussNewton(maxIter=100,maxStep=0.2,debug=False,LSreduction=0.3,maxIterLS=50)\n",
|
|
"opt.remember('f', ('norm_g', lambda M:np.linalg.norm(M.g)))\n",
|
|
"inv = inverse.Inversion(prob,reg,opt,beta0=1e-4,maxIter=2,debug=False)\n",
|
|
"m0 = np.zeros_like(m_true)\n",
|
|
"\n",
|
|
"mrec = inv.run(m0)\n",
|
|
"\n",
|
|
"plt.plot(M.vectorCCx, m_true, 'b-')\n",
|
|
"plt.plot(M.vectorCCx, mrec, 'r-')\n",
|
|
"\n",
|
|
"figure()\n",
|
|
"plot(opt.recall('f'))\n"
|
|
],
|
|
"language": "python",
|
|
"metadata": {},
|
|
"outputs": [
|
|
{
|
|
"output_type": "stream",
|
|
"stream": "stdout",
|
|
"text": [
|
|
"====================== Inexact Gauss Newton ======================\n",
|
|
" # beta phi_d phi_m f |proj(x-g)-x| LS \n",
|
|
"-----------------------------------------------------------------\n",
|
|
" 0 1.00e-04 9.62e+02 0.00e+00 9.62e+02 1.02e+04 0 \n",
|
|
" 1 1.00e-04 6.63e+02 7.73e+02 6.63e+02 8.47e+03 0 \n",
|
|
" 2 1.00e-04 4.15e+02 4.39e+03 4.15e+02 6.63e+03 0 \n",
|
|
" 3 1.00e-04 2.26e+02 6.85e+03 2.27e+02 4.80e+03 0 "
|
|
]
|
|
},
|
|
{
|
|
"output_type": "stream",
|
|
"stream": "stdout",
|
|
"text": [
|
|
"\n",
|
|
" 4 1.00e-04 9.74e+01 1.07e+04 9.84e+01 3.02e+03 0 \n",
|
|
" 5 1.00e-04 2.42e+01 1.64e+04 2.58e+01 1.35e+03 0 \n",
|
|
" 6 1.00e-04 1.06e+00 2.34e+04 3.39e+00 9.21e+00 0 \n",
|
|
"------------------------- STOP! -------------------------\n",
|
|
"1 : |fc-fOld| = 2.2421e+01 <= tolF*(1+|f0|) = 9.6325e+01\n",
|
|
"0 : |xc-x_last| = 2.1351e+00 <= tolX*(1+|x0|) = 1.0000e-01\n",
|
|
"0 : |proj(x-g)-x| = 9.2073e+00 <= tolG = 1.0000e-01\n",
|
|
"0 : |proj(x-g)-x| = 9.2073e+00 <= 1e3*eps = 1.0000e-02\n",
|
|
"0 : maxIter = 100 <= iter = 6\n",
|
|
"1 : phi_d = 1.0595e+00 <= phi_d_target = 2.0000e+01 \n",
|
|
"------------------------- DONE! -------------------------\n",
|
|
"-------------------------STOP!-------------------------\n",
|
|
"0 : maxIter = 2 <= iter = 1\n",
|
|
"1 : phi_d = 1.0595e+00 <= phi_d_target = 2.0000e+01 \n",
|
|
"-------------------------DONE!-------------------------\n"
|
|
]
|
|
},
|
|
{
|
|
"metadata": {},
|
|
"output_type": "pyout",
|
|
"prompt_number": 3,
|
|
"text": [
|
|
"[<matplotlib.lines.Line2D at 0x10ebf9f10>]"
|
|
]
|
|
},
|
|
{
|
|
"metadata": {},
|
|
"output_type": "display_data",
|
|
"png": "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\nxXsAAAAASUVORK5CYII=\n",
|
|
"text": [
|
|
"<matplotlib.figure.Figure at 0x10ecafa10>"
|
|
]
|
|
},
|
|
{
|
|
"metadata": {},
|
|
"output_type": "display_data",
|
|
"png": "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\n",
|
|
"text": [
|
|
"<matplotlib.figure.Figure at 0x10ecbec90>"
|
|
]
|
|
}
|
|
],
|
|
"prompt_number": 3
|
|
},
|
|
{
|
|
"cell_type": "code",
|
|
"collapsed": false,
|
|
"input": [
|
|
"FUN = SimPEG.tests.getQuadratic(sp.identity(2),np.array([-5,-5]))\n",
|
|
"# FUN = SimPEG.tests.Rosenbrock\n",
|
|
"\n",
|
|
"f = FUN(np.array([1,2]))\n",
|
|
"print f\n",
|
|
"n,l,u = 50,-10,10\n",
|
|
"I = np.zeros((n,n))\n",
|
|
"X = np.linspace(l,u,n)\n",
|
|
"for i, x in enumerate(X):\n",
|
|
" for j, y in enumerate(X):\n",
|
|
" f, g, H = FUN(np.array([x,y]))\n",
|
|
" I[i,j] = f\n",
|
|
"\n",
|
|
"colorbar(contourf(X,X, I.T))\n",
|
|
"\n",
|
|
"GN = inverse.GaussNewton()\n",
|
|
"xopt = GN.minimize(FUN,np.array([0,0]))\n",
|
|
"print xopt"
|
|
],
|
|
"language": "python",
|
|
"metadata": {},
|
|
"outputs": [
|
|
{
|
|
"output_type": "stream",
|
|
"stream": "stdout",
|
|
"text": [
|
|
"(-12.5, array([-4., -3.]), <2x2 sparse matrix of type '<type 'numpy.float64'>'\n",
|
|
"\twith 2 stored elements (1 diagonals) in DIAgonal format>)\n",
|
|
"=========== Gauss Newton ==========="
|
|
]
|
|
},
|
|
{
|
|
"output_type": "stream",
|
|
"stream": "stdout",
|
|
"text": [
|
|
"\n",
|
|
" # f |proj(x-g)-x| LS \n",
|
|
"-----------------------------------\n",
|
|
" 0 0.00e+00 7.07e+00 0 \n",
|
|
" 1 -2.50e+01 0.00e+00 0 \n",
|
|
"------------------------- STOP! -------------------------\n",
|
|
"0 : |fc-fOld| = 2.5000e+01 <= tolF*(1+|f0|) = 1.0000e-01\n",
|
|
"0 : |xc-x_last| = 7.0711e+00 <= tolX*(1+|x0|) = 1.0000e-01\n",
|
|
"1 : |proj(x-g)-x| = 0.0000e+00 <= tolG = 1.0000e-01\n",
|
|
"1 : |proj(x-g)-x| = 0.0000e+00 <= 1e3*eps = 1.0000e-02\n",
|
|
"0 : maxIter = 20 <= iter = 1\n",
|
|
"------------------------- DONE! -------------------------\n",
|
|
"[ 5. 5.]\n"
|
|
]
|
|
},
|
|
{
|
|
"metadata": {},
|
|
"output_type": "display_data",
|
|
"png": "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\nBFYAAAAASUVORK5CYII=\n",
|
|
"text": [
|
|
"<matplotlib.figure.Figure at 0x10ebd9750>"
|
|
]
|
|
}
|
|
],
|
|
"prompt_number": 5
|
|
},
|
|
{
|
|
"cell_type": "code",
|
|
"collapsed": false,
|
|
"input": [
|
|
"opt = inverse.ProjectedGradient(maxIter=50,maxStep=np.inf, maxIterLS=20, debug=False)\n",
|
|
"opt.remember('f')\n",
|
|
"opt.lower = -2\n",
|
|
"opt.upper = 2\n",
|
|
"opt.minimize(FUN,np.array([0,0]))"
|
|
],
|
|
"language": "python",
|
|
"metadata": {},
|
|
"outputs": [
|
|
{
|
|
"output_type": "stream",
|
|
"stream": "stdout",
|
|
"text": [
|
|
"======================= Projected Gradient =======================\n",
|
|
" # f |proj(x-g)-x| LS itType aSet bSet Comment\n",
|
|
"------------------------------------------------------------------\n",
|
|
" 0 0.00e+00 2.83e+00 0 SD 0 0 \n",
|
|
" 1 -1.60e+01 0.00e+00 0 SD 2 2 \n",
|
|
"------------------------- STOP! -------------------------\n",
|
|
"0 : |fc-fOld| = 1.6000e+01 <= tolF*(1+|f0|) = 1.0000e-01\n",
|
|
"0 : |xc-x_last| = 2.8284e+00 <= tolX*(1+|x0|) = 1.0000e-01\n",
|
|
"1 : |proj(x-g)-x| = 0.0000e+00 <= tolG = 1.0000e-01\n",
|
|
"1 : |proj(x-g)-x| = 0.0000e+00 <= 1e3*eps = 1.0000e-02\n",
|
|
"0 : maxIter = 50 <= iter = 1\n",
|
|
"1 : probSize = 2 <= bindingSet = 2\n",
|
|
"------------------------- DONE! -------------------------\n"
|
|
]
|
|
},
|
|
{
|
|
"metadata": {},
|
|
"output_type": "pyout",
|
|
"prompt_number": 7,
|
|
"text": [
|
|
"array([ 2., 2.])"
|
|
]
|
|
}
|
|
],
|
|
"prompt_number": 7
|
|
},
|
|
{
|
|
"cell_type": "code",
|
|
"collapsed": false,
|
|
"input": [
|
|
"opt = inverse.ProjectedGradient(maxIter=50, maxStep=0.3,debug=False, maxIterLS=20, tolCG=1e-5, maxIterCG=1000)\n",
|
|
"opt.lower, opt.upper = -0.4, 0.9\n",
|
|
"opt.remember('f', 'xc', ('norm_g', lambda M: np.linalg.norm(M.g)), 'phi_d', 'phi_m')\n",
|
|
"inv = inverse.Inversion(prob,reg,opt,beta0=1e-3,debug=False)\n",
|
|
"inv.remember(('phi_d',lambda I:I.opt.recall('phi_d')),('phi_m',lambda I:I.opt.recall('phi_m')))\n",
|
|
"m0 = np.zeros_like(m_true)\n",
|
|
"mrecB = inv.run(m0)"
|
|
],
|
|
"language": "python",
|
|
"metadata": {},
|
|
"outputs": [
|
|
{
|
|
"output_type": "stream",
|
|
"stream": "stdout",
|
|
"text": [
|
|
"====================================== Projected Gradient ======================================\n",
|
|
" # beta phi_d phi_m f |proj(x-g)-x| LS itType aSet bSet Comment\n",
|
|
"------------------------------------------------------------------------------------------------\n",
|
|
" 0 1.00e-03 9.62e+02 0.00e+00 9.62e+02 2.14e+01 0 SD 0 0 \n",
|
|
" 1 1.00e-03 9.53e+02 8.49e-03 9.53e+02 2.18e+01 9 SD 0 0 \n",
|
|
" 2 1.00e-03 5.32e+02 1.42e+03 5.33e+02 2.20e+01 0 .CG. 0 0 "
|
|
]
|
|
},
|
|
{
|
|
"output_type": "stream",
|
|
"stream": "stdout",
|
|
"text": [
|
|
"\n",
|
|
" 3 1.00e-03 2.32e+02 5.66e+03 2.38e+02 2.26e+01 0 .CG. 0 0 "
|
|
]
|
|
},
|
|
{
|
|
"output_type": "stream",
|
|
"stream": "stdout",
|
|
"text": [
|
|
"\n",
|
|
" 4 1.00e-03 1.29e+02 8.85e+03 1.38e+02 2.30e+01 1 .CG. 0 0 "
|
|
]
|
|
},
|
|
{
|
|
"output_type": "stream",
|
|
"stream": "stdout",
|
|
"text": [
|
|
"\n",
|
|
" 5 1.00e-03 1.10e+02 9.74e+03 1.20e+02 2.15e+01 3 .CG. 22 22 "
|
|
]
|
|
},
|
|
{
|
|
"output_type": "stream",
|
|
"stream": "stdout",
|
|
"text": [
|
|
"\n",
|
|
" 6 1.00e-03 1.09e+02 9.74e+03 1.19e+02 2.36e+01 10 SD 22 0 Stop SD\n",
|
|
" 7 1.00e-03 7.65e+01 1.33e+04 8.98e+01 2.21e+01 1 .CG. 85 75 "
|
|
]
|
|
},
|
|
{
|
|
"output_type": "stream",
|
|
"stream": "stdout",
|
|
"text": [
|
|
"\n",
|
|
" 8 1.00e-03 5.11e+01 1.33e+04 6.44e+01 2.38e+01 9 SD 75 3 \n",
|
|
" 9 1.00e-03 5.07e+01 1.33e+04 6.41e+01 2.11e+01 12 SD 4 4 \n",
|
|
" 10 1.00e-03 5.06e+01 1.33e+04 6.40e+01 2.20e+01 12 SD 17 9 Stop SD\n",
|
|
" 11 1.00e-03 5.04e+01 1.34e+04 6.37e+01 2.05e+01 8 .CG. 85 81 "
|
|
]
|
|
},
|
|
{
|
|
"output_type": "stream",
|
|
"stream": "stdout",
|
|
"text": [
|
|
"\n",
|
|
" 12 1.00e-03 5.03e+01 1.34e+04 6.37e+01 1.65e+01 13 SD 81 26 \n",
|
|
" 13 1.00e-03 5.03e+01 1.34e+04 6.37e+01 1.67e+01 15 SD 30 30 \n",
|
|
" 14 1.00e-03 5.03e+01 1.34e+04 6.36e+01 1.42e+01 15 SD 84 84 Stop SD\n",
|
|
" 15 1.00e-03 2.65e+01 2.26e+04 4.91e+01 2.52e+01 0 .CG. 190 50 "
|
|
]
|
|
},
|
|
{
|
|
"output_type": "stream",
|
|
"stream": "stdout",
|
|
"text": [
|
|
"\n",
|
|
" 16 1.00e-03 1.51e+01 2.26e+04 3.77e+01 2.24e+01 10 SD 50 1 \n",
|
|
"------------------------- STOP! -------------------------\n",
|
|
"1 : |fc-fOld| = 1.1392e+01 <= tolF*(1+|f0|) = 9.6325e+01\n",
|
|
"1 : |xc-x_last| = 3.4809e-03 <= tolX*(1+|x0|) = 1.0000e-01\n",
|
|
"0 : |proj(x-g)-x| = 2.2369e+01 <= tolG = 1.0000e-01\n",
|
|
"0 : |proj(x-g)-x| = 2.2369e+01 <= 1e3*eps = 1.0000e-02\n",
|
|
"0 : maxIter = 50 <= iter = 16\n",
|
|
"0 : probSize = 1000 <= bindingSet = 1\n",
|
|
"1 : phi_d = 1.5077e+01 <= phi_d_target = 2.0000e+01 \n",
|
|
"------------------------- DONE! -------------------------\n",
|
|
"-------------------------STOP!-------------------------\n",
|
|
"0 : maxIter = 10 <= iter = 1\n",
|
|
"1 : phi_d = 1.5077e+01 <= phi_d_target = 2.0000e+01 \n",
|
|
"-------------------------DONE!-------------------------\n"
|
|
]
|
|
}
|
|
],
|
|
"prompt_number": 8
|
|
},
|
|
{
|
|
"cell_type": "code",
|
|
"collapsed": false,
|
|
"input": [
|
|
"# First set up the figure, the axis, and the plot element we want to animate\n",
|
|
"fig = plt.figure()\n",
|
|
"ax = plt.axes()\n",
|
|
"ax.plot(M.vectorCCx, m_true, 'b-')\n",
|
|
"txt = plt.text(0.8,0.9,'')\n",
|
|
"line, = ax.plot([], [], 'r-', lw=1)\n",
|
|
"\n",
|
|
"def animate(i):\n",
|
|
" txt.set_text('iteration %d'%i)\n",
|
|
" line.set_data(M.vectorCCx, np.array(opt.recall('xc')[i]))\n",
|
|
"\n",
|
|
"SimPEG.utils.animate(fig, animate, frames=len(opt.recall('xc')))"
|
|
],
|
|
"language": "python",
|
|
"metadata": {},
|
|
"outputs": [
|
|
{
|
|
"html": [
|
|
"<video controls loop>\n",
|
|
" <source src=\"data:video/x-m4v;base64,AAAAIGZ0eXBpc29tAAACAGlzb21pc28yYXZjMW1wNDEAAAAIZnJlZQAALXFtZGF0AAACoQYF//+d\n",
|
|
"3EXpvebZSLeWLNgg2SPu73gyNjQgLSBjb3JlIDEyNSAtIEguMjY0L01QRUctNCBBVkMgY29kZWMg\n",
|
|
"LSBDb3B5bGVmdCAyMDAzLTIwMTIgLSBodHRwOi8vd3d3LnZpZGVvbGFuLm9yZy94MjY0Lmh0bWwg\n",
|
|
"LSBvcHRpb25zOiBjYWJhYz0xIHJlZj0zIGRlYmxvY2s9MTowOjAgYW5hbHlzZT0weDM6MHgxMTMg\n",
|
|
"bWU9aGV4IHN1Ym1lPTcgcHN5PTEgcHN5X3JkPTEuMDA6MC4wMCBtaXhlZF9yZWY9MSBtZV9yYW5n\n",
|
|
"ZT0xNiBjaHJvbWFfbWU9MSB0cmVsbGlzPTEgOHg4ZGN0PTEgY3FtPTAgZGVhZHpvbmU9MjEsMTEg\n",
|
|
"ZmFzdF9wc2tpcD0xIGNocm9tYV9xcF9vZmZzZXQ9LTIgdGhyZWFkcz0xMiBsb29rYWhlYWRfdGhy\n",
|
|
"ZWFkcz0yIHNsaWNlZF90aHJlYWRzPTAgbnI9MCBkZWNpbWF0ZT0xIGludGVybGFjZWQ9MCBibHVy\n",
|
|
"YXlfY29tcGF0PTAgY29uc3RyYWluZWRfaW50cmE9MCBiZnJhbWVzPTMgYl9weXJhbWlkPTIgYl9h\n",
|
|
"ZGFwdD0xIGJfYmlhcz0wIGRpcmVjdD0xIHdlaWdodGI9MSBvcGVuX2dvcD0wIHdlaWdodHA9MiBr\n",
|
|
"ZXlpbnQ9MjUwIGtleWludF9taW49MjAgc2NlbmVjdXQ9NDAgaW50cmFfcmVmcmVzaD0wIHJjX2xv\n",
|
|
"b2thaGVhZD00MCByYz1jcmYgbWJ0cmVlPTEgY3JmPTIzLjAgcWNvbXA9MC42MCBxcG1pbj0wIHFw\n",
|
|
"bWF4PTY5IHFwc3RlcD00IGlwX3JhdGlvPTEuNDAgYXE9MToxLjAwAIAAAAlFZYiEAFf9EwAD0rwK\n",
|
|
"a/s12U1hg0FMgMmMOVNcwAAAAwANFchWCs4PnSPLHgxFeZ2MBPwOINxDCInVnrlTnaSkcTqCnVwZ\n",
|
|
"C32ci4e4iEXqjfabfM26fKQmxb+v+i35CIUYvwFed9H6aEX+hZ9g90vyHpRRW3xSWaZ4rATX4Ful\n",
|
|
"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\n",
|
|
"\" type=\"video/mp4\">\n",
|
|
" Your browser does not support the video tag.\n",
|
|
"</video>"
|
|
],
|
|
"metadata": {},
|
|
"output_type": "pyout",
|
|
"prompt_number": 9,
|
|
"text": [
|
|
"<matplotlib.animation.FuncAnimation at 0x10ee35450>"
|
|
]
|
|
}
|
|
],
|
|
"prompt_number": 9
|
|
},
|
|
{
|
|
"cell_type": "code",
|
|
"collapsed": false,
|
|
"input": [
|
|
"plot(opt.recall('phi_d'))"
|
|
],
|
|
"language": "python",
|
|
"metadata": {},
|
|
"outputs": [
|
|
{
|
|
"metadata": {},
|
|
"output_type": "pyout",
|
|
"prompt_number": 10,
|
|
"text": [
|
|
"[<matplotlib.lines.Line2D at 0x10eb01450>]"
|
|
]
|
|
},
|
|
{
|
|
"metadata": {},
|
|
"output_type": "display_data",
|
|
"png": "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\n",
|
|
"text": [
|
|
"<matplotlib.figure.Figure at 0x11030ec90>"
|
|
]
|
|
}
|
|
],
|
|
"prompt_number": 10
|
|
}
|
|
],
|
|
"metadata": {}
|
|
}
|
|
]
|
|
} |