inweb-bootstrap/docs/goldbach/S-sp.html

164 lines
12 KiB
HTML
Raw Normal View History

2020-04-12 16:24:23 +00:00
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
2020-04-21 16:55:17 +00:00
<title>Summing Primes</title>
2020-04-20 22:26:08 +00:00
<link href="../docs-assets/Breadcrumbs.css" rel="stylesheet" rev="stylesheet" type="text/css">
2020-04-12 16:24:23 +00:00
<meta name="viewport" content="width=device-width initial-scale=1">
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
<meta http-equiv="Content-Language" content="en-gb">
2020-04-20 22:26:08 +00:00
<link href="../docs-assets/Base.css" rel="stylesheet" rev="stylesheet" type="text/css">
<script>
MathJax = {
2020-04-21 23:52:25 +00:00
tex: {
inlineMath: '$', '$'], ['\\(', '\\)'
},
svg: {
fontCache: 'global'
}
};
</script>
<script type="text/javascript" id="MathJax-script" async
2020-04-21 23:52:25 +00:00
src="https://cdn.jsdelivr.net/npm/mathjax@3/es5/tex-svg.js">
</script>
2020-04-21 23:52:25 +00:00
<script src="http://code.jquery.com/jquery-1.12.4.min.js"
integrity="sha256-ZosEbRLbNQzLpnKIkEdrPv7lOy9C27hHQ+Xp8a4MxAQ=" crossorigin="anonymous"></script>
2020-04-20 22:26:08 +00:00
2020-04-21 23:52:25 +00:00
<script src="../docs-assets/Bigfoot.js"></script>
2020-04-20 22:26:08 +00:00
<link href="../docs-assets/Bigfoot.css" rel="stylesheet" rev="stylesheet" type="text/css">
2020-04-21 23:52:25 +00:00
<link href="../docs-assets/Carousel.css" rel="stylesheet" rev="stylesheet" type="text/css">
<script src="../docs-assets/Carousel.js"></script>
2020-04-21 16:55:17 +00:00
<link href="../docs-assets/Colours.css" rel="stylesheet" rev="stylesheet" type="text/css">
<link href="../docs-assets/ConsoleText-Colours.css" rel="stylesheet" rev="stylesheet" type="text/css">
2020-04-12 16:24:23 +00:00
</head>
<body>
<nav role="navigation">
2020-04-13 16:06:45 +00:00
<h1><a href="../index.html">
2020-04-20 22:26:08 +00:00
<img src="../docs-assets/Octagram.png" width=72 height=72">
2020-04-13 16:06:45 +00:00
</a></h1>
<ul><li><a href="../inweb/index.html">inweb</a></li>
</ul><h2>Foundation Module</h2><ul>
<li><a href="../foundation-module/index.html">foundation</a></li>
2020-04-12 16:24:23 +00:00
<li><a href="../foundation-test/index.html">foundation-test</a></li>
2020-04-13 16:06:45 +00:00
</ul><h2>Example Webs</h2><ul>
<li><a href="index.html"><span class="selectedlink">goldbach</span></a></li>
2020-04-12 16:24:23 +00:00
<li><a href="../twinprimes/twinprimes.html">twinprimes</a></li>
2020-04-15 22:45:08 +00:00
<li><a href="../eastertide/index.html">eastertide</a></li>
2020-04-14 17:36:42 +00:00
</ul><h2>Repository</h2><ul>
2020-04-20 22:34:44 +00:00
<li><a href="https://github.com/ganelson/inweb"><img src="../docs-assets/github.png" height=18> github</a></li>
2020-04-14 17:36:42 +00:00
</ul><h2>Related Projects</h2><ul>
<li><a href="../../../inform/docs/index.html">inform</a></li>
<li><a href="../../../intest/docs/index.html">intest</a></li>
2020-04-12 16:24:23 +00:00
2020-04-13 16:06:45 +00:00
</ul>
2020-04-12 16:24:23 +00:00
</nav>
<main role="main">
2020-04-21 16:55:17 +00:00
<!--Weave of 'Summing Primes' generated by Inweb-->
<ul class="crumbs"><li><a href="../index.html">Home</a></li><li><a href="index.html">The Goldbach Conjecture</a></li><li><b>Summing Primes</b></li></ul><p class="purpose">Here we verify the conjecture for small numbers.</p>
2020-04-12 16:24:23 +00:00
2020-04-20 22:26:08 +00:00
<p class="inwebparagraph"><a id="SP1"></a><b>&#167;1. </b>So, this is a program to see if even numbers from 4 to 100 can all be written
2020-04-12 16:24:23 +00:00
as a sum of two primes. Christian Goldbach asked Euler in 1742 if every even
number greater than 2 can be written this way. This remains open, though &mdash;
2020-04-12 16:24:23 +00:00
</p>
<ul class="items"><li>(a) every even number is a sum of at most six primes (Ramaré, 1995), and
</li><li>(b) every odd number is a sum of at most five (Tao, 2012).
</li></ul>
2020-04-22 22:57:09 +00:00
<p class="inwebparagraph">Besides which, <span class="extract"><span class="extract-syntax">printf(k+1)</span></span>, to say the least: see <a href="http://www.google.com" class="external">http://www.google.com</a>
2020-04-21 23:52:25 +00:00
or for that matter see <a href="S-tsoe.html" class="internal">The Sieve of Eratosthenes</a>.
2020-04-20 22:26:08 +00:00
</p>
2020-04-22 11:31:01 +00:00
<center><img src="Letter.jpg" height="720"></center>
2020-04-20 22:26:08 +00:00
<p class="inwebparagraph">Computer verification has been made up to around \(10^{18}\), but by rather better
methods.<sup id="fnref:1"><a href="#fn:1" rel="footnote">1</a></sup> Which is awesome.<sup id="fnref:2"><a href="#fn:2" rel="footnote">2</a></sup> And \(i&lt;j\), that's for sure.
$$ \int_0^1 \cos x {\rm d}x $$
Which is really the point.
</p>
<ul class="footnotetexts"><li class="footnote" id="fn:1"><p class="inwebfootnote"><sup id="fnref:1"><a href="#fn:1" rel="footnote">1</a></sup> And don't just take my word for it.
<a href="#fnref:1" title="return to text"> &#x21A9;</a></p></li><li class="footnote" id="fn:2"><p class="inwebfootnote"><sup id="fnref:2"><a href="#fn:2" rel="footnote">2</a></sup> Really!
2020-04-21 23:52:25 +00:00
<a href="#fnref:2" title="return to text"> &#x21A9;</a></p></li></ul><p class="inwebparagraph"><a id="SP2"></a><b>&#167;2. </b>And now...
</p>
2020-04-22 11:31:01 +00:00
<div class="carousel-container" id="carousel-no-1">
<div class="carousel-slide fading-slide" style="display: block;">
<div class="carousel-caption-above">This is numero 1</div>
<div class="carousel-number-above">1 / 3</div>
<div class="carousel-content"><center><img src="img1.jpg"></center>
2020-04-21 23:52:25 +00:00
</div>
</div>
2020-04-22 11:31:01 +00:00
<div class="carousel-slide fading-slide" style="display: none;">
<div class="carousel-number">2 / 3</div>
<div class="carousel-content"><center><img src="img2.jpg"></center>
2020-04-21 23:52:25 +00:00
</div>
</div>
2020-04-22 11:31:01 +00:00
<div class="carousel-slide fading-slide" style="display: none;">
<div class="carousel-number-below">3 / 3</div>
<div class="carousel-content"><center><img src="img3.jpg"></center>
</div>
<div class="carousel-caption-below">So, this is a program to see if even numbers from 4 to 100 can all be written as a sum of two primes. Christian Goldbach asked Euler in 1742 if every even number greater than 2 can be written this way.</div>
</div>
<a class="carousel-prev-button" onclick="carouselMoveSlide(&quot;carousel-no-1&quot;, &quot;carousel-dots-no-1&quot;, -1)">&#10094;</a>
<a class="carousel-next-button" onclick="carouselMoveSlide(&quot;carousel-no-1&quot;, &quot;carousel-dots-no-1&quot;, 1)">&#10095;</a>
2020-04-21 23:52:25 +00:00
</div>
2020-04-22 11:31:01 +00:00
<div class="carousel-dots-container" id="carousel-dots-no-1">
<span class="carousel-dot carousel-dot-active" onclick="carouselSetSlide(&quot;carousel-no-1&quot;, &quot;carousel-dots-no-1&quot;, 0)"></span>
<span class="carousel-dot" onclick="carouselSetSlide(&quot;carousel-no-1&quot;, &quot;carousel-dots-no-1&quot;, 1)"></span>
<span class="carousel-dot" onclick="carouselSetSlide(&quot;carousel-no-1&quot;, &quot;carousel-dots-no-1&quot;, 2)"></span>
2020-04-21 23:52:25 +00:00
</div>
<p class="inwebparagraph">So there, really!
</p>
<p class="inwebparagraph"><a id="SP3"></a><b>&#167;3. </b></p>
2020-04-20 22:26:08 +00:00
2020-04-12 16:24:23 +00:00
<pre class="definitions">
2020-04-20 22:26:08 +00:00
<span class="definition-keyword">define</span> <span class="constant-syntax">RANGE</span><span class="plain-syntax"> </span><span class="constant-syntax">100</span>
2020-04-12 16:24:23 +00:00
</pre>
2020-04-21 16:55:17 +00:00
<pre class="displayed-code all-displayed-code">
<span class="plain-syntax">#</span><span class="identifier-syntax">include</span><span class="plain-syntax"> &lt;</span><span class="identifier-syntax">stdio</span><span class="plain-syntax">.</span><span class="identifier-syntax">h</span><span class="plain-syntax">&gt;</span>
2020-04-12 16:24:23 +00:00
2020-04-21 16:55:17 +00:00
<span class="reserved-syntax">int</span><span class="plain-syntax"> </span><span class="function-syntax">main</span><span class="plain-syntax">(</span><span class="reserved-syntax">int</span><span class="plain-syntax"> </span><span class="identifier-syntax">argc</span><span class="plain-syntax">, </span><span class="reserved-syntax">char</span><span class="plain-syntax"> *</span><span class="identifier-syntax">argv</span><span class="plain-syntax">[]) {</span>
<span class="plain-syntax"> </span><span class="reserved-syntax">for</span><span class="plain-syntax"> (</span><span class="reserved-syntax">int</span><span class="plain-syntax"> </span><span class="identifier-syntax">i</span><span class="plain-syntax">=4; </span><span class="identifier-syntax">i</span><span class="plain-syntax">&lt;</span><span class="constant-syntax">RANGE</span><span class="plain-syntax">; </span><span class="identifier-syntax">i</span><span class="plain-syntax">=</span><span class="identifier-syntax">i</span><span class="plain-syntax">+2) </span><span class="comment"> stepping in twos to stay even</span>
2020-04-21 23:52:25 +00:00
<span class="plain-syntax"> </span>&lt;<span class="named-paragraph">Solve Goldbach's conjecture for i</span> <span class="named-paragraph-number">3.1</span>&gt;<span class="character-syntax">;</span>
2020-04-21 16:55:17 +00:00
<span class="character-syntax">}</span>
2020-04-21 23:52:25 +00:00
</pre><p class="inwebparagraph"><a id="SP3_1"></a><b>&#167;3.1. </b>This ought to print:
2020-04-12 16:24:23 +00:00
</p>
2020-04-21 16:55:17 +00:00
<pre class="ConsoleText-displayed-code all-displayed-code">
<span class="ConsoleText-plain-syntax"> </span><span class="ConsoleText-element-syntax">$</span><span class="ConsoleText-plain-syntax"> </span><span class="ConsoleText-function-syntax">goldbach/Tangled/goldbach</span><span class="ConsoleText-identifier-syntax"> -fish</span><span class="ConsoleText-plain-syntax"> 1</span>
<span class="ConsoleText-plain-syntax"> 4 = 2+2</span>
<span class="ConsoleText-plain-syntax"> 6 = 3+3 </span><a href="https://www.wikipedia.org" class="external">https://www.wikipedia.org</a>
<span class="ConsoleText-plain-syntax"> 8 = 3+5</span>
<span class="ConsoleText-plain-syntax"> 10 = 3+7 = 5+5</span>
<span class="ConsoleText-plain-syntax"> 12 = 5+7</span>
<span class="ConsoleText-plain-syntax"> 14 = 3+11 = 7+7</span>
<span class="ConsoleText-plain-syntax"> ...</span>
2020-04-12 16:24:23 +00:00
</pre>
<p class="inwebparagraph">We'll print each different pair of primes adding up to i. We
only check in the range \(2 \leq j \leq i/2\) to avoid counting pairs
twice over (thus \(8 = 3+5 = 5+3\), but that's hardly two different ways).
</p>
<p class="macrodefinition"><code class="display">
2020-04-21 23:52:25 +00:00
&lt;<span class="named-paragraph-defn">Solve Goldbach's conjecture for i</span> <span class="named-paragraph-number">3.1</span>&gt; =
2020-04-12 16:24:23 +00:00
</code></p>
2020-04-21 16:55:17 +00:00
<pre class="displayed-code all-displayed-code">
<span class="plain-syntax"> </span><span class="identifier-syntax">printf</span><span class="plain-syntax">(</span><span class="string-syntax">"%d"</span><span class="plain-syntax">, </span><span class="identifier-syntax">i</span><span class="plain-syntax">);</span>
<span class="plain-syntax"> </span><span class="reserved-syntax">for</span><span class="plain-syntax"> (</span><span class="reserved-syntax">int</span><span class="plain-syntax"> </span><span class="identifier-syntax">j</span><span class="plain-syntax">=2; </span><span class="identifier-syntax">j</span><span class="plain-syntax">&lt;=</span><span class="identifier-syntax">i</span><span class="plain-syntax">/2; </span><span class="identifier-syntax">j</span><span class="plain-syntax">++)</span>
<span class="plain-syntax"> </span><span class="reserved-syntax">if</span><span class="plain-syntax"> ((</span><a href="S-tsoe.html#SP2" class="function-link"><span class="function-syntax">isprime</span></a><span class="plain-syntax">(</span><span class="identifier-syntax">j</span><span class="plain-syntax">)) &amp;&amp; (</span><a href="S-tsoe.html#SP2" class="function-link"><span class="function-syntax">isprime</span></a><span class="plain-syntax">(</span><span class="identifier-syntax">i</span><span class="plain-syntax">-</span><span class="identifier-syntax">j</span><span class="plain-syntax">)))</span>
<span class="plain-syntax"> </span><span class="identifier-syntax">printf</span><span class="plain-syntax">(</span><span class="string-syntax">" = %d+%d"</span><span class="plain-syntax">, </span><span class="identifier-syntax">j</span><span class="plain-syntax">, </span><span class="identifier-syntax">i</span><span class="plain-syntax">-</span><span class="identifier-syntax">j</span><span class="plain-syntax">);</span>
<span class="plain-syntax"> </span><span class="identifier-syntax">printf</span><span class="plain-syntax">(</span><span class="string-syntax">"\n"</span><span class="plain-syntax">);</span>
2020-04-21 23:52:25 +00:00
</pre><ul class="endnotetexts"><li>This code is used in <a href="S-sp.html#SP3">&#167;3</a>.</li></ul><hr class="tocbar">
2020-04-12 16:24:23 +00:00
<ul class="toc"><li><i>(This section begins Sections.)</i></li><li><a href="S-tsoe.html">Continue with 'The Sieve of Eratosthenes'</a></li></ul><hr class="tocbar">
<!--End of weave-->
</main>
</body>
</html>