PhysIKA – Documentation https://PhysikaTeam.github.io/docs.html Recent content in Documentation on PhysIKA Hugo -- gohugo.io Docs: Scene Graph https://PhysikaTeam.github.io/docs/architecture/scenegraph.html Thu, 05 Jan 2017 00:00:00 +0000 https://PhysikaTeam.github.io/docs/architecture/scenegraph.html <h2 id="structure-of-a-scene">Structure of a scene</h2> <p><img src="./scenegraph/sceneflow.jpg" alt="SceneFlow"></p> <h2 id="scene-graph-traversal">Scene graph traversal</h2> <blockquote> <p>To be continued&hellip;</p> </blockquote> Docs: Cloth Simulation https://PhysikaTeam.github.io/docs/examples/cloth.html Thu, 05 Jan 2017 00:00:00 +0000 https://PhysikaTeam.github.io/docs/examples/cloth.html Docs: Incompressible Fluids https://PhysikaTeam.github.io/docs/examples/fluids/incompressible.html Thu, 05 Jan 2017 00:00:00 +0000 https://PhysikaTeam.github.io/docs/examples/fluids/incompressible.html Docs: Nodes https://PhysikaTeam.github.io/docs/architecture/nodes.html Thu, 05 Jan 2017 00:00:00 +0000 https://PhysikaTeam.github.io/docs/architecture/nodes.html <h2 id="structure-of-a-node">Structure of a node</h2> <p>The follow code demonstrates a typical implementation of a node that handles the one-way coupling between particles and static trianglar boundaries.</p> <div class="highlight"><pre style="background-color:#f8f8f8;-moz-tab-size:4;-o-tab-size:4;tab-size:4"><code class="language-go" data-lang="go"><span style="color:#000">template</span><span style="color:#000;font-weight:bold">&lt;</span><span style="color:#000">typename</span> <span style="color:#000">TDataType</span><span style="color:#000;font-weight:bold">&gt;</span> <span style="color:#000">class</span> <span style="color:#000">StaticMeshBoundary</span> <span style="color:#000;font-weight:bold">:</span> <span style="color:#000">public</span> <span style="color:#000">Node</span> <span style="color:#000;font-weight:bold">{</span> <span style="color:#000">DECLARE_CLASS_1</span><span style="color:#000;font-weight:bold">(</span><span style="color:#000">StaticMeshBoundary</span><span style="color:#000;font-weight:bold">,</span> <span style="color:#000">TDataType</span><span style="color:#000;font-weight:bold">)</span> <span style="color:#000">public</span><span style="color:#000;font-weight:bold">:</span> <span style="color:#000">typedef</span> <span style="color:#000">typename</span> <span style="color:#000">TDataType</span><span style="color:#000;font-weight:bold">::</span><span style="color:#000">Real</span> <span style="color:#000">Real</span><span style="color:#000;font-weight:bold">;</span> <span style="color:#000">typedef</span> <span style="color:#000">typename</span> <span style="color:#000">TDataType</span><span style="color:#000;font-weight:bold">::</span><span style="color:#000">Coord</span> <span style="color:#000">Coord</span><span style="color:#000;font-weight:bold">;</span> <span style="color:#000">typedef</span> <span style="color:#000">typename</span> <span style="color:#000">TopologyModule</span><span style="color:#000;font-weight:bold">::</span><span style="color:#000">Triangle</span> <span style="color:#000">Triangle</span><span style="color:#000;font-weight:bold">;</span> <span style="color:#000">StaticMeshBoundary</span><span style="color:#000;font-weight:bold">();</span> <span style="color:#a40000">~</span><span style="color:#000">StaticMeshBoundary</span><span style="color:#000;font-weight:bold">()</span> <span style="color:#000">override</span><span style="color:#000;font-weight:bold">;</span> <span style="color:#000">void</span> <span style="color:#000">advance</span><span style="color:#000;font-weight:bold">(</span><span style="color:#000">Real</span> <span style="color:#000">dt</span><span style="color:#000;font-weight:bold">)</span> <span style="color:#000">override</span><span style="color:#000;font-weight:bold">;</span> <span style="color:#000">public</span><span style="color:#000;font-weight:bold">:</span> <span style="color:#8f5902;font-style:italic">/** </span><span style="color:#8f5902;font-style:italic"> * @brief Input rigid bodies </span><span style="color:#8f5902;font-style:italic"> */</span> <span style="color:#000">DEF_NODE_PORTS</span><span style="color:#000;font-weight:bold">(</span><span style="color:#000">RigidBody</span><span style="color:#000;font-weight:bold">,</span> <span style="color:#000">RigidBody</span><span style="color:#000;font-weight:bold">&lt;</span><span style="color:#000">TDataType</span><span style="color:#000;font-weight:bold">&gt;,</span> <span style="color:#4e9a06">&#34;A rigid body&#34;</span><span style="color:#000;font-weight:bold">);</span> <span style="color:#8f5902;font-style:italic">/** </span><span style="color:#8f5902;font-style:italic"> * @brief Input particle systems </span><span style="color:#8f5902;font-style:italic"> */</span> <span style="color:#000">DEF_NODE_PORTS</span><span style="color:#000;font-weight:bold">(</span><span style="color:#000">ParticleSystem</span><span style="color:#000;font-weight:bold">,</span> <span style="color:#000">ParticleSystem</span><span style="color:#000;font-weight:bold">&lt;</span><span style="color:#000">TDataType</span><span style="color:#000;font-weight:bold">&gt;,</span> <span style="color:#4e9a06">&#34;Particle Systems&#34;</span><span style="color:#000;font-weight:bold">);</span> <span style="color:#000">public</span><span style="color:#000;font-weight:bold">:</span> <span style="color:#8f5902;font-style:italic">/** </span><span style="color:#8f5902;font-style:italic"> * @brief Particle position </span><span style="color:#8f5902;font-style:italic"> */</span> <span style="color:#000">DEF_EMPTY_CURRENT_ARRAY</span><span style="color:#000;font-weight:bold">(</span><span style="color:#000">ParticlePosition</span><span style="color:#000;font-weight:bold">,</span> <span style="color:#000">Coord</span><span style="color:#000;font-weight:bold">,</span> <span style="color:#000">DeviceType</span><span style="color:#000;font-weight:bold">::</span><span style="color:#000">GPU</span><span style="color:#000;font-weight:bold">,</span> <span style="color:#4e9a06">&#34;Particle position&#34;</span><span style="color:#000;font-weight:bold">);</span> <span style="color:#8f5902;font-style:italic">/** </span><span style="color:#8f5902;font-style:italic"> * @brief Particle velocity </span><span style="color:#8f5902;font-style:italic"> */</span> <span style="color:#000">DEF_EMPTY_CURRENT_ARRAY</span><span style="color:#000;font-weight:bold">(</span><span style="color:#000">ParticleVelocity</span><span style="color:#000;font-weight:bold">,</span> <span style="color:#000">Coord</span><span style="color:#000;font-weight:bold">,</span> <span style="color:#000">DeviceType</span><span style="color:#000;font-weight:bold">::</span><span style="color:#000">GPU</span><span style="color:#000;font-weight:bold">,</span> <span style="color:#4e9a06">&#34;Particle velocity&#34;</span><span style="color:#000;font-weight:bold">);</span> <span style="color:#8f5902;font-style:italic">/** </span><span style="color:#8f5902;font-style:italic"> * @brief Triangle vertex </span><span style="color:#8f5902;font-style:italic"> */</span> <span style="color:#000">DEF_EMPTY_CURRENT_ARRAY</span><span style="color:#000;font-weight:bold">(</span><span style="color:#000">TriangleVertex</span><span style="color:#000;font-weight:bold">,</span> <span style="color:#000">Coord</span><span style="color:#000;font-weight:bold">,</span> <span style="color:#000">DeviceType</span><span style="color:#000;font-weight:bold">::</span><span style="color:#000">GPU</span><span style="color:#000;font-weight:bold">,</span> <span style="color:#4e9a06">&#34;Particle position&#34;</span><span style="color:#000;font-weight:bold">);</span> <span style="color:#8f5902;font-style:italic">/** </span><span style="color:#8f5902;font-style:italic"> * @brief Particle velocity </span><span style="color:#8f5902;font-style:italic"> */</span> <span style="color:#000">DEF_EMPTY_CURRENT_ARRAY</span><span style="color:#000;font-weight:bold">(</span><span style="color:#000">TriangleIndex</span><span style="color:#000;font-weight:bold">,</span> <span style="color:#000">Triangle</span><span style="color:#000;font-weight:bold">,</span> <span style="color:#000">DeviceType</span><span style="color:#000;font-weight:bold">::</span><span style="color:#000">GPU</span><span style="color:#000;font-weight:bold">,</span> <span style="color:#4e9a06">&#34;Particle velocity&#34;</span><span style="color:#000;font-weight:bold">);</span> <span style="color:#000">private</span><span style="color:#000;font-weight:bold">:</span> <span style="color:#8f5902;font-style:italic">/** </span><span style="color:#8f5902;font-style:italic"> * @brief Define other private members below </span><span style="color:#8f5902;font-style:italic"> */</span> <span style="color:#000;font-weight:bold">};</span> </code></pre></div><p>To be recognized by the reflecting system in PhysIKA, each class should be started with the following macro definition</p> <div class="highlight"><pre style="background-color:#f8f8f8;-moz-tab-size:4;-o-tab-size:4;tab-size:4"><code class="language-go" data-lang="go"> <span style="color:#000">DECLARE_CLASS</span><span style="color:#000;font-weight:bold">(</span><span style="color:#000">ClassName</span><span style="color:#000;font-weight:bold">)</span> </code></pre></div><p>or</p> <div class="highlight"><pre style="background-color:#f8f8f8;-moz-tab-size:4;-o-tab-size:4;tab-size:4"><code class="language-go" data-lang="go"> <span style="color:#000">DECLARE_CLASS_1</span><span style="color:#000;font-weight:bold">(</span><span style="color:#000">ClassName</span><span style="color:#000;font-weight:bold">,</span> <span style="color:#000">TemplateName</span><span style="color:#000;font-weight:bold">)</span> </code></pre></div><p>for templated class.</p> <p>The above declaration should be concluded with the following macro definition</p> <div class="highlight"><pre style="background-color:#f8f8f8;-moz-tab-size:4;-o-tab-size:4;tab-size:4"><code class="language-go" data-lang="go"> <span style="color:#000">IMPLEMENT_CLASS</span><span style="color:#000;font-weight:bold">(</span><span style="color:#000">ClassName</span><span style="color:#000;font-weight:bold">)</span> </code></pre></div><p>or</p> <div class="highlight"><pre style="background-color:#f8f8f8;-moz-tab-size:4;-o-tab-size:4;tab-size:4"><code class="language-go" data-lang="go"> <span style="color:#000">IMPLEMENT_CLASS_1</span><span style="color:#000;font-weight:bold">(</span><span style="color:#000">ClassName</span><span style="color:#000;font-weight:bold">,</span> <span style="color:#000">TemplateName</span><span style="color:#000;font-weight:bold">)</span> </code></pre></div><p>for templated class.</p> <p>Then, an instance of StaticMeshBoundary can correctly created by passing the class name to the static function in the Object class.</p> <div class="highlight"><pre style="background-color:#f8f8f8;-moz-tab-size:4;-o-tab-size:4;tab-size:4"><code class="language-go" data-lang="go"> <span style="color:#000">static</span> <span style="color:#000">Object</span><span style="color:#ce5c00;font-weight:bold">*</span> <span style="color:#000">createObject</span><span style="color:#000;font-weight:bold">(</span><span style="color:#000">std</span><span style="color:#000;font-weight:bold">::</span><span style="color:#204a87;font-weight:bold">string</span> <span style="color:#000">name</span><span style="color:#000;font-weight:bold">);</span> </code></pre></div><p>In addition, an instance of the reflected class can also be create from the PhysIKA Studio.</p> <p><img src="./nodes/createInstanceFromQt.jpg" alt="Example"></p> <h3 id="node-ports">Node Ports</h3> <h3 id="mechanical-status">Mechanical Status</h3> <h3 id="topology">Topology</h3> Docs: Modules https://PhysikaTeam.github.io/docs/architecture/modules.html Thu, 05 Jan 2017 00:00:00 +0000 https://PhysikaTeam.github.io/docs/architecture/modules.html <h2 id="structure-of-a-module">Structure of a module</h2> <p>The following code demonstrates the typical strcuture of a module, which contains regular variables, input variables and output variables.</p> <div class="highlight"><pre style="background-color:#f8f8f8;-moz-tab-size:4;-o-tab-size:4;tab-size:4"><code class="language-go" data-lang="go"><span style="color:#000">template</span><span style="color:#000;font-weight:bold">&lt;</span><span style="color:#000">typename</span> <span style="color:#000">TDataType</span><span style="color:#000;font-weight:bold">&gt;</span> <span style="color:#000">class</span> <span style="color:#000">SummationDensity</span> <span style="color:#000;font-weight:bold">:</span> <span style="color:#000">public</span> <span style="color:#000">ComputeModule</span> <span style="color:#000;font-weight:bold">{</span> <span style="color:#000">DECLARE_CLASS_1</span><span style="color:#000;font-weight:bold">(</span><span style="color:#000">SummationDensity</span><span style="color:#000;font-weight:bold">,</span> <span style="color:#000">TDataType</span><span style="color:#000;font-weight:bold">)</span> <span style="color:#000">public</span><span style="color:#000;font-weight:bold">:</span> <span style="color:#000">typedef</span> <span style="color:#000">typename</span> <span style="color:#000">TDataType</span><span style="color:#000;font-weight:bold">::</span><span style="color:#000">Real</span> <span style="color:#000">Real</span><span style="color:#000;font-weight:bold">;</span> <span style="color:#000">typedef</span> <span style="color:#000">typename</span> <span style="color:#000">TDataType</span><span style="color:#000;font-weight:bold">::</span><span style="color:#000">Coord</span> <span style="color:#000">Coord</span><span style="color:#000;font-weight:bold">;</span> <span style="color:#000">SummationDensity</span><span style="color:#000;font-weight:bold">();</span> <span style="color:#a40000">~</span><span style="color:#000">SummationDensity</span><span style="color:#000;font-weight:bold">()</span> <span style="color:#000">override</span> <span style="color:#000;font-weight:bold">{};</span> <span style="color:#000">void</span> <span style="color:#000">compute</span><span style="color:#000;font-weight:bold">()</span> <span style="color:#000">override</span><span style="color:#000;font-weight:bold">;</span> <span style="color:#000">protected</span><span style="color:#000;font-weight:bold">:</span> <span style="color:#000">void</span> <span style="color:#000">calculateScalingFactor</span><span style="color:#000;font-weight:bold">();</span> <span style="color:#000">void</span> <span style="color:#000">compute</span><span style="color:#000;font-weight:bold">(</span><span style="color:#000">DeviceArray</span><span style="color:#000;font-weight:bold">&lt;</span><span style="color:#000">Real</span><span style="color:#000;font-weight:bold">&gt;</span><span style="color:#ce5c00;font-weight:bold">&amp;</span> <span style="color:#000">rho</span><span style="color:#000;font-weight:bold">);</span> <span style="color:#000">void</span> <span style="color:#000">compute</span><span style="color:#000;font-weight:bold">(</span> <span style="color:#000">DeviceArray</span><span style="color:#000;font-weight:bold">&lt;</span><span style="color:#000">Real</span><span style="color:#000;font-weight:bold">&gt;</span><span style="color:#ce5c00;font-weight:bold">&amp;</span> <span style="color:#000">rho</span><span style="color:#000;font-weight:bold">,</span> <span style="color:#000">DeviceArray</span><span style="color:#000;font-weight:bold">&lt;</span><span style="color:#000">Coord</span><span style="color:#000;font-weight:bold">&gt;</span><span style="color:#ce5c00;font-weight:bold">&amp;</span> <span style="color:#000">pos</span><span style="color:#000;font-weight:bold">,</span> <span style="color:#000">NeighborList</span><span style="color:#000;font-weight:bold">&lt;</span><span style="color:#204a87;font-weight:bold">int</span><span style="color:#000;font-weight:bold">&gt;</span><span style="color:#ce5c00;font-weight:bold">&amp;</span> <span style="color:#000">neighbors</span><span style="color:#000;font-weight:bold">,</span> <span style="color:#000">Real</span> <span style="color:#000">smoothingLength</span><span style="color:#000;font-weight:bold">,</span> <span style="color:#000">Real</span> <span style="color:#000">mass</span><span style="color:#000;font-weight:bold">);</span> <span style="color:#000">public</span><span style="color:#000;font-weight:bold">:</span> <span style="color:#8f5902;font-style:italic">///Define intrinsic fields </span><span style="color:#8f5902;font-style:italic"></span> <span style="color:#000">DEF_EMPTY_VAR</span><span style="color:#000;font-weight:bold">(</span><span style="color:#000">RestDensity</span><span style="color:#000;font-weight:bold">,</span> <span style="color:#000">Real</span><span style="color:#000;font-weight:bold">,</span> <span style="color:#4e9a06">&#34;Rest Density&#34;</span><span style="color:#000;font-weight:bold">);</span> <span style="color:#000">DEF_EMPTY_VAR</span><span style="color:#000;font-weight:bold">(</span><span style="color:#000">Mass</span><span style="color:#000;font-weight:bold">,</span> <span style="color:#000">Real</span><span style="color:#000;font-weight:bold">,</span> <span style="color:#4e9a06">&#34;Particle mass, note that this module only support a constant mass for all particles.&#34;</span><span style="color:#000;font-weight:bold">);</span> <span style="color:#000">DEF_EMPTY_VAR</span><span style="color:#000;font-weight:bold">(</span><span style="color:#000">SmoothingLength</span><span style="color:#000;font-weight:bold">,</span> <span style="color:#000">Real</span><span style="color:#000;font-weight:bold">,</span> <span style="color:#4e9a06">&#34;Indicating the smoothing length&#34;</span><span style="color:#000;font-weight:bold">);</span> <span style="color:#000">DEF_EMPTY_VAR</span><span style="color:#000;font-weight:bold">(</span><span style="color:#000">SamplingDistance</span><span style="color:#000;font-weight:bold">,</span> <span style="color:#000">Real</span><span style="color:#000;font-weight:bold">,</span> <span style="color:#4e9a06">&#34;Indicating the initial sampling distance&#34;</span><span style="color:#000;font-weight:bold">);</span> <span style="color:#8f5902;font-style:italic">///Define input fields </span><span style="color:#8f5902;font-style:italic"></span> <span style="color:#8f5902;font-style:italic">/** </span><span style="color:#8f5902;font-style:italic"> * @brief Particle positions </span><span style="color:#8f5902;font-style:italic"> */</span> <span style="color:#000">DEF_EMPTY_IN_ARRAY</span><span style="color:#000;font-weight:bold">(</span><span style="color:#000">Position</span><span style="color:#000;font-weight:bold">,</span> <span style="color:#000">Coord</span><span style="color:#000;font-weight:bold">,</span> <span style="color:#000">DeviceType</span><span style="color:#000;font-weight:bold">::</span><span style="color:#000">GPU</span><span style="color:#000;font-weight:bold">,</span> <span style="color:#4e9a06">&#34;Particle position&#34;</span><span style="color:#000;font-weight:bold">);</span> <span style="color:#8f5902;font-style:italic">/** </span><span style="color:#8f5902;font-style:italic"> * @brief Neighboring particles </span><span style="color:#8f5902;font-style:italic"> * </span><span style="color:#8f5902;font-style:italic"> */</span> <span style="color:#000">DEF_EMPTY_IN_NEIGHBOR_LIST</span><span style="color:#000;font-weight:bold">(</span><span style="color:#000">NeighborIndex</span><span style="color:#000;font-weight:bold">,</span> <span style="color:#204a87;font-weight:bold">int</span><span style="color:#000;font-weight:bold">,</span> <span style="color:#4e9a06">&#34;Neighboring particles&#39; ids&#34;</span><span style="color:#000;font-weight:bold">);</span> <span style="color:#8f5902;font-style:italic">///Define output fields </span><span style="color:#8f5902;font-style:italic"></span> <span style="color:#8f5902;font-style:italic">/** </span><span style="color:#8f5902;font-style:italic"> * @brief Particle densities </span><span style="color:#8f5902;font-style:italic"> */</span> <span style="color:#000">DEF_EMPTY_OUT_ARRAY</span><span style="color:#000;font-weight:bold">(</span><span style="color:#000">Density</span><span style="color:#000;font-weight:bold">,</span> <span style="color:#000">Real</span><span style="color:#000;font-weight:bold">,</span> <span style="color:#000">DeviceType</span><span style="color:#000;font-weight:bold">::</span><span style="color:#000">GPU</span><span style="color:#000;font-weight:bold">,</span> <span style="color:#4e9a06">&#34;Particle position&#34;</span><span style="color:#000;font-weight:bold">);</span> <span style="color:#000">private</span><span style="color:#000;font-weight:bold">:</span> <span style="color:#8f5902;font-style:italic">///Define other class members </span><span style="color:#8f5902;font-style:italic"></span><span style="color:#000;font-weight:bold">};</span> </code></pre></div><p>In the Qt-based GUI, the above module appears like</p> <p><img src="./modules/summation-density.jpg" alt="ModuleView"></p> <p>Besides, all regular variables will be shown in the property editor</p> <p><img src="./modules/property.jpg" alt="Property"></p> <h3 id="intrinsic-fields">Intrinsic fields</h3> <blockquote> <p>All intrinsic field names are started with an prefix <strong>var</strong>, e.g., this-&gt;varRestDensity().</p> </blockquote> <p>If a intrinsic field is defined, it can be used by the module without explicitly initializing its value.</p> <p>To declare an empty field of real type, use the following formulation</p> <pre><code>DEF_EMPTY_VAR(RestDensity, Real, &quot;Rest Density&quot;); </code></pre><h3 id="input-fields">Input fields</h3> <blockquote> <p>All input field names are started with an prefix <strong>in</strong>, e.g., this-&gt;inPosition().</p> </blockquote> <p>Input fields of a module are usually empty. Therefore, to execuate a module, its input fields should be explicitly specified.</p> <p>To set up an input field, the most efficienty way is by connecting an output field to an input field, e.g.,</p> <div class="highlight"><pre style="background-color:#f8f8f8;-moz-tab-size:4;-o-tab-size:4;tab-size:4"><code class="language-go" data-lang="go"><span style="color:#000">this</span><span style="color:#ce5c00;font-weight:bold">-</span><span style="color:#000;font-weight:bold">&gt;</span><span style="color:#000">outPosition</span><span style="color:#000;font-weight:bold">().</span><span style="color:#000">connect</span><span style="color:#000;font-weight:bold">(</span><span style="color:#000">m_densitySum</span><span style="color:#ce5c00;font-weight:bold">-</span><span style="color:#000;font-weight:bold">&gt;</span><span style="color:#000">inPosition</span><span style="color:#000;font-weight:bold">());</span> </code></pre></div><h3 id="output-fields">Output fields</h3> <blockquote> <p>All output field names are started with an prefix <strong>out</strong>, e.g., this-&gt;outPosition().</p> </blockquote> <p>The values of output fields are computed from input fields. As long as either the intrinsic fields all input fields are changed, the output fields should be updated again.</p> Docs: Viscous Fluids https://PhysikaTeam.github.io/docs/examples/fluids/viscous.html Thu, 05 Jan 2017 00:00:00 +0000 https://PhysikaTeam.github.io/docs/examples/fluids/viscous.html Docs: Fields https://PhysikaTeam.github.io/docs/architecture/fields.html Thu, 05 Jan 2017 00:00:00 +0000 https://PhysikaTeam.github.io/docs/architecture/fields.html <h2 id="field-types">Field types</h2> <pre><code>VarField </code></pre><pre><code>ArrayField </code></pre><pre><code>NeighborField </code></pre> Docs: Particle System https://PhysikaTeam.github.io/docs/advanced/particle-system.html Thu, 05 Jan 2017 00:00:00 +0000 https://PhysikaTeam.github.io/docs/advanced/particle-system.html Docs: Particle-based Elastic Objects https://PhysikaTeam.github.io/docs/examples/elasticity.html Thu, 05 Jan 2017 00:00:00 +0000 https://PhysikaTeam.github.io/docs/examples/elasticity.html Docs: Collision https://PhysikaTeam.github.io/docs/examples/collision.html Thu, 05 Jan 2017 00:00:00 +0000 https://PhysikaTeam.github.io/docs/examples/collision.html Docs: Height Field https://PhysikaTeam.github.io/docs/advanced/height-field.html Thu, 05 Jan 2017 00:00:00 +0000 https://PhysikaTeam.github.io/docs/advanced/height-field.html Docs: Rigid Body Dynamics https://PhysikaTeam.github.io/docs/advanced/rigid-body.html Thu, 05 Jan 2017 00:00:00 +0000 https://PhysikaTeam.github.io/docs/advanced/rigid-body.html Docs: Finite Element https://PhysikaTeam.github.io/docs/advanced/finite-element.html Thu, 05 Jan 2017 00:00:00 +0000 https://PhysikaTeam.github.io/docs/advanced/finite-element.html Docs: Linux https://PhysikaTeam.github.io/docs/gettingstarted/linux.html Thu, 05 Jan 2017 00:00:00 +0000 https://PhysikaTeam.github.io/docs/gettingstarted/linux.html <div class="pageinfo pageinfo-primary"> <p>To appear&hellip;</p> </div> Docs: Related projects https://PhysikaTeam.github.io/docs/reference/parameter-reference.html Thu, 05 Jan 2017 00:00:00 +0000 https://PhysikaTeam.github.io/docs/reference/parameter-reference.html Docs: Windows https://PhysikaTeam.github.io/docs/gettingstarted/windows.html Thu, 05 Jan 2017 00:00:00 +0000 https://PhysikaTeam.github.io/docs/gettingstarted/windows.html <h1 id="how-to-build-physika--in-windows-environment">How to build physika in windows environment</h1> <p>This page tells you how to build physika, including installation and basic configuration.</p> <h3 id="install-cmake">Install Cmake</h3> <ol> <li>Download the latest version of cmake executable file(Click <a href="https://cmake.org/download/">Here</a> to download cmake executable file).</li> <li>Double click to install directly.</li> </ol> <h3 id="install-cuda-110">Install Cuda 11.0</h3> <ol> <li> <p>Download cuda11.0(Click <a href="https://developer.nvidia.com/cuda-downloads?target_os=Windows&amp;target_arch=x86_64&amp;target_version=10&amp;target_type=exelocal">Here</a> to download cuda11.0 executable file)<img src="cuda11.0.PNG" alt=""></p> </li> <li> <p>Double click to install directly.</p> </li> <li> <p>Open the command line and enter the nvcc -V command. The following message appears, indicating that the installation is successful.</p> <p><img src="cuda.PNG" alt=""></p> </li> </ol> <h3 id="install-visual-studio-2017">Install <strong>Visual Studio 2017</strong></h3> <ol> <li> <p>Download Visual Studio 2017(Click <a href="https://visualstudio.microsoft.com/zh-hans/vs/older-downloads/">Here</a> to download visual studio 2017 executable file)</p> </li> <li> <p>The community version of visual studio is free. It is recommended to install the community edition.</p> </li> <li> <p>Choose what you need to install.</p> <p><img src="vs.PNG" alt=""></p> </li> </ol> <h3 id="install-physika">Install PhysiKA</h3> <ol> <li> <p>pull the latest version of the Physika project by directly using <code>git clone</code>.</p> <pre><code>git clone https://github.com/PhysikaTeam/PhysIKA.git cd PhysIKA git submodule update --init --recursive` git checkout -b dev git pull origin dev </code></pre></li> <li> <p>Use cmake to compile and generate the corresponding project.</p> <p><img src="cmake1PNG.PNG" alt=""></p> </li> <li> <p>Configure to set up Visual Studio 2017 and 64-bit. Before that, make sure you install python3.7、cuda11.0 and Visual Studio 2017.</p> <p><img src="cmake1.PNG" style="zoom:50%;" /></p> </li> <li> <p>After generation, such a folder will be generated. Open with visual studio 2017 sln file.</p> <p><img src="fold.PNG" style="zoom:50%;" /></p> </li> <li> <p>Run the project under the example folder. You will see the following results.</p> <p><img src="result.PNG" style="zoom:50%;" /></p> </li> </ol> Docs: How to contribute to PhysIKA documentation https://PhysikaTeam.github.io/docs/contributing/physika-webset.html Mon, 01 Jan 0001 00:00:00 +0000 https://PhysikaTeam.github.io/docs/contributing/physika-webset.html <h2 id="prerequisites-and-installation">Prerequisites and installation</h2> <h3 id="install-hugo">Install Hugo</h3> <p>You need a <a href="https://github.com/gohugoio/hugo/releases">recent <strong>extended</strong> version</a> (we recommend version 0.53 or later) of <a href="https://gohugo.io/">Hugo</a> to do local builds and previews of sites (like this one) that use Docsy. If you install from the release page, make sure to get the <code>extended</code> Hugo version, which supports <a href="https://sass-lang.com/documentation/file.SCSS_FOR_SASS_USERS.html">SCSS</a>; you may need to scroll down the list of releases to see it.</p> <p>For comprehensive Hugo documentation, see <a href="https://gohugo.io/">gohugo.io</a>.</p> <p>To see if you already have hugo installed and check the installed version, run the following commands:</p> <pre><code>hugo version </code></pre><h4 id="windows">windows</h4> <p>1.Download hugo executable file</p> <p>Click <a href="https://github.com/gohugoio/hugo/releases">Here</a> to download hugo executable file, you must download an extended version. For example, an 64bit windows OS should download <code>hugo_extended_0.75.1_Windows-64bit.zip</code>.</p> <p>2.Config the path</p> <p>Config the path where .exe file exist to environment variables. The path should not have spaces, which may cause some unexpected problems.</p> <p>For example, the path of <code>D:\Hugo\bin</code> is ok. The path of <code>D:\Program Files (x86)\Hugo\bin</code> may cause some unexpected problems.</p> <h4 id="linux">Linux</h4> <p>Do <strong>not</strong> use <code>sudo apt-get install hugo</code>, as it currently doesn&rsquo;t get you the <code>extended</code> version.</p> <p>If you&rsquo;ve already installed Hugo, check your version:</p> <pre><code>hugo version </code></pre><p>If the result is <code>v0.52</code> or earlier, or if you don&rsquo;t see <code>Extended</code>, you&rsquo;ll need to install the latest version.</p> <ol> <li> <p>Go to the <a href="https://github.com/gohugoio/hugo/releases">Hugo releases</a> page.</p> </li> <li> <p>In the most recent release, scroll down until you find a list of <strong>Extended</strong> versions.</p> </li> <li> <p>Download the latest extended version (<code>hugo_extended_0.5X_Linux-64bit.tar.gz</code>).</p> </li> <li> <p>Create a new directory:</p> <pre><code>mkdir hugo </code></pre> </li> <li> <p>Extract the files you downloaded to <code>hugo</code>.</p> </li> <li> <p>Switch to your new directory:</p> <pre><code>cd hugo </code></pre> </li> <li> <p>Install Hugo:</p> <pre><code>sudo install hugo /usr/bin </code></pre> </li> </ol> <h4 id="macos">macOS</h4> <p>Install Hugo using <a href="https://gohugo.io/getting-started/installing/#homebrew-macos">Brew</a>.</p> <h2 id="install-nodejs-and-npm">Install Node.js and npm</h2> <p>To see if you already have Node.js and npm installed and check the installed version, run the following commands:</p> <pre><code>node -v npm -v </code></pre><p>Click <a href="http://nodejs.cn/download/">Here</a> to download Node.js and install it.</p> <h2 id="install-postcss">Install PostCSS</h2> <p>To build or update your site&rsquo;s CSS resources, you also need <a href="https://postcss.org/"><code>PostCSS</code></a> to create the final assets. If you need to install it, you must have a recent version of <a href="https://nodejs.org/en/">NodeJS</a> installed on your machine so you can use <code>npm</code>, the Node package manager. By default <code>npm</code> installs tools under the directory where you run <code>npm install</code>:</p> <pre><code>npm install postcss --save-dev npm install -D --save autoprefixer npm install -D --save postcss-cli </code></pre><p>Note that versions of <code>PostCSS</code> later than 5.0.1 will not load <code>autoprefixer</code> if installed <a href="https://flaviocopes.com/npm-packages-local-global/">globally</a>, you must use a local install.</p> <h2 id="clone-physika-webset-code-and-run">Clone PhysiKA webset code and run</h2> <ol> <li> <p>Make a local working copy of the PhysiKA webset directly using <code>git clone</code>:</p> <pre><code>git clone https://github.com/PhysikaTeam/PhysIKA-website.git </code></pre> </li> <li> <p>Switch to the root of the cloned project, for example:</p> <pre><code> cd physIKA-website </code></pre> </li> <li> <p>Build your site:</p> <pre><code> hugo server </code></pre> </li> <li> <p>Preview your site in your browser at: http://localhost:1313/. You can use <code>Ctrl + c</code> to stop the Hugo server whenever you like.</p> </li> </ol> <p>In the cmd of windows, enter into current folder, and input <code>hugo server</code> to launch the local server. <img src="" alt="screen shot"></p> <h2 id="pull-requests">Pull requests</h2> <p>Finally, you should make an &ldquo;Pull requests&rdquo; at our github repository. Thanks for your contribution to PhysIKA opensource project!</p> <h2 id="publishing-website">Publishing website</h2> <ol> <li> <p>Generate public folder</p> <pre><code> cd physiIKA-website hugo </code></pre> </li> <li> <p>Push files(If you have permission)</p> <pre><code> cd public git init git add -A git commit -am &quot;init&quot; git remote add origin https://github.com/PhysikaTeam/PhysikaTeam.github.io git push -f origin master </code></pre> </li> <li> <p>Modify Custom domain(If you have permission) Enter the settings of the PhysikaTeam.github.io project(<a href="https://github.com/PhysikaTeam/PhysikaTeam.github.io/settings)">https://github.com/PhysikaTeam/PhysikaTeam.github.io/settings)</a>. Add <code>www.physika.net</code> in Custom domain. Wait a few minutes, you can see PhysiIKA website on <code>www.physika.net</code>.</p> </li> </ol> <h1 id="if-our-project-is-helpful-to-you-give-a-star-and-watch-us">If our project is helpful to you, give a star and watch us!!!</h1>