Difference between revisions of "Code Sprint 2017-04-04"

From VTKM
Jump to navigation Jump to search
 
(6 intermediate revisions by 2 users not shown)
Line 1: Line 1:
Our third code sprint was held on April 4-6, 2017 and was hosted at the University of Oregon.
+
 
 +
[[File:CodeSprint2017 GroupPicture.png|800px]]
 +
 
 +
Our third code sprint was held on April 4-6, 2017 and was hosted at the University of Oregon. Pictured left-to-right:  James Kress (ORNL/UO), Abhishek Yenpure (UO), Sudhanshu Sane (UO), Manish Mathai (UO), Matt Larsen (LLNL), Nicole Marsaglia (UO), Bernd Hentschel (RWTH-Aachen), Brent Lessley (UO), Roba Binyahib (UO), Rob Maynard (Kitware), Hank Childs (UO), Stephanie Labasan (LLNL/UO), Dave Pugmire (ORNL), Ken Moreland (SNL), David Lonie (Kitware), Mark Kim (ORNL), Dongliang Chu (ORNL), Tom Otahal (SNL), and Alberto Villareal (Intel).
 +
 
  
 
http://ix.cs.uoregon.edu/~hank/vtkm17.html
 
http://ix.cs.uoregon.edu/~hank/vtkm17.html
  
Possible topics:
+
=== Get VTK-m Now ===
 +
 
 +
Get the latest version of the '''[[Media:VTKmUsersGuide.pdf|VTK-m Users' Guide]]'''. (I just uploaded an updated version.)
 +
 
 +
If you have not yet, get VTK-m on your laptop now by cloning the following URL:
 +
 
 +
:https://gitlab.kitware.com/vtk/vtk-m.git
 +
 
 +
Build it. The Users' Guide has some instructions.
 +
 
 +
