We're sorry but this page doesn't work properly without JavaScript enabled. Please enable it to continue.
Feedback

The Concise Common Workflow Language

00:00

Formal Metadata

Title
The Concise Common Workflow Language
Subtitle
Concision and elegance in a workflow language using lisp
Alternative Title
Concise Common Workflow Language
Title of Series
Number of Parts
Author
Contributors
License
CC Attribution 2.0 Belgium:
You are free to use, adapt and copy, distribute and transmit the work or content in adapted or unchanged form for any legal purpose as long as the work is attributed to the author in the manner specified by the author or licensor.
Identifiers
Publisher
Release Date
Language

Content Metadata

Subject Area
Genre
Abstract
Scientific workflows are readily and most easily expressed as shell scripts. However, shell scripts are notorious for being "duct tape", and are hard to adapt to different hardware and software environments. Workflow languages such as the Common Workflow Language (CWL) were developed to address this pain point. However, CWL does come at the cost of increased verbosity and reduced readability. Even seasoned scientists shy away from writing CWL, and fall back to the familiarity of shell scripts. This need not be. There is no reason to inflict the behind-the-scenes complexity of workflow languages on the user. It should be possible to automatically translate (in other words, compile) a simple shell-like script into a workflow language specification. In effect, we create a new domain specific language that is almost as easy to write as a shell script, but compiles to CWL. No other language is better suited to this task of creating domain specific languages than lisp. The lisps with their homoiconicity and unique macro system empower the programmer to use ordinary code to hack the compiler itself. In this talk, I will present the Concise Common Workflow Language (ccwl). The Concise Common Workflow Language (ccwl) is a concise syntax to express CWL workflows. It is a compiler that compiles a simple lispy shell-like workflow specification into a CWL workflow. It is implemented in the Scheme programming language, a minimalist dialect of lisp. I will discuss the considerations that went into the design of ccwl, and demonstrate its expressive power with illustrative examples.
WordDirectory serviceScripting languageoutputProcess (computing)Flow separationCodeFluid staticsSoftwareComputer hardwareIntegrated development environmentCluster samplingExplosionComputer fileReduction of orderGastropod shellProblemorientierte ProgrammierspracheNumbering schemeLatent heatProgramming languageComputer fileoutputTerm (mathematics)Directory serviceScripting languageFunction (mathematics)Computer hardwareEntire functionData managementIntegrated development environmentForm (programming)Category of beingWordSemiconductor memoryBoilerplate (text)LogicSingle-precision floating-point formatLine (geometry)LaptopVirtual machinePortable communications deviceGoodness of fitMultiplication signRun time (program lifecycle phase)Internet service providerComputer programmingCodeSoftwareMereologyError messageGastropod shellLimit (category theory)DampingSoftware bugString (computer science)Type theoryDifferent (Kate Ryan album)Traffic reportingFerry CorstenNumbering schemeProblemorientierte ProgrammierspracheQuicksortElectronic mailing listData analysisTouchscreenArtificial lifeTypprüfungProgrammer (hardware)Process (computing)Data dictionaryFlow separationLipschitz-StetigkeitWritingInterface (computing)Group actionLetterpress printingNetwork topologyThermal conductivityExpert systemComplex (psychology)Profil (magazine)Parameter (computer programming)BuildingCASE <Informatik>DataflowCompilation albumTask (computing)TelecommunicationSubject indexingArithmetic meanCombinational logicInsertion lossReal numberObject (grammar)DigitizingAddress spaceSoftware developerFilm editingArmBit rateXMLComputer animation
Demo (music)Gamma functionData dictionaryEmailGastropod shellDampingDataflowWordData dictionaryComputer animation
outputDefault (computer science)WordCodeHeegaard splittingNumbering schemeCASE <Informatik>Function (mathematics)Alphabet (computer science)Electronic mailing listType theoryoutputFlagStandard deviationComputer fileArithmetic meanFamilyComputer animationXMLUMLProgram flowchart
CASE <Informatik>Tape driveoutputWordFunction (mathematics)Multiplication signType theoryEquivalence relationComputer fileStandard deviationXMLProgram flowchartComputer animation
World Wide Web ConsortiumWordEmailQuicksortWordData dictionaryGame theorySingle-precision floating-point formatoutputUniqueness quantificationType theoryFlagComputer fileStandard deviationFunction (mathematics)BuildingEntropie <Informationstheorie>Right angleProjective planeDean numberXMLUMLProgram flowchartComputer animation
EmailData dictionaryoutputData dictionaryComputer fileType theory2 (number)Function (mathematics)Pairwise comparisonRoyal NavyExtension (kinesiology)XMLProgram flowchartJSON
WordData dictionaryoutputForm (programming)Type theoryComputer fileMultiplication signXMLUMLProgram flowchartSource codeJSON
Demo (music)Data dictionaryGastropod shellFunction (mathematics)Graph (mathematics)Visualization (computer graphics)outputCompilation albumContext awarenessMultiplication signPlastikkartePlotterVideo gameMessage passingOpen setComputer animation
Shape (magazine)SubgraphoutputFunction (mathematics)Demo (music)Graph (mathematics)EmailData dictionaryWordView (database)Single-precision floating-point formatCASE <Informatik>Source codeComputer animationXMLUMLProgram flowchart
EmailGamma functionWordCASE <Informatik>Function (mathematics)outputForm (programming)Military baseComputer animation
Function (mathematics)Demo (music)Graph (mathematics)SubgraphGamma functionLemma (mathematics)outputWordWorld Wide Web ConsortiumPrice indexCASE <Informatik>outputWordGastropod shellQuicksortFunction (mathematics)Source codeProgram flowchartXMLUML
WordGamma functionDemo (music)Graph (mathematics)outputGastropod shelloutputWordQuicksortMessage passingVisualization (computer graphics)Computer clusterArmWhiteboardPlastikkarteExtension (kinesiology)Multiplication signData dictionaryForm (programming)Computer fileType theorySource codeXMLProgram flowchartUML
Demo (music)Gamma functionGraph (mathematics)SubgraphWordWorld Wide Web ConsortiumConstructor (object-oriented programming)Exterior algebraUniverse (mathematics)Data dictionaryQuicksortIdentifiabilityOrder (biology)Source codeJSONXMLProgram flowchart
Function (mathematics)Graph (mathematics)SubgraphData dictionaryFunction (mathematics)BuildingData dictionaryQuicksortoutputProjective planeDependent and independent variablesWordSource codeComputer animationXMLUMLProgram flowchartJSON
Data dictionaryWorld Wide Web ConsortiumFunction (mathematics)MereologyGreen's functionPrice indexWebsiteQuicksortForm (programming)
Data dictionaryWordWeb Ontology LanguageoutputWorld Wide Web ConsortiumModel-driven engineeringWeightData dictionarySpacetimeWordArmForm (programming)Source code
Gamma functionGraph (mathematics)Dew pointDemo (music)Position operatorDataflowOnline helpVideo gameArithmetic meanPoint (geometry)Program flowchartComputer animationSource code
Demo (music)Gamma functionData dictionaryStatisticsShared memoryMultiplication signFluid staticsTape driveBitType theorySource codeComputer animation
Gamma functionDemo (music)Data dictionaryUniqueness quantificationHausdorff spaceHash functionDirectory serviceComputer fileFunction (mathematics)Source codeComputer animation
Demo (music)Data dictionaryArithmetic meanComputer fileComputer-assisted translationError messageDemo (music)WordData dictionaryCompilation albumMessage passingCombinational logicSource codeJSONComputer animation
Demo (music)Arithmetic meanData dictionaryMassCompilation albumComputer fileQuantumPRINCE2Line (geometry)Numbering schemeMessage passingTraffic reportingContext awarenessoutputSource codeError messageType theoryComputer animationSource code
Data dictionaryDemo (music)Asynchronous Transfer ModeType theoryNumbering schemeProjective planeContext awarenessSource codeError messageFehlererkennungComputer programmingLine (geometry)Source code
WebsiteSoftware repositoryMotion capturePrisoner's dilemmaYouTubeWebsiteEmailDemo (music)Computer animation
Programming languageComputer virusVideo gameComputer-assisted translationPlanningComputer animationMeeting/Interview
Online chatExtension (kinesiology)Gastropod shellVariable (mathematics)Standard deviationInternet service providerIntegrated development environmentDescriptive statisticsProgramming languageFunction (mathematics)CodeoutputSoftware developerContext awarenessPlanningKeyboard shortcutSingle-precision floating-point formatFile formatMultiplication signBlogParameter (computer programming)Data conversionPoint (geometry)Arithmetic progressionOnline helpLink (knot theory)Validity (statistics)Axiom of choiceCASE <Informatik>Table (information)Physical lawBinary codeQuicksortDataflowCivil engineeringSocial classDegree (graph theory)WordINTEGRALMeeting/Interview
Data dictionaryTouchscreenParameter (computer programming)Function (mathematics)Hash functionOnline chatWordHeegaard splittingMeeting/Interview
Wechselseitige InformationGamma functionMacro (computer science)Exception handlingError messageNumbering schemeComputer fileLine (geometry)Source codeCategory of beingExpressionSystem callSubject indexingService (economics)RadiusComputer animationMeeting/Interview
Source codeUniform resource locatorRun time (program lifecycle phase)Object (grammar)Exception handlingMacro (computer science)Line (geometry)Numbering schemeGreen's functionWater vaporExpressionArmMultiplication signMeeting/Interview
AuthorizationMultiplication signMeeting/InterviewComputer animation
Transcript: Englisch(auto-generated)