Skip to content
Snippets Groups Projects
Select Git revision
  • d3f62364cf512cd9d93a93d89170cfea1bb2b0a1
  • master default protected
  • suffa/cumulantfourth_order_correction_with_psm
  • mr_refactor_wfb
  • Sparse
  • WallLaw
  • improved_comm
  • release/1.3.7
  • release/1.3.6
  • release/1.3.5
  • release/1.3.4
  • release/1.3.3
  • release/1.3.2
  • release/1.3.1
  • release/1.3
  • release/1.2
  • release/1.1.1
  • release/1.1
  • release/1.0.1
  • release/1.0
  • release/0.4.4
  • release/0.4.3
  • release/0.4.2
  • release/0.4.1
  • release/0.4.0
  • release/0.3.4
  • release/0.3.3
27 results

03_tutorial_lbm_formulation.ipynb

Blame
  • ComposerFeatures.py 1.70 KiB
    from pystencilssfg import SourceFileGenerator
    
    
    with SourceFileGenerator() as sfg:
    
        sfg.function("factorial").params(sfg.var("n", "uint64")).returns(
            "uint64"
        ).inline().constexpr()(
            sfg.branch("n == 0")("return 1;")("return n * factorial(n - 1);")
        )
    
        q = sfg.var("q", "double")
        k = sfg.var("k", "uint64_t")
        x = sfg.var("x", "double")
    
        sfg.include("<cmath>")
    
        sfg.struct("Series")(
            sfg.method("geometric")
            .static()
            .attr("nodiscard")
            .params(q, k)
            .returns("double")(
                sfg.branch("k == 0")(
                    "return 1.0;"
                )(
                    "return Series::geometric(q, k - 1) + std::pow(q, k);"
                )
            )
        )
    
        sfg.struct("ConstexprMath")(
            sfg.method("abs").static().constexpr().inline()
            .params(x)
            .returns("double")
            (
                "if (x >= 0.0) return x; else return -x;"
            ),
    
            sfg.method("geometric")
            .static()
            .constexpr()
            .inline()
            .params(q, k)
            .returns("double")(
                sfg.branch("k == 0")(
                    "return 1.0;"
                )(
                    "return 1 + q * ConstexprMath::geometric(q, k - 1);"
                )
            )
        )
    
        with sfg.namespace("inheritance_test"):
            sfg.klass("Parent")(
                sfg.public(
                    sfg.method("compute").returns("int").virtual().const()(
                        "return 24;"
                    )
                )
            )
    
            sfg.klass("Child", bases=["public Parent"])(
                sfg.public(
                    sfg.method("compute").returns("int").override().const()(
                        "return 31;"
                    )
                )
            )