=== Possible topics ===
  
 
* Sources (wavelet, tangle field, [https://github.com/PETTT/miniIO miniIO])
 
* Sources (wavelet, tangle field, [https://github.com/PETTT/miniIO miniIO])
Line 14: Line 28:
 
* Clean up old [https://gitlab.kitware.com/vtk/vtk-m/merge_requests merge requests]
 
* Clean up old [https://gitlab.kitware.com/vtk/vtk-m/merge_requests merge requests]
 
* Redesign error reporting
 
* Redesign error reporting
 +
 +
=== Participants ===
  
 
{|
 
{|
 
! Participant || From || Project
 
! Participant || From || Project
 
|-
 
|-
| Dongliang Chu || ORNL ||  
+
| Dongliang Chu || ORNL || particle advection
 +
|-
 +
| Mark Kim || ORNL || particle advection, ray tracing
 
|-
 
|-
| Mark Kim || ORNL ||
+
| James Kress || ORNL || particle advection
 
|-
 
|-
| James Kress || ORNL ||
+
| Matt Larsen || LLNL || hash function bakeoff, ray-tracing infrastructure, spatial search structures, point-based rendering
 
|-
 
|-
| Matt Larsen || LLNL ||
+
| David Lonie || Kitware || reducing VTK-m library size, virtual functions
 
|-
 
|-
| David Lonie || Kitware ||
+
| Rob Maynard || Kitware || answer questions!
 
|-
 
|-
| Rob Maynard || Kitware ||
+
| Ken Moreland || SNL || hash function bakeoff
 
|-
 
|-
| Ken Moreland || SNL ||
+
| Thomas Otahal || SNL || vectorization/threading on Xeon Phi
 
|-
 
|-
| Thomas Otahal || SNL ||
+
| David Pugmire || ORNL || particle advection
 
|-
 
|-
| David Pugmire || ORNL ||
+
| Brent Lessley || UO || hash function bakeoff, graph analysis
 +
|-
 +
| Alberto Villareal || Intel || vectorization/threading on Xeon Phi
 +
|-
 +
| Hank Childs || UO || "getting started", particle advection, spatial search structures
 +
|-
 +
| Bernd Hentschel || Aachen || "getting started", particle advection
 
|}
 
|}
 +
 +
=== Quick Tutorial ===
 +
 +
To follow along (or do on your own) clone:
 +
 +
:https://gitlab.kitware.com/kmorel/vtkm-exercises
 +
 +
=== Quick Poll on Signature Types ===
 +
 +
VTK-m's heavy use of templates requires many type aliases to be defined. Originally we used <tt>typedef</tt> exclusively for this, but recently we moved to <tt>using</tt>. The effect of the two keywords is equivalent, but we like the syntax of <tt>using</tt> better because it brings the name being defined to the front of the statement, which makes it easier to see and read.
 +
 +
One current disagreement the designers have is whether we should use <tt>using</tt> for signatures (like <tt>ControlSignature</tt> and <tt>ExecutionSignature</tt>) or we should keep using <tt>typedef</tt>. The argument for <tt>using</tt> is that it cleanly separates the signature from the alias name. The argument for <tt>typedef</tt> is that the declaration itself looks like a function prototype declaration and will be easier for end users to grok the high level concept.
 +
 +
Here is a comparison. The following code is copied from a worklet for extract surface. It is nontrivial but not abnormal. The current implementation here uses <tt>typedef</tt>
 +
 +
<source lang="cpp">
 +
    typedef void ControlSignature(CellSetIn cellset,
 +
                                  FieldOut<> faceHashes,
 +
                                  FieldOut<> originCells,
 +
                                  FieldOut<> originFaces);
 +
    typedef void ExecutionSignature(_2,
 +
                                    _3,
 +
                                    _4,
 +
                                    CellShape,
 +
                                    FromIndices,
 +
                                    InputIndex,
 +
                                    VisitIndex);
 +
</source>
 +
 +
Now here is the same declarations using the <tt>using</tt> keyword instead.
 +
 +
<source lang="cpp">
 +
    using ControlSignature = void(CellSetIn cellset,
 +
                                  FieldOut<> faceHashes,
 +
                                  FieldOut<> originCells,
 +
                                  FieldOut<> originFaces);
 +
    using ExecutionSignature = void(_2,
 +
                                    _3,
 +
                                    _4,
 +
                                    CellShape,
 +
                                    FromIndices,
 +
                                    InputIndex,
 +
                                    VisitIndex);
 +
</source>
 +
 +
Since we have several users from different backgrounds, this is a good time to collect several opinions.

Latest revision as of 11:23, 6 April 2017

CodeSprint2017 GroupPicture.png

Our third code sprint was held on April 4-6, 2017 and was hosted at the University of Oregon. Pictured left-to-right: James Kress (ORNL/UO), Abhishek Yenpure (UO), Sudhanshu Sane (UO), Manish Mathai (UO), Matt Larsen (LLNL), Nicole Marsaglia (UO), Bernd Hentschel (RWTH-Aachen), Brent Lessley (UO), Roba Binyahib (UO), Rob Maynard (Kitware), Hank Childs (UO), Stephanie Labasan (LLNL/UO), Dave Pugmire (ORNL), Ken Moreland (SNL), David Lonie (Kitware), Mark Kim (ORNL), Dongliang Chu (ORNL), Tom Otahal (SNL), and Alberto Villareal (Intel).


http://ix.cs.uoregon.edu/~hank/vtkm17.html

Get VTK-m Now

Get the latest version of the VTK-m Users' Guide. (I just uploaded an updated version.)

If you have not yet, get VTK-m on your laptop now by cloning the following URL:

https://gitlab.kitware.com/vtk/vtk-m.git

Build it. The Users' Guide has some instructions.

Possible topics

  • Sources (wavelet, tangle field, miniIO)
  • Hash function bake off
  • Image comparison testing
  • Filters compiled into library
  • Dynamic classes
  • Fix exports in rendering library for OSX
  • Build simple "tutorial" exercises
  • Clean up old merge requests
  • Redesign error reporting

Participants

Participant From Project
Dongliang Chu ORNL particle advection
Mark Kim ORNL particle advection, ray tracing
James Kress ORNL particle advection
Matt Larsen LLNL hash function bakeoff, ray-tracing infrastructure, spatial search structures, point-based rendering
David Lonie Kitware reducing VTK-m library size, virtual functions
Rob Maynard Kitware answer questions!
Ken Moreland SNL hash function bakeoff
Thomas Otahal SNL vectorization/threading on Xeon Phi
David Pugmire ORNL particle advection
Brent Lessley UO hash function bakeoff, graph analysis
Alberto Villareal Intel vectorization/threading on Xeon Phi
Hank Childs UO "getting started", particle advection, spatial search structures
Bernd Hentschel Aachen "getting started", particle advection

Quick Tutorial

To follow along (or do on your own) clone:

https://gitlab.kitware.com/kmorel/vtkm-exercises

Quick Poll on Signature Types

VTK-m's heavy use of templates requires many type aliases to be defined. Originally we used typedef exclusively for this, but recently we moved to using. The effect of the two keywords is equivalent, but we like the syntax of using better because it brings the name being defined to the front of the statement, which makes it easier to see and read.

One current disagreement the designers have is whether we should use using for signatures (like ControlSignature and ExecutionSignature) or we should keep using typedef. The argument for using is that it cleanly separates the signature from the alias name. The argument for typedef is that the declaration itself looks like a function prototype declaration and will be easier for end users to grok the high level concept.

Here is a comparison. The following code is copied from a worklet for extract surface. It is nontrivial but not abnormal. The current implementation here uses typedef

    typedef void ControlSignature(CellSetIn cellset,
                                  FieldOut<> faceHashes,
                                  FieldOut<> originCells,
                                  FieldOut<> originFaces);
    typedef void ExecutionSignature(_2,
                                    _3,
                                    _4,
                                    CellShape,
                                    FromIndices,
                                    InputIndex,
                                    VisitIndex);

Now here is the same declarations using the using keyword instead.

    using ControlSignature = void(CellSetIn cellset,
                                  FieldOut<> faceHashes,
                                  FieldOut<> originCells,
                                  FieldOut<> originFaces);
    using ExecutionSignature = void(_2,
                                    _3,
                                    _4,
                                    CellShape,
                                    FromIndices,
                                    InputIndex,
                                    VisitIndex);

Since we have several users from different backgrounds, this is a good time to collect several opinions.