File: ex1.c.html

package info (click to toggle)
petsc 3.7.5%2Bdfsg1-4
  • links: PTS, VCS
  • area: main
  • in suites: stretch
  • size: 163,864 kB
  • ctags: 618,438
  • sloc: ansic: 515,133; python: 29,793; makefile: 20,458; fortran: 18,998; cpp: 6,515; f90: 3,914; sh: 1,012; xml: 621; objc: 445; csh: 240; java: 13
file content (106 lines) | stat: -rw-r--r-- 9,172 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
<center><a href="ex1.c">Actual source code: ex1.c</a></center><br>

<html>
<head> <link rel="canonical" href="http://www.mcs.anl.gov/petsc/petsc-current/tutorials/python/ex1.c.html" />
<title></title>
<meta name="generator" content="c2html 0.9.4">
<meta name="date" content="2017-01-01T16:37:10+00:00">
</head>

<body bgcolor="#FFFFFF">
   <div id="version" align=right><b>petsc-3.7.5 2017-01-01</b></div>
   <div id="bugreport" align=right><a href="mailto:petsc-maint@mcs.anl.gov?subject=Typo or Error in Documentation &body=Please describe the typo or error in the documentation: petsc-3.7.5 v3.7.5 tutorials/python/ex1.c.html "><small>Report Typos and Errors</small></a></div>
<pre width="80"><a name="line1">  1: </a><font color="#A020F0">#include &lt;petscksp.h&gt;</font>

<a name="line3">  3: </a><font color="#B22222">/* ------------------------------------------------------- */</font>

