Epstein Files Full PDF

CLICK HERE
Technopedia Center
PMB University Brochure
Faculty of Engineering and Computer Science
S1 Informatics S1 Information Systems S1 Information Technology S1 Computer Engineering S1 Electrical Engineering S1 Civil Engineering

faculty of Economics and Business
S1 Management S1 Accountancy

Faculty of Letters and Educational Sciences
S1 English literature S1 English language education S1 Mathematics education S1 Sports Education
teknopedia

  • Registerasi
  • Brosur UTI
  • Kip Scholarship Information
  • Performance
Flag Counter
  1. World Encyclopedia
  2. Futhark (programming language) - Wikipedia
Futhark (programming language) - Wikipedia
From Wikipedia, the free encyclopedia
Programming language
Futhark
Paradigmarray, functional
FamilyML
Designed byTroels Henriksen, Cosmin Oancea, Martin Elsman
DeveloperUniversity of Copenhagen[1]
First appeared2014; 12 years ago (2014)
Typing disciplineinferred, static, strong, Hindley–Milner, uniqueness, dependent
OScross-platform
LicenseISC
Websitefuthark-lang.org
Influenced by
APL, Haskell, NESL, Standard ML

Futhark is a multi-paradigm, high-level, functional, data parallel, array programming language. It is a dialect of the language ML, originally developed at UCPH Department of Computer Science (DIKU) as part of the HIPERFIT project.[2] It focuses on enabling data parallel programs written in a functional style to be executed with high performance on massively parallel hardware, especially graphics processing units (GPUs). Futhark is strongly inspired by NESL, and its implementation uses a variant of the flattening transformation, but imposes constraints on how parallelism can be expressed in order to enable more aggressive compiler optimisations. In particular, irregular nested data parallelism is not supported.[3] It is free and open-source software released under an ISC license.

Overview

[edit]

Futhark is a language in the ML family, with an indentation-insensitive syntax derived from OCaml, Standard ML, and Haskell. The type system is based on a Hindley–Milner type system with a variety of extensions, such as uniqueness types and size-dependent types. Futhark is not intended as a general-purpose programming language for writing full applications, but is instead focused on writing compute kernels (not always the same as a GPU kernel) which are then invoked from applications written in conventional languages.[4]

Futhark is named after the first six letters of the Runic alphabet.[5]: 2 

Examples

[edit]

Dot product

[edit]

The following program computes the dot product of two vectors containing double-precision numbers.

def dotprod xs ys = f64.sum (map2 (*) xs ys))

It can also be equivalently written with explicit type annotations as follows.

def dotprod [n] (xs: [n]f64) (ys: [n]f64) : f64 = f64.sum (map2 (*) xs ys))

This makes the size-dependent types explicit: this function can only be invoked with two arrays of the same size, and the type checker will reject any program where this cannot be statically determined.

Matrix multiplication

[edit]

The following program performs matrix multiplication, using the definition of dot product above.

def matmul [n][m][p] (A: [n][m]f64) (B: [m][p]f64) : [n][p]f64 =
  map (\A_row ->
         map (\B_col -> dotprod A_row B_col)
             (transpose B))
      A

This shows how the types enforce that the function is only invoked with matrices of compatible size. Also, it is an example of nested data parallelism.

References

[edit]
  1. ^ "License". futhark-lang.org. Retrieved 2023-03-26. Developed at DIKU
  2. ^ "Home". hiperfit.dk.
  3. ^ Henriksen, Troels; Serup, Niels G. W.; Elsman, Martin; Henglein, Fritz; Oancea, Cosmin (2017). "Futhark: Purely Functional GPU-Programming with Nested Parallelism and In-Place Array Updates" (PDF). Proceedings of the 38th ACM SIGPLAN Conference on Programming Language Design and Implementation. PLDI 2017. ACM.
  4. ^ "Futhark User's Guide". futhark.readthedocs.io.
  5. ^ Troels, Henriksen (November 2017). Design and Implementation of the Futhark Programming Language (PDF) (PhD thesis). University of Copenhagen. Retrieved 2024-05-25.
  • v
  • t
  • e
ML programming
Software
Implementations,
dialects
Caml
  • OCaml°
    • Eff
    • F*°
    • F#°
    • JoCaml°
    • Reason°
Standard ML
  • Alice°
  • Concurrent ML
  • Extended ML
  • MLton°
  • Standard ML of New Jersey° (SML/NJ)
Dependent ML
  • ATS°
  • Futhark°
  • Lazy ML
  • MacroML
  • Ur°