<a name="line7">  7: </a><strong><font color="#4169E1"><a name="RunTest"></a><a href="tutorials/../../docs/manualpages/Sys/PetscErrorCode.html#PetscErrorCode">PetscErrorCode</a> RunTest(void)</font></strong>
<a name="line8">  8: </a>{
<a name="line9">  9: </a>  <a href="tutorials/../../docs/manualpages/Sys/PetscInt.html#PetscInt">PetscInt</a>       N    = 100;
<a name="line10"> 10: </a>  <a href="tutorials/../../docs/manualpages/Sys/PetscBool.html#PetscBool">PetscBool</a>      draw = <a href="tutorials/../../docs/manualpages/Sys/PETSC_FALSE.html#PETSC_FALSE">PETSC_FALSE</a>;
<a name="line11"> 11: </a>  <a href="tutorials/../../docs/manualpages/Sys/PetscReal.html#PetscReal">PetscReal</a>      rnorm;
<a name="line12"> 12: </a>  <a href="tutorials/../../docs/manualpages/Mat/Mat.html#Mat">Mat</a>            A;
<a name="line13"> 13: </a>  <a href="tutorials/../../docs/manualpages/Vec/Vec.html#Vec">Vec</a>            b,x,r;
<a name="line14"> 14: </a>  <a href="tutorials/../../docs/manualpages/KSP/KSP.html#KSP">KSP</a>            ksp;
<a name="line15"> 15: </a>  <a href="tutorials/../../docs/manualpages/PC/PC.html#PC">PC</a>             pc;


<a name="line20"> 20: </a>  <a href="tutorials/../../docs/manualpages/Sys/PetscOptionsGetInt.html#PetscOptionsGetInt">PetscOptionsGetInt</a>(NULL,NULL,<font color="#666666">"-N"</font>,&amp;N,NULL);
<a name="line21"> 21: </a>  <a href="tutorials/../../docs/manualpages/Sys/PetscOptionsGetBool.html#PetscOptionsGetBool">PetscOptionsGetBool</a>(NULL,NULL,<font color="#666666">"-draw"</font>,&amp;draw,NULL);

<a name="line23"> 23: </a>  <a href="tutorials/../../docs/manualpages/Mat/MatCreate.html#MatCreate">MatCreate</a>(<a href="tutorials/../../docs/manualpages/Sys/PETSC_COMM_WORLD.html#PETSC_COMM_WORLD">PETSC_COMM_WORLD</a>,&amp;A);
<a name="line24"> 24: </a>  <a href="tutorials/../../docs/manualpages/Mat/MatSetSizes.html#MatSetSizes">MatSetSizes</a>(A,<a href="tutorials/../../docs/manualpages/Sys/PETSC_DECIDE.html#PETSC_DECIDE">PETSC_DECIDE</a>,<a href="tutorials/../../docs/manualpages/Sys/PETSC_DECIDE.html#PETSC_DECIDE">PETSC_DECIDE</a>,N,N);
<a name="line25"> 25: </a>  <a href="tutorials/../../docs/manualpages/Mat/MatSetType.html#MatSetType">MatSetType</a>(A,MATPYTHON);
<a name="line26"> 26: </a>  <a href="tutorials/../../docs/manualpages/Mat/MatPythonSetType.html#MatPythonSetType">MatPythonSetType</a>(A,<font color="#666666">"example1.py:Laplace1D"</font>);
<a name="line27"> 27: </a>  <a href="tutorials/../../docs/manualpages/Mat/MatSetUp.html#MatSetUp">MatSetUp</a>(A);

<a name="line29"> 29: </a>  <a href="tutorials/../../docs/manualpages/Mat/MatCreateVecs.html#MatCreateVecs">MatCreateVecs</a>(A,&amp;x,&amp;b);
<a name="line30"> 30: </a>  <a href="tutorials/../../docs/manualpages/Vec/VecSet.html#VecSet">VecSet</a>(b,1);

<a name="line32"> 32: </a>  <a href="tutorials/../../docs/manualpages/KSP/KSPCreate.html#KSPCreate">KSPCreate</a>(<a href="tutorials/../../docs/manualpages/Sys/PETSC_COMM_WORLD.html#PETSC_COMM_WORLD">PETSC_COMM_WORLD</a>,&amp;ksp);
<a name="line33"> 33: </a>  <a href="tutorials/../../docs/manualpages/KSP/KSPSetType.html#KSPSetType">KSPSetType</a>(ksp,KSPPYTHON);
<a name="line34"> 34: </a>  <a href="tutorials/../../docs/manualpages/KSP/KSPPythonSetType.html#KSPPythonSetType">KSPPythonSetType</a>(ksp,<font color="#666666">"example1.py:ConjGrad"</font>);

<a name="line36"> 36: </a>  <a href="tutorials/../../docs/manualpages/KSP/KSPGetPC.html#KSPGetPC">KSPGetPC</a>(ksp,&amp;pc);
<a name="line37"> 37: </a>  <a href="tutorials/../../docs/manualpages/PC/PCSetType.html#PCSetType">PCSetType</a>(pc,PCPYTHON);
<a name="line38"> 38: </a>  <a href="tutorials/../../docs/manualpages/PC/PCPythonSetType.html#PCPythonSetType">PCPythonSetType</a>(pc,<font color="#666666">"example1.py:Jacobi"</font>);

<a name="line40"> 40: </a>  <a href="tutorials/../../docs/manualpages/KSP/KSPSetOperators.html#KSPSetOperators">KSPSetOperators</a>(ksp,A,A);
<a name="line41"> 41: </a>  <a href="tutorials/../../docs/manualpages/KSP/KSPSetFromOptions.html#KSPSetFromOptions">KSPSetFromOptions</a>(ksp);
<a name="line42"> 42: </a>  <a href="tutorials/../../docs/manualpages/KSP/KSPSolve.html#KSPSolve">KSPSolve</a>(ksp,b,x);

<a name="line44"> 44: </a>  <a href="tutorials/../../docs/manualpages/Vec/VecDuplicate.html#VecDuplicate">VecDuplicate</a>(b,&amp;r);
<a name="line45"> 45: </a>  <a href="tutorials/../../docs/manualpages/Mat/MatMult.html#MatMult">MatMult</a>(A,x,r);
<a name="line46"> 46: </a>  <a href="tutorials/../../docs/manualpages/Vec/VecAYPX.html#VecAYPX">VecAYPX</a>(r,-1,b);
<a name="line47"> 47: </a>  <a href="tutorials/../../docs/manualpages/Vec/VecNorm.html#VecNorm">VecNorm</a>(r,<a href="tutorials/../../docs/manualpages/Vec/NORM_2.html#NORM_2">NORM_2</a>,&amp;rnorm);
<a name="line48"> 48: </a>  <a href="tutorials/../../docs/manualpages/Sys/PetscPrintf.html#PetscPrintf">PetscPrintf</a>(<a href="tutorials/../../docs/manualpages/Sys/PETSC_COMM_WORLD.html#PETSC_COMM_WORLD">PETSC_COMM_WORLD</a>,<font color="#666666">"error norm = %g\n"</font>,rnorm);

<a name="line50"> 50: </a>  <font color="#4169E1">if</font> (draw) {
<a name="line51"> 51: </a>    <a href="tutorials/../../docs/manualpages/Vec/VecView.html#VecView">VecView</a>(x,<a href="tutorials/../../docs/manualpages/Viewer/PETSC_VIEWER_DRAW_WORLD.html#PETSC_VIEWER_DRAW_WORLD">PETSC_VIEWER_DRAW_WORLD</a>);
<a name="line52"> 52: </a>    <a href="tutorials/../../docs/manualpages/Sys/PetscSleep.html#PetscSleep">PetscSleep</a>(2);
<a name="line53"> 53: </a>  }

<a name="line55"> 55: </a>  <a href="tutorials/../../docs/manualpages/Vec/VecDestroy.html#VecDestroy">VecDestroy</a>(&amp;x);
<a name="line56"> 56: </a>  <a href="tutorials/../../docs/manualpages/Vec/VecDestroy.html#VecDestroy">VecDestroy</a>(&amp;b);
<a name="line57"> 57: </a>  <a href="tutorials/../../docs/manualpages/Vec/VecDestroy.html#VecDestroy">VecDestroy</a>(&amp;r);
<a name="line58"> 58: </a>  <a href="tutorials/../../docs/manualpages/Mat/MatDestroy.html#MatDestroy">MatDestroy</a>(&amp;A);
<a name="line59"> 59: </a>  <a href="tutorials/../../docs/manualpages/KSP/KSPDestroy.html#KSPDestroy">KSPDestroy</a>(&amp;ksp);

<a name="line61"> 61: </a>  <font color="#4169E1">return</font>(0);
<a name="line62"> 62: </a>}

<a name="line64"> 64: </a><font color="#B22222">/* ------------------------------------------------------- */</font>

<a name="line66"> 66: </a>static char help[] = <font color="#666666">"Python-implemented <a href="tutorials/../../docs/manualpages/Mat/Mat.html#Mat">Mat</a>/<a href="tutorials/../../docs/manualpages/KSP/KSP.html#KSP">KSP</a>/<a href="tutorials/../../docs/manualpages/PC/PC.html#PC">PC</a>.\n\n"</font>;

<a name="line68"> 68: </a><font color="#B22222">/*</font>
<a name="line69"> 69: </a><font color="#B22222">#define PYTHON_EXE "python2.5"</font>
<a name="line70"> 70: </a><font color="#B22222">#define PYTHON_LIB "/usr/lib/libpython2.5"</font>
<a name="line71"> 71: </a><font color="#B22222">*/</font>

<a name="line73"> 73: </a><font color="#A020F0">#if !defined(PYTHON_EXE)</font>
<a name="line74"> 74: </a><strong><font color="#228B22">#define PYTHON_EXE 0</font></strong>
<a name="line75"> 75: </a><font color="#A020F0">#endif</font>
<a name="line76"> 76: </a><font color="#A020F0">#if !defined(PYTHON_LIB)</font>
<a name="line77"> 77: </a><strong><font color="#228B22">#define PYTHON_LIB 0</font></strong>
<a name="line78"> 78: </a><font color="#A020F0">#endif</font>

<a name="line82"> 82: </a><strong><font color="#4169E1"><a name="main"></a>int main(int argc, char *argv[])</font></strong>
<a name="line83"> 83: </a>{

<a name="line86"> 86: </a>  <a href="tutorials/../../docs/manualpages/Sys/PetscInitialize.html#PetscInitialize">PetscInitialize</a>(&amp;argc,&amp;argv,0,help);

<a name="line88"> 88: </a>  PetscPythonInitialize(PYTHON_EXE,PYTHON_LIB);

<a name="line90"> 90: </a>  RunTest();PetscPythonPrintError();

<a name="line92"> 92: </a>  <a href="tutorials/../../docs/manualpages/Sys/PetscFinalize.html#PetscFinalize">PetscFinalize</a>();

<a name="line94"> 94: </a>  <font color="#4169E1">return</font> 0;
<a name="line95"> 95: </a>}

<a name="line97"> 97: </a><font color="#B22222">/* ------------------------------------------------------- */</font>
</pre>
</body>

</html>