Programming tools
  • Alt-Ergo°
  • Astrée
  • Camlp4°
  • CompCert°
  • FFTW°
  • Frama-C°
  • Haxe°
  • Marionnet°
  • MTASC°
  • Poplog°
  • Semgrep°
  • SLAM project
  • Theorem provers,
    proof assistants
    • HOL°
      • HOL Light°
    • Isabelle°
    • LEGO
    • Logic for Computable Functions
    • Matita°
    • Rocq°
    • Twelf°
    • GeneWeb°
    Community
    Designers
  • Lennart Augustsson (Lazy ML)
  • Damien Doligez (OCaml)
  • Gérard Huet (Caml)
  • Xavier Leroy (Caml, OCaml)
  • Robin Milner (ML)
  • Don Sannella (Extended ML)
  • Don Syme (F#)
    • Thierry Coquand
    • Steven G. Johnson
    • Christine Paulin-Mohring
    • Frank Pfenning
    • Simon Thompson
  • Italics = discontinued
  • ° = Open-source software
    Book Categories: Family:ML • Family:OCaml • Software:OCaml
    • v
    • t
    • e
    Parallel computing
    General
    • Distributed computing
    • Parallel computing
    • Parallel algorithm
    • Massively parallel
    • Cloud computing
    • High-performance computing
    • Multiprocessing
    • Manycore processor
    • GPGPU
    • Computer network
    • Systolic array
    Levels
    • Bit
    • Instruction
    • Thread
    • Task
    • Data
    • Memory
    • Loop
    • Pipeline
    Multithreading
    • Temporal
    • Simultaneous (SMT)
    • Simultaneous and heterogenous
    • Speculative (SpMT)
    • Preemptive
    • Cooperative
    • Clustered multi-thread (CMT)
    • Hardware scout
    Theory
    • PRAM model
    • PEM model
    • Analysis of parallel algorithms
    • Amdahl's law
    • Gustafson's law
    • Cost efficiency
    • Karp–Flatt metric
    • Slowdown
    • Speedup
    Elements
    • Process
    • Thread
    • Fiber
    • Instruction window
    • Array
    Coordination
    • Multiprocessing
    • Memory coherence
    • Cache coherence
    • Cache invalidation
    • Barrier
    • Synchronization
    • Application checkpointing
    Programming
    • Stream processing
    • Dataflow programming
    • Models
      • Implicit parallelism
      • Explicit parallelism
      • Concurrency
    • Non-blocking algorithm
    Hardware
    • Flynn's taxonomy
      • SISD
      • SIMD
        • Array processing (SIMT)
        • Pipelined processing
        • Associative processing
      • MISD
      • MIMD
    • Dataflow architecture
    • Pipelined processor
    • Superscalar processor
    • Vector processor
    • Multiprocessor
      • symmetric
      • asymmetric
    • Memory
      • shared
      • distributed
      • distributed shared
      • UMA
      • NUMA
      • COMA
    • Massively parallel computer
    • Computer cluster
      • Beowulf cluster
    • Grid computer
    • Hardware acceleration
    APIs
    • Ateji PX
    • Boost
    • Chapel
    • HPX
    • Charm++
    • Cilk
    • Coarray Fortran
    • CUDA
    • Dryad
    • C++ AMP
    • Global Arrays
    • GPUOpen
    • MPI
    • OpenMP
    • OpenCL
    • OpenHMPP
    • OpenACC
    • Parallel Extensions
    • PVM
    • pthreads
    • RaftLib
    • ROCm
    • UPC
    • TBB
    • ZPL
    Problems
    • Automatic parallelization
    • Cache stampede
    • Deadlock
    • Deterministic algorithm
    • Embarrassingly parallel
    • Parallel slowdown
    • Race condition
    • Software lockout
    • Scalability
    • Starvation
    •  Category: Parallel computing
    Retrieved from "https://teknopedia.ac.id/w/index.php?title=Futhark_(programming_language)&oldid=1271834659"
    Categories:
    • Programming languages
    • High-level programming languages
    • Functional languages
    • Parallel computing
    • Array programming languages
    • Dependently typed languages
    • Dependently typed programming
    • Statically typed programming languages
    • ML programming language family
    • Free and open source compilers
    • 2014 software
    • Programming languages created in 2014
    • Software using the ISC license
    Hidden categories:
    • Articles with short description
    • Short description matches Wikidata

    • indonesia
    • Polski
    • العربية
    • Deutsch
    • English
    • Español
    • Français
    • Italiano
    • مصرى
    • Nederlands
    • 日本語
    • Português
    • Sinugboanong Binisaya
    • Svenska
    • Українська
    • Tiếng Việt
    • Winaray
    • 中文
    • Русский
    Sunting pranala
    url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url url
    Pusat Layanan

    UNIVERSITAS TEKNOKRAT INDONESIA | ASEAN's Best Private University
    Jl. ZA. Pagar Alam No.9 -11, Labuhan Ratu, Kec. Kedaton, Kota Bandar Lampung, Lampung 35132
    Phone: (0721) 702022
    Email: pmb@teknokrat.ac.id