diff --git a/404.html b/404.html index e5d015bdb..b6a745ca2 100644 --- a/404.html +++ b/404.html @@ -8,13 +8,13 @@ - - + +

404

Looks like we've got some broken links.
Take me home.
- + diff --git a/about.html b/about.html index a09130011..c65449dc7 100644 --- a/about.html +++ b/about.html @@ -8,8 +8,8 @@ - - + +
- + diff --git a/assets/css/0.styles.2922c98a.css b/assets/css/0.styles.2922c98a.css deleted file mode 100644 index 0febff5a9..000000000 --- a/assets/css/0.styles.2922c98a.css +++ /dev/null @@ -1 +0,0 @@ -svg[data-v-49140617]{position:absolute;right:7.5px;opacity:.75;cursor:pointer}svg.hover[data-v-49140617]{opacity:0}svg[data-v-49140617]:hover{opacity:1!important}span[data-v-49140617]{position:absolute;font-size:.85rem;line-height:.425rem;right:50px;opacity:0;transition:opacity .5s}.success[data-v-49140617]{opacity:1!important}.code-copy-added:hover>.code-copy svg{opacity:.75}code[class*=language-],pre[class*=language-]{color:#ccc;background:none;font-family:Consolas,Monaco,Andale Mono,Ubuntu Mono,monospace;font-size:1em;text-align:left;white-space:pre;word-spacing:normal;word-break:normal;word-wrap:normal;line-height:1.5;-moz-tab-size:4;-o-tab-size:4;tab-size:4;-webkit-hyphens:none;hyphens:none}pre[class*=language-]{padding:1em;margin:.5em 0;overflow:auto}:not(pre)>code[class*=language-],pre[class*=language-]{background:#2d2d2d}:not(pre)>code[class*=language-]{padding:.1em;border-radius:.3em;white-space:normal}.token.block-comment,.token.cdata,.token.comment,.token.doctype,.token.prolog{color:#999}.token.punctuation{color:#ccc}.token.attr-name,.token.deleted,.token.namespace,.token.tag{color:#e2777a}.token.function-name{color:#6196cc}.token.boolean,.token.function,.token.number{color:#f08d49}.token.class-name,.token.constant,.token.property,.token.symbol{color:#f8c555}.token.atrule,.token.builtin,.token.important,.token.keyword,.token.selector{color:#cc99cd}.token.attr-value,.token.char,.token.regex,.token.string,.token.variable{color:#7ec699}.token.entity,.token.operator,.token.url{color:#67cdcc}.token.bold,.token.important{font-weight:700}.token.italic{font-style:italic}.token.entity{cursor:help}.token.inserted{color:green}.theme-default-content code{color:#476582;padding:.25rem .5rem;margin:0;font-size:.85em;background-color:rgba(27,31,35,.05);border-radius:3px}.theme-default-content code .token.deleted{color:#ec5975}.theme-default-content code .token.inserted{color:#267cb9}.code-copy{position:absolute;bottom:0;right:0;z-index:3}.theme-default-content pre,.theme-default-content pre[class*=language-]{line-height:1.4;padding:1.25rem 1.5rem;margin:.85rem 0;background-color:#282c34;border-radius:6px;overflow:auto}.theme-default-content pre[class*=language-] code,.theme-default-content pre code{color:#fff;padding:0;background-color:transparent;border-radius:0}div[class*=language-]{position:relative;background-color:#282c34;border-radius:6px}div[class*=language-] .highlight-lines{-webkit-user-select:none;user-select:none;padding-top:1.3rem;position:absolute;top:0;left:0;width:100%;line-height:1.4}div[class*=language-] .highlight-lines .highlighted{background-color:rgba(0,0,0,.66)}div[class*=language-] pre,div[class*=language-] pre[class*=language-]{background:transparent;position:relative;z-index:1}div[class*=language-]:before{position:absolute;z-index:3;top:.8em;right:1em;font-size:.75rem;color:hsla(0,0%,100%,.4)}div[class*=language-]:not(.line-numbers-mode) .line-numbers-wrapper{display:none}div[class*=language-].line-numbers-mode .highlight-lines .highlighted{position:relative}div[class*=language-].line-numbers-mode .highlight-lines .highlighted:before{content:" ";position:absolute;z-index:3;left:0;top:0;display:block;width:3.5rem;height:100%;background-color:rgba(0,0,0,.66)}div[class*=language-].line-numbers-mode pre{padding-left:4.5rem;vertical-align:middle}div[class*=language-].line-numbers-mode .line-numbers-wrapper{position:absolute;top:0;width:3.5rem;text-align:center;color:hsla(0,0%,100%,.3);padding:1.25rem 0;line-height:1.4}div[class*=language-].line-numbers-mode .line-numbers-wrapper br{-webkit-user-select:none;user-select:none}div[class*=language-].line-numbers-mode .line-numbers-wrapper .line-number{position:relative;z-index:4;-webkit-user-select:none;user-select:none;font-size:.85em}div[class*=language-].line-numbers-mode:after{content:"";position:absolute;z-index:2;top:0;left:0;width:3.5rem;height:100%;border-radius:6px 0 0 6px;border-right:1px solid rgba(0,0,0,.66);background-color:#282c34}div[class~=language-js]:before{content:"js"}div[class~=language-ts]:before{content:"ts"}div[class~=language-html]:before{content:"html"}div[class~=language-md]:before{content:"md"}div[class~=language-vue]:before{content:"vue"}div[class~=language-css]:before{content:"css"}div[class~=language-sass]:before{content:"sass"}div[class~=language-scss]:before{content:"scss"}div[class~=language-less]:before{content:"less"}div[class~=language-stylus]:before{content:"stylus"}div[class~=language-go]:before{content:"go"}div[class~=language-java]:before{content:"java"}div[class~=language-c]:before{content:"c"}div[class~=language-sh]:before{content:"sh"}div[class~=language-yaml]:before{content:"yaml"}div[class~=language-py]:before{content:"py"}div[class~=language-docker]:before{content:"docker"}div[class~=language-dockerfile]:before{content:"dockerfile"}div[class~=language-makefile]:before{content:"makefile"}div[class~=language-javascript]:before{content:"js"}div[class~=language-typescript]:before{content:"ts"}div[class~=language-markup]:before{content:"html"}div[class~=language-markdown]:before{content:"md"}div[class~=language-json]:before{content:"json"}div[class~=language-ruby]:before{content:"rb"}div[class~=language-python]:before{content:"py"}div[class~=language-bash]:before{content:"sh"}div[class~=language-php]:before{content:"php"}.custom-block .custom-block-title{font-weight:600;margin-bottom:-.4rem}.custom-block.danger,.custom-block.tip,.custom-block.warning{padding:.1rem 1.5rem;border-left-width:.5rem;border-left-style:solid;margin:1rem 0}.custom-block.tip{background-color:#f3f5f7;border-color:#42b983}.custom-block.warning{background-color:rgba(255,229,100,.3);border-color:#e7c000;color:#6b5900}.custom-block.warning .custom-block-title{color:#b29400}.custom-block.warning a{color:#2c3e50}.custom-block.danger{background-color:#ffe6e6;border-color:#c00;color:#4d0000}.custom-block.danger .custom-block-title{color:#900}.custom-block.danger a{color:#2c3e50}.custom-block.details{display:block;position:relative;border-radius:2px;margin:1.6em 0;padding:1.6em;background-color:#eee}.custom-block.details h4{margin-top:0}.custom-block.details figure:last-child,.custom-block.details p:last-child{margin-bottom:0;padding-bottom:0}.custom-block.details summary{outline:none;cursor:pointer}.arrow{display:inline-block;width:0;height:0}.arrow.up{border-bottom:6px solid #ccc}.arrow.down,.arrow.up{border-left:4px solid transparent;border-right:4px solid transparent}.arrow.down{border-top:6px solid #ccc}.arrow.right{border-left:6px solid #ccc}.arrow.left,.arrow.right{border-top:4px solid transparent;border-bottom:4px solid transparent}.arrow.left{border-right:6px solid #ccc}.theme-default-content:not(.custom){max-width:740px;margin:0 auto;padding:2rem 2.5rem}@media (max-width:1280px){.theme-default-content:not(.custom){padding:2rem}}@media (max-width:500px){.theme-default-content:not(.custom){padding:1.5rem}}.table-of-contents .badge{vertical-align:middle}body,html{padding:0;margin:0;background-color:#fff}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:16px;color:#2c3e50}a{font-weight:500;color:#267cb9}a,a:hover{text-decoration:none}a:hover{color:#8a684f}.navbar{z-index:20;right:0;height:3.6rem;background-color:#fff;box-sizing:border-box;border-bottom:1px solid #eaecef}.navbar,.sidebar-mask{position:fixed;top:0;left:0}.sidebar-mask{z-index:9;width:100vw;height:100vh;display:none}.sidebar{font-size:16px;background-color:#fff;width:20rem;position:fixed;z-index:10;margin:0;top:3.6rem;left:0;bottom:0;box-sizing:border-box;border-right:1px solid #eaecef;overflow-y:auto}.sidebar .nav-links .nav-item{padding-left:0!important}.sidebar-heading{font-weight:600!important}.dropdown-wrapper{cursor:inherit!important}.dropdown-wrapper a,.dropdown-wrapper button{cursor:pointer}.dropdown-wrapper .nav-dropdown .dropdown-item em,.dropdown-wrapper .nav-dropdown .dropdown-item span{padding:0 1.5rem 0 1.25rem}.dropdown-wrapper .nav-dropdown .dropdown-subitem-wrapper .dropdown-subitem a,.dropdown-wrapper .nav-dropdown .dropdown-subitem-wrapper .dropdown-subitem em,.dropdown-wrapper .nav-dropdown .dropdown-subitem-wrapper .dropdown-subitem span{padding-left:2.2rem}.fullpage-content,.theme-default-content{height:100%}.fullpage-content img,.theme-default-content img{max-width:100%}.fullpage-content figure,.theme-default-content figure{max-width:130%;margin:0 -15%;text-align:center}.fullpage-content figcaption,.theme-default-content figcaption{margin:0 11.53%;font-style:italic;display:inline-block;text-align:left}.fullpage-content figcaption:before,.theme-default-content figcaption:before{content:"Figure: ";font-weight:700}@media (min-width:1600px){.fullpage-content img,.theme-default-content img{max-height:90%}.fullpage-content figure,.theme-default-content figure{max-width:150%;margin:0 -25%}.fullpage-content figcaption,.theme-default-content figcaption{margin:0 16.66%}}.theme-default-content:not(.custom)>:first-child{margin-top:3.6rem}.theme-default-content:not(.custom) p.demo{padding:1rem 1.5rem;border:1px solid #ddd;border-radius:4px}.theme-default-content.custom{padding:0;margin:0}.page{padding-left:20rem;padding-bottom:0}.page p a code{font-weight:400;color:#267cb9}.page kbd{background:#eee;border:.15rem solid #ddd;border-bottom:.25rem solid #ddd;border-radius:.15rem;padding:0 .15em}.page blockquote{font-size:1rem;color:#999;border-left:.2rem solid #dfe2e5;margin:1rem 0;padding:.25rem 0 .25rem 1rem}.page>p{margin:0}.page ol,.page ul{padding-left:1.2em}.page strong{font-weight:600}.page h1,.page h2,.page h3,.page h4,.page h5,.page h6{font-weight:600;line-height:1.25}.page h2,.page h3,.page h4{margin-top:-3.6rem;padding-top:3.6rem}.theme-default-content:not(.custom)>.page{margin-top:-3.1rem;padding-top:4.6rem;margin-bottom:0}.theme-default-content:not(.custom)>.page+.custom-block,.theme-default-content:not(.custom)>.page+p,.theme-default-content:not(.custom)>.page+pre,.theme-default-content:not(.custom)>.page:first-child,.theme-default-content:not(.custom)>.page margin-bottom 1rem,.theme-default-content:not(.custom)>.page margin-top -1.5rem{margin-top:2rem}.page:hover .header-anchor{opacity:1}.page h1{font-size:2.2rem}.page h2{font-size:1.65rem;padding-bottom:.3rem;border-bottom:1px solid #eaecef}.page h3{font-size:1.35rem}.page .line-number,.page code,.page kbd{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.page ol,.page p,.page ul{line-height:1.7}.page hr{border:0;border-top:1px solid #eaecef}.page table{border-collapse:collapse;margin:1rem 0;display:block;overflow-x:auto}.page tr{border-top:1px solid #dfe2e5}.page tr:nth-child(2n){background-color:#f6f8fa}.page td,.page th{border:1px solid #dfe2e5;padding:.6em 1em}a.header-anchor{font-size:.85em;float:left;margin-left:-.87em;padding-right:.23em;margin-top:.125em;opacity:0}a.header-anchor:hover{text-decoration:none}.theme-container.sidebar-open .sidebar-mask{display:block}.theme-container.no-navbar .theme-default-content:not(.custom)>h1,.theme-container.no-navbar h2,.theme-container.no-navbar h3,.theme-container.no-navbar h4,.theme-container.no-navbar h5,.theme-container.no-navbar h6{margin-top:1.5rem;padding-top:0}.theme-container.no-navbar .sidebar{top:0}@media (min-width:1025px){.theme-container.no-sidebar .sidebar{display:none}.theme-container.no-sidebar .page{padding-left:0}}.vue-component.search-box .icon{display:none}@media (max-width:1366px){.navbar .site-name{display:none}.fullpage-content figure,.theme-default-content figure{margin:0;max-width:100%}.fullpage-content figcaption,.theme-default-content figcaption{margin:0}}@media (max-width:1280px){.sidebar{font-size:15px;width:16.4rem}.page{padding-left:16.4rem}.navbar .nav-links .nav-item:first-of-type{display:none}}@media (max-width:1024px){.sidebar{top:0;padding-top:3.6rem;transform:translateX(-100%);transition:transform .2s ease}.page{padding-left:0}.theme-container.sidebar-open .sidebar{transform:translateX(0)}.theme-container.no-navbar .sidebar{padding-top:0}.navbar .site-name.can-hide{display:inline-block;width:auto}.nav-links .nav-item:first-child{margin-left:1.5rem!important}}@media (max-width:500px){.page h1{font-size:1.9rem}.theme-default-content div[class*=language-]{margin:.85rem -1.5rem;border-radius:0}}@media (max-width:300px){.navbar .site-name.can-hide{display:none}}#nprogress{pointer-events:none}#nprogress .bar{background:#267cb9;position:fixed;z-index:1031;top:0;left:0;width:100%;height:2px}#nprogress .peg{display:block;position:absolute;right:0;width:100px;height:100%;box-shadow:0 0 10px #267cb9,0 0 5px #267cb9;opacity:1;transform:rotate(3deg) translateY(-4px)}#nprogress .spinner{display:block;position:fixed;z-index:1031;top:15px;right:15px}#nprogress .spinner-icon{width:18px;height:18px;box-sizing:border-box;border-color:#267cb9 transparent transparent #267cb9;border-style:solid;border-width:2px;border-radius:50%;animation:nprogress-spinner .4s linear infinite}.nprogress-custom-parent{overflow:hidden;position:relative}.nprogress-custom-parent #nprogress .bar,.nprogress-custom-parent #nprogress .spinner{position:absolute}@keyframes nprogress-spinner{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.code-switcher div[class*=language-]:before{content:""}.code-switcher .tab-header ul{padding:0;text-align:right;margin-bottom:-5px;margin-top:20px}.code-switcher .tab-header li{display:inline-block;padding:0 10px;cursor:pointer;border-radius:4px;border:2px solid #eaecef;margin-left:5px;font-size:80%}.code-switcher .tab-header li.active{border-color:#267cb9}.icon.outbound{color:#aaa;display:inline-block;vertical-align:middle;position:relative;top:-1px}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}.home{padding-top:3.6rem;max-width:960px;margin:0 auto;display:block}.home .hero{text-align:center}.home .hero img{max-width:100%;max-height:179px;display:block;margin:1.5rem auto}.home .hero h1{font-size:3rem}.home .hero .action,.home .hero .description,.home .hero h1{margin:1.8rem auto}.home .hero .description{max-width:42rem;font-size:1.4rem;line-height:1.3;color:#6a8bad}.home .hero .description.small{font-size:1.1rem}.home .hero .description a{text-decoration:underline}.home .hero .action-button{display:inline-block;font-size:1.2rem;color:#fff;background-color:#267cb9;padding:.8rem 1.6rem;border-radius:4px;transition:background-color .1s ease;box-sizing:border-box;border-bottom:1px solid #2270a6}.home .hero .action-button:hover{background-color:#2b8cd1}.home .features{border-top:1px solid #eaecef;padding:1.2rem 0;margin-top:2.5rem;display:flex;flex-wrap:wrap;align-items:flex-start;align-content:stretch;justify-content:space-between}.home .feature{flex-grow:1;flex-basis:49%;max-width:49%}.home .feature h2{font-size:1.4rem;font-weight:500;border-bottom:none;padding-bottom:0;color:#3a5169}.home .feature p{color:#4e6e8e}@media (max-width:1024px){.home .features{flex-direction:column}.home .feature{max-width:100%;padding:0 2.5rem}}@media (max-width:500px){.home{padding-left:1.5rem;padding-right:1.5rem}.home .hero img{max-height:210px;margin:2rem auto 1.2rem}.home .hero h1{font-size:2rem}.home .hero .action,.home .hero .description,.home .hero h1{margin:1.2rem auto}.home .hero .description{font-size:1.2rem}.home .hero .action-button{font-size:1rem;padding:.6rem 1.2rem}.home .feature h2{font-size:1.25rem}}.algolia-search-wrapper>span{vertical-align:middle}.algolia-search-wrapper .algolia-autocomplete{line-height:normal}.algolia-search-wrapper .algolia-autocomplete .ds-dropdown-menu{background-color:#fff;border:1px solid #999;border-radius:4px;font-size:16px;margin:6px 0 0;padding:4px;text-align:left}.algolia-search-wrapper .algolia-autocomplete .ds-dropdown-menu:before{border-color:#999}.algolia-search-wrapper .algolia-autocomplete .ds-dropdown-menu [class*=ds-dataset-]{border:none;padding:0}.algolia-search-wrapper .algolia-autocomplete .ds-dropdown-menu .ds-suggestions{margin-top:0}.algolia-search-wrapper .algolia-autocomplete .ds-dropdown-menu .ds-suggestion{border-bottom:1px solid #eaecef}.algolia-search-wrapper .algolia-autocomplete .algolia-docsearch-suggestion--highlight{color:#2c815b}.algolia-search-wrapper .algolia-autocomplete .algolia-docsearch-suggestion{border-color:#eaecef;padding:0}.algolia-search-wrapper .algolia-autocomplete .algolia-docsearch-suggestion .algolia-docsearch-suggestion--category-header{padding:5px 10px;margin-top:0;background:#267cb9;color:#fff;font-weight:600}.algolia-search-wrapper .algolia-autocomplete .algolia-docsearch-suggestion .algolia-docsearch-suggestion--category-header .algolia-docsearch-suggestion--highlight{background:hsla(0,0%,100%,.6)}.algolia-search-wrapper .algolia-autocomplete .algolia-docsearch-suggestion .algolia-docsearch-suggestion--wrapper{padding:0}.algolia-search-wrapper .algolia-autocomplete .algolia-docsearch-suggestion .algolia-docsearch-suggestion--title{font-weight:600;margin-bottom:0;color:#2c3e50}.algolia-search-wrapper .algolia-autocomplete .algolia-docsearch-suggestion .algolia-docsearch-suggestion--subcategory-column{vertical-align:top;padding:5px 7px 5px 5px;border-color:#eaecef;background:#f1f3f5}.algolia-search-wrapper .algolia-autocomplete .algolia-docsearch-suggestion .algolia-docsearch-suggestion--subcategory-column:after{display:none}.algolia-search-wrapper .algolia-autocomplete .algolia-docsearch-suggestion .algolia-docsearch-suggestion--subcategory-column-text{color:#555}.algolia-search-wrapper .algolia-autocomplete .algolia-docsearch-footer{border-color:#eaecef}.algolia-search-wrapper .algolia-autocomplete .ds-cursor .algolia-docsearch-suggestion--content{background-color:#e7edf3!important;color:#2c3e50}@media (min-width:1024px){.algolia-search-wrapper .algolia-autocomplete .algolia-docsearch-suggestion .algolia-docsearch-suggestion--subcategory-column{float:none;width:150px;min-width:150px;display:table-cell}.algolia-search-wrapper .algolia-autocomplete .algolia-docsearch-suggestion .algolia-docsearch-suggestion--content{float:none;display:table-cell;width:100%;vertical-align:top}.algolia-search-wrapper .algolia-autocomplete .algolia-docsearch-suggestion .ds-dropdown-menu{min-width:515px!important}}@media (max-width:1024px){.algolia-search-wrapper .ds-dropdown-menu{min-width:calc(100vw - 4rem)!important;max-width:calc(100vw - 4rem)!important}.algolia-search-wrapper .algolia-docsearch-suggestion--wrapper{padding:5px 7px 5px 5px!important}.algolia-search-wrapper .algolia-docsearch-suggestion--subcategory-column{padding:0!important;background:#fff!important}.algolia-search-wrapper .algolia-docsearch-suggestion--subcategory-column-text:after{content:" > ";font-size:10px;line-height:14.4px;display:inline-block;width:5px;margin:-3px 3px 0;vertical-align:middle}}.search-box{display:inline-block;position:relative;margin-right:1rem}.search-box input{cursor:text;width:10rem;height:2rem;color:#4e6e8e;display:inline-block;border:1px solid #cfd4db;border-radius:2rem;font-size:.9rem;line-height:2rem;padding:0 .5rem 0 2rem;outline:none;transition:all .2s ease;background:#fff url(/assets/img/search.83621669.svg) .6rem .5rem no-repeat;background-size:1rem}.search-box input:focus{cursor:auto;border-color:#267cb9}.search-box .suggestions{background:#fff;width:20rem;position:absolute;top:2rem;border:1px solid #cfd4db;border-radius:6px;padding:.4rem;list-style-type:none}.search-box .suggestions.align-right{right:0}.search-box .suggestion{line-height:1.4;padding:.4rem .6rem;border-radius:4px;cursor:pointer}.search-box .suggestion a{white-space:normal;color:#5d82a6}.search-box .suggestion a .page-title{font-weight:600}.search-box .suggestion a .header{font-size:.9em;margin-left:.25em}.search-box .suggestion.focused{background-color:#f3f4f5}.search-box .suggestion.focused a{color:#267cb9}@media (max-width:1280px){.search-box input{cursor:pointer;width:0;border-color:transparent;position:relative}.search-box input:focus{cursor:text;left:0;width:10rem}}@media (-ms-high-contrast:none){.search-box input{height:2rem}}@media (max-width:1280px) and (min-width:1024px){.search-box .suggestions{left:0}}@media (max-width:1024px){.search-box{margin-right:0}.search-box input{left:1rem}.search-box .suggestions{right:0}}@media (max-width:500px){.search-box .suggestions{width:calc(100vw - 4rem)}.search-box input:focus{width:8rem}}.sidebar-button{cursor:pointer;display:none;width:1.25rem;height:1.25rem;position:absolute;padding:.6rem;top:.6rem;left:1rem}.sidebar-button .icon{display:block;width:1.25rem;height:1.25rem}@media (max-width:1024px){.sidebar-button{display:block}}.dropdown-enter,.dropdown-leave-to{height:0!important}.badge[data-v-385f24c3]{display:inline-block;font-size:14px;height:18px;line-height:18px;border-radius:3px;padding:0 6px;color:#fff;background-color:#42b983}.badge.green[data-v-385f24c3],.badge.tip[data-v-385f24c3]{background-color:#267cb9}.badge.error[data-v-385f24c3]{background-color:#da5961}.badge.warn[data-v-385f24c3],.badge.warning[data-v-385f24c3],.badge.yellow[data-v-385f24c3]{background-color:#e7c000}.badge+.badge[data-v-385f24c3]{margin-left:5px}.channels{display:flex}.channels ul{margin:0 1em 0 0;padding:0;list-style-type:none;line-height:1.9;flex-grow:1}.channels a,.channels a:hover{text-decoration:none}.channels img{vertical-align:middle;height:20px;width:20px;filter:invert(1);background-color:#d3c1af;padding:2px;margin-top:-2px;border-radius:3px}.channels .gitter img{background-color:#12e69a}.channels .julia img{background-color:#6aa74d}.channels .github img{background-color:#e7e8e8}.channels .linkedin img{background-color:#ff884a}.channels .youtube img{background-color:#0ff}.channels .x img{background-color:#fff}.channels .r img{background-color:#d8923c}.channels .pypi img{background-color:#c88a56}.channels .conda img{background-color:#bb57cc}.channels .npm img{background-color:#34c7c8}.channels .qgis img{background-color:#a769cd}iframe.stretch{width:100%;height:100%;border:0}.docgen section.action-bar{display:none}.searchbox{display:inline-block;position:relative;width:200px;height:32px!important;white-space:nowrap;box-sizing:border-box;visibility:visible!important}.searchbox .algolia-autocomplete{display:block;width:100%;height:100%}.searchbox__wrapper{width:100%;height:100%;z-index:999;position:relative}.searchbox__input{display:inline-block;box-sizing:border-box;transition:box-shadow .4s ease,background .4s ease;border:0;border-radius:16px;box-shadow:inset 0 0 0 1px #ccc;background:#fff!important;padding:0 26px 0 32px;width:100%;height:100%;vertical-align:middle;white-space:normal;font-size:12px;-webkit-appearance:none;-moz-appearance:none;appearance:none}.searchbox__input::-webkit-search-cancel-button,.searchbox__input::-webkit-search-decoration,.searchbox__input::-webkit-search-results-button,.searchbox__input::-webkit-search-results-decoration{display:none}.searchbox__input:hover{box-shadow:inset 0 0 0 1px #b3b3b3}.searchbox__input:active,.searchbox__input:focus{outline:0;box-shadow:inset 0 0 0 1px #aaa;background:#fff}.searchbox__input::-moz-placeholder{color:#aaa}.searchbox__input::placeholder{color:#aaa}.searchbox__submit{position:absolute;top:0;margin:0;border:0;border-radius:16px 0 0 16px;background-color:rgba(69,142,225,0);padding:0;width:32px;height:100%;vertical-align:middle;text-align:center;font-size:inherit;-webkit-user-select:none;-moz-user-select:none;user-select:none;right:inherit;left:0}.searchbox__submit:before{display:inline-block;margin-right:-4px;height:100%;vertical-align:middle;content:""}.searchbox__submit:active,.searchbox__submit:hover{cursor:pointer}.searchbox__submit:focus{outline:0}.searchbox__submit svg{width:14px;height:14px;vertical-align:middle;fill:#6d7e96}.searchbox__reset{display:block;position:absolute;top:8px;right:8px;margin:0;border:0;background:none;cursor:pointer;padding:0;font-size:inherit;-webkit-user-select:none;-moz-user-select:none;user-select:none;fill:rgba(0,0,0,.5)}.searchbox__reset.hide{display:none}.searchbox__reset:focus{outline:0}.searchbox__reset svg{display:block;margin:4px;width:8px;height:8px}.searchbox__input:valid~.searchbox__reset{display:block;animation-name:sbx-reset-in;animation-duration:.15s}@keyframes sbx-reset-in{0%{transform:translate3d(-20%,0,0);opacity:0}to{transform:none;opacity:1}}.algolia-autocomplete.algolia-autocomplete-right .ds-dropdown-menu{right:0!important;left:inherit!important}.algolia-autocomplete.algolia-autocomplete-right .ds-dropdown-menu:before{right:48px}.algolia-autocomplete.algolia-autocomplete-left .ds-dropdown-menu{left:0!important;right:inherit!important}.algolia-autocomplete.algolia-autocomplete-left .ds-dropdown-menu:before{left:48px}.algolia-autocomplete .ds-dropdown-menu{top:-6px;border-radius:4px;margin:6px 0 0;padding:0;text-align:left;height:auto;position:relative;background:transparent;border:none;z-index:999;max-width:600px;min-width:500px;box-shadow:0 1px 0 0 rgba(0,0,0,.2),0 2px 3px 0 rgba(0,0,0,.1)}.algolia-autocomplete .ds-dropdown-menu:before{display:block;position:absolute;content:"";width:14px;height:14px;background:#fff;z-index:1000;top:-7px;border-top:1px solid #d9d9d9;border-right:1px solid #d9d9d9;transform:rotate(-45deg);border-radius:2px}.algolia-autocomplete .ds-dropdown-menu .ds-suggestions{position:relative;z-index:1000;margin-top:8px}.algolia-autocomplete .ds-dropdown-menu .ds-suggestions a:hover{text-decoration:none}.algolia-autocomplete .ds-dropdown-menu .ds-suggestion{cursor:pointer}.algolia-autocomplete .ds-dropdown-menu .ds-suggestion.ds-cursor .algolia-docsearch-suggestion.suggestion-layout-simple,.algolia-autocomplete .ds-dropdown-menu .ds-suggestion.ds-cursor .algolia-docsearch-suggestion:not(.suggestion-layout-simple) .algolia-docsearch-suggestion--content{background-color:rgba(69,142,225,.05)}.algolia-autocomplete .ds-dropdown-menu [class^=ds-dataset-]{position:relative;border:1px solid #d9d9d9;background:#fff;border-radius:4px;overflow:auto;padding:0 8px 8px}.algolia-autocomplete .ds-dropdown-menu *{box-sizing:border-box}.algolia-autocomplete .algolia-docsearch-suggestion{display:block;position:relative;padding:0 8px;background:#fff;color:#02060c;overflow:hidden}.algolia-autocomplete .algolia-docsearch-suggestion--highlight{color:#174d8c;background:rgba(143,187,237,.1);padding:.1em .05em}.algolia-autocomplete .algolia-docsearch-suggestion--category-header .algolia-docsearch-suggestion--category-header-lvl0 .algolia-docsearch-suggestion--highlight,.algolia-autocomplete .algolia-docsearch-suggestion--category-header .algolia-docsearch-suggestion--category-header-lvl1 .algolia-docsearch-suggestion--highlight,.algolia-autocomplete .algolia-docsearch-suggestion--text .algolia-docsearch-suggestion--highlight{padding:0 0 1px;background:inherit;box-shadow:inset 0 -2px 0 0 rgba(69,142,225,.8);color:inherit}.algolia-autocomplete .algolia-docsearch-suggestion--content{display:block;float:right;width:70%;position:relative;padding:5.33333px 0 5.33333px 10.66667px;cursor:pointer}.algolia-autocomplete .algolia-docsearch-suggestion--content:before{content:"";position:absolute;display:block;top:0;height:100%;width:1px;background:#ddd;left:-1px}.algolia-autocomplete .algolia-docsearch-suggestion--category-header{position:relative;border-bottom:1px solid #ddd;display:none;margin-top:8px;padding:4px 0;font-size:1em;color:#33363d}.algolia-autocomplete .algolia-docsearch-suggestion--wrapper{width:100%;float:left;padding:8px 0 0}.algolia-autocomplete .algolia-docsearch-suggestion--subcategory-column{float:left;width:30%;text-align:right;position:relative;padding:5.33333px 10.66667px;color:#a4a7ae;font-size:.9em;word-wrap:break-word}.algolia-autocomplete .algolia-docsearch-suggestion--subcategory-column:before{content:"";position:absolute;display:block;top:0;height:100%;width:1px;background:#ddd;right:0}.algolia-autocomplete .algolia-docsearch-suggestion--subcategory-inline{display:none}.algolia-autocomplete .algolia-docsearch-suggestion--title{margin-bottom:4px;color:#02060c;font-size:.9em;font-weight:700}.algolia-autocomplete .algolia-docsearch-suggestion--text{display:block;line-height:1.2em;font-size:.85em;color:#63676d}.algolia-autocomplete .algolia-docsearch-suggestion--no-results{width:100%;padding:8px 0;text-align:center;font-size:1.2em}.algolia-autocomplete .algolia-docsearch-suggestion--no-results:before{display:none}.algolia-autocomplete .algolia-docsearch-suggestion code{padding:1px 5px;font-size:90%;border:none;color:#222;background-color:#ebebeb;border-radius:3px;font-family:Menlo,Monaco,Consolas,Courier New,monospace}.algolia-autocomplete .algolia-docsearch-suggestion code .algolia-docsearch-suggestion--highlight{background:none}.algolia-autocomplete .algolia-docsearch-suggestion.algolia-docsearch-suggestion__main .algolia-docsearch-suggestion--category-header,.algolia-autocomplete .algolia-docsearch-suggestion.algolia-docsearch-suggestion__secondary{display:block}@media (min-width:768px){.algolia-autocomplete .algolia-docsearch-suggestion .algolia-docsearch-suggestion--subcategory-column{display:block}}@media (max-width:768px){.algolia-autocomplete .algolia-docsearch-suggestion .algolia-docsearch-suggestion--subcategory-column{display:inline-block;width:auto;float:left;padding:0;color:#02060c;font-size:.9em;font-weight:700;text-align:left;opacity:.5}.algolia-autocomplete .algolia-docsearch-suggestion .algolia-docsearch-suggestion--subcategory-column:before{display:none}.algolia-autocomplete .algolia-docsearch-suggestion .algolia-docsearch-suggestion--subcategory-column:after{content:"|"}.algolia-autocomplete .algolia-docsearch-suggestion .algolia-docsearch-suggestion--content{display:inline-block;width:auto;text-align:left;float:left;padding:0}.algolia-autocomplete .algolia-docsearch-suggestion .algolia-docsearch-suggestion--content:before{display:none}}.algolia-autocomplete .suggestion-layout-simple.algolia-docsearch-suggestion{border-bottom:1px solid #eee;padding:8px;margin:0}.algolia-autocomplete .suggestion-layout-simple .algolia-docsearch-suggestion--content{width:100%;padding:0}.algolia-autocomplete .suggestion-layout-simple .algolia-docsearch-suggestion--content:before{display:none}.algolia-autocomplete .suggestion-layout-simple .algolia-docsearch-suggestion--category-header{margin:0;padding:0;display:block;width:100%;border:none}.algolia-autocomplete .suggestion-layout-simple .algolia-docsearch-suggestion--category-header-lvl0,.algolia-autocomplete .suggestion-layout-simple .algolia-docsearch-suggestion--category-header-lvl1{opacity:.6;font-size:.85em}.algolia-autocomplete .suggestion-layout-simple .algolia-docsearch-suggestion--category-header-lvl1:before{background-image:url('data:image/svg+xml;utf8,');content:"";width:10px;height:10px;display:inline-block}.algolia-autocomplete .suggestion-layout-simple .algolia-docsearch-suggestion--wrapper{width:100%;float:left;margin:0;padding:0}.algolia-autocomplete .suggestion-layout-simple .algolia-docsearch-suggestion--duplicate-content,.algolia-autocomplete .suggestion-layout-simple .algolia-docsearch-suggestion--subcategory-inline{display:none!important}.algolia-autocomplete .suggestion-layout-simple .algolia-docsearch-suggestion--title{margin:0;color:#458ee1;font-size:.9em;font-weight:400}.algolia-autocomplete .suggestion-layout-simple .algolia-docsearch-suggestion--title:before{content:"#";font-weight:700;color:#458ee1;display:inline-block}.algolia-autocomplete .suggestion-layout-simple .algolia-docsearch-suggestion--text{margin:4px 0 0;display:block;line-height:1.4em;padding:5.33333px 8px;background:#f8f8f8;font-size:.85em;opacity:.8}.algolia-autocomplete .suggestion-layout-simple .algolia-docsearch-suggestion--text .algolia-docsearch-suggestion--highlight{color:#3f4145;font-weight:700;box-shadow:none}.algolia-autocomplete .algolia-docsearch-footer{width:134px;height:20px;z-index:2000;margin-top:10.66667px;float:right;font-size:0;line-height:0}.algolia-autocomplete .algolia-docsearch-footer--logo{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg width='168' height='24' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cpath d='M78.988.938h16.594a2.968 2.968 0 012.966 2.966V20.5a2.967 2.967 0 01-2.966 2.964H78.988a2.967 2.967 0 01-2.966-2.964V3.897A2.961 2.961 0 0178.988.938zm41.937 17.866c-4.386.02-4.386-3.54-4.386-4.106l-.007-13.336 2.675-.424v13.254c0 .322 0 2.358 1.718 2.364v2.248zm-10.846-2.18c.821 0 1.43-.047 1.855-.129v-2.719a6.334 6.334 0 00-1.574-.199 5.7 5.7 0 00-.897.069 2.699 2.699 0 00-.814.24c-.24.116-.439.28-.582.491-.15.212-.219.335-.219.656 0 .628.219.991.616 1.23s.938.362 1.615.362zm-.233-9.7c.883 0 1.629.109 2.231.328.602.218 1.088.525 1.444.915.363.396.609.922.76 1.483.157.56.232 1.175.232 1.85v6.874a32.5 32.5 0 01-1.868.314c-.834.123-1.772.185-2.813.185-.69 0-1.327-.069-1.895-.198a4.001 4.001 0 01-1.471-.636 3.085 3.085 0 01-.951-1.134c-.226-.465-.343-1.12-.343-1.803 0-.656.13-1.073.384-1.525a3.24 3.24 0 011.047-1.106c.445-.287.95-.492 1.532-.615a8.8 8.8 0 011.82-.185 8.404 8.404 0 011.972.24v-.438c0-.307-.035-.6-.11-.874a1.88 1.88 0 00-.384-.73 1.784 1.784 0 00-.724-.493 3.164 3.164 0 00-1.143-.205c-.616 0-1.177.075-1.69.164a7.735 7.735 0 00-1.26.307l-.321-2.192c.335-.117.834-.233 1.478-.349a10.98 10.98 0 012.073-.178zm52.842 9.626c.822 0 1.43-.048 1.854-.13V13.7a6.347 6.347 0 00-1.574-.199c-.294 0-.595.021-.896.069a2.7 2.7 0 00-.814.24 1.46 1.46 0 00-.582.491c-.15.212-.218.335-.218.656 0 .628.218.991.615 1.23.404.245.938.362 1.615.362zm-.226-9.694c.883 0 1.629.108 2.231.327.602.219 1.088.526 1.444.915.355.39.609.923.759 1.483a6.8 6.8 0 01.233 1.852v6.873c-.41.088-1.034.19-1.868.314-.834.123-1.772.184-2.813.184-.69 0-1.327-.068-1.895-.198a4.001 4.001 0 01-1.471-.635 3.085 3.085 0 01-.951-1.134c-.226-.465-.343-1.12-.343-1.804 0-.656.13-1.073.384-1.524.26-.45.608-.82 1.047-1.107.445-.286.95-.491 1.532-.614a8.803 8.803 0 012.751-.13c.329.034.671.096 1.04.185v-.437a3.3 3.3 0 00-.109-.875 1.873 1.873 0 00-.384-.731 1.784 1.784 0 00-.724-.492 3.165 3.165 0 00-1.143-.205c-.616 0-1.177.075-1.69.164a7.75 7.75 0 00-1.26.307l-.321-2.193c.335-.116.834-.232 1.478-.348a11.633 11.633 0 012.073-.177zm-8.034-1.271a1.626 1.626 0 01-1.628-1.62c0-.895.725-1.62 1.628-1.62.904 0 1.63.725 1.63 1.62 0 .895-.733 1.62-1.63 1.62zm1.348 13.22h-2.689V7.27l2.69-.423v11.956zm-4.714 0c-4.386.02-4.386-3.54-4.386-4.107l-.008-13.336 2.676-.424v13.254c0 .322 0 2.358 1.718 2.364v2.248zm-8.698-5.903c0-1.156-.253-2.119-.746-2.788-.493-.677-1.183-1.01-2.067-1.01-.882 0-1.574.333-2.065 1.01-.493.676-.733 1.632-.733 2.788 0 1.168.246 1.953.74 2.63.492.683 1.183 1.018 2.066 1.018.882 0 1.574-.342 2.067-1.019.492-.683.738-1.46.738-2.63zm2.737-.007c0 .902-.13 1.584-.397 2.33a5.52 5.52 0 01-1.128 1.906 4.986 4.986 0 01-1.752 1.223c-.685.286-1.739.45-2.265.45-.528-.006-1.574-.157-2.252-.45a5.096 5.096 0 01-1.744-1.223c-.487-.527-.863-1.162-1.137-1.906a6.345 6.345 0 01-.41-2.33c0-.902.123-1.77.397-2.508a5.554 5.554 0 011.15-1.892 5.133 5.133 0 011.75-1.216c.679-.287 1.425-.423 2.232-.423.808 0 1.553.142 2.237.423a4.88 4.88 0 011.753 1.216 5.644 5.644 0 011.135 1.892c.287.738.431 1.606.431 2.508zm-20.138 0c0 1.12.246 2.363.738 2.882.493.52 1.13.78 1.91.78.424 0 .828-.062 1.204-.178.377-.116.677-.253.917-.417V9.33a10.476 10.476 0 00-1.766-.226c-.971-.028-1.71.37-2.23 1.004-.513.636-.773 1.75-.773 2.788zm7.438 5.274c0 1.824-.466 3.156-1.404 4.004-.936.846-2.367 1.27-4.296 1.27-.705 0-2.17-.137-3.34-.396l.431-2.118c.98.205 2.272.26 2.95.26 1.074 0 1.84-.219 2.299-.656.459-.437.684-1.086.684-1.948v-.437a8.07 8.07 0 01-1.047.397c-.43.13-.93.198-1.492.198-.739 0-1.41-.116-2.018-.349a4.206 4.206 0 01-1.567-1.025c-.431-.45-.774-1.017-1.013-1.694-.24-.677-.363-1.885-.363-2.773 0-.834.13-1.88.384-2.577.26-.696.629-1.298 1.129-1.796.493-.498 1.095-.881 1.8-1.162a6.605 6.605 0 012.428-.457c.87 0 1.67.109 2.45.24.78.129 1.444.265 1.985.415V18.17z' fill='%235468FF'/%3E%3Cpath d='M6.972 6.677v1.627c-.712-.446-1.52-.67-2.425-.67-.585 0-1.045.13-1.38.391a1.24 1.24 0 00-.502 1.03c0 .425.164.765.494 1.02.33.256.835.532 1.516.83.447.192.795.356 1.045.495.25.138.537.332.862.582.324.25.563.548.718.894.154.345.23.741.23 1.188 0 .947-.334 1.691-1.004 2.234-.67.542-1.537.814-2.601.814-1.18 0-2.16-.229-2.936-.686v-1.708c.84.628 1.814.942 2.92.942.585 0 1.048-.136 1.388-.407.34-.271.51-.646.51-1.125 0-.287-.1-.55-.302-.79-.203-.24-.42-.42-.655-.542-.234-.123-.585-.29-1.053-.503a61.27 61.27 0 01-.582-.271 13.67 13.67 0 01-.55-.287 4.275 4.275 0 01-.567-.351 6.92 6.92 0 01-.455-.4c-.18-.17-.31-.34-.39-.51-.08-.17-.155-.37-.224-.598a2.553 2.553 0 01-.104-.742c0-.915.333-1.638.998-2.17.664-.532 1.523-.798 2.576-.798.968 0 1.793.17 2.473.51zm7.468 5.696v-.287c-.022-.607-.187-1.088-.495-1.444-.309-.357-.75-.535-1.324-.535-.532 0-.99.194-1.373.583-.382.388-.622.949-.717 1.683h3.909zm1.005 2.792v1.404c-.596.34-1.383.51-2.362.51-1.255 0-2.255-.377-3-1.132-.744-.755-1.116-1.744-1.116-2.968 0-1.297.34-2.316 1.021-3.055.68-.74 1.548-1.11 2.6-1.11 1.033 0 1.852.323 2.458.966.606.644.91 1.572.91 2.784 0 .33-.033.676-.096 1.038h-5.314c.107.702.405 1.239.894 1.611.49.372 1.106.558 1.85.558.862 0 1.58-.202 2.155-.606zm6.605-1.77h-1.212c-.596 0-1.045.116-1.349.35-.303.234-.454.532-.454.894 0 .372.117.664.35.877.235.213.575.32 1.022.32.51 0 .912-.142 1.204-.424.293-.281.44-.651.44-1.108v-.91zm-4.068-2.554V9.325c.627-.361 1.457-.542 2.489-.542 2.116 0 3.175 1.026 3.175 3.08V17h-1.548v-.957c-.415.68-1.143 1.02-2.186 1.02-.766 0-1.38-.22-1.843-.661-.462-.442-.694-1.003-.694-1.684 0-.776.293-1.38.878-1.81.585-.431 1.404-.647 2.457-.647h1.34V11.8c0-.554-.133-.971-.399-1.253-.266-.282-.707-.423-1.324-.423a4.07 4.07 0 00-2.345.718zm9.333-1.93v1.42c.394-1 1.101-1.5 2.123-1.5.148 0 .313.016.494.048v1.531a1.885 1.885 0 00-.75-.143c-.542 0-.989.24-1.34.718-.351.479-.527 1.048-.527 1.707V17h-1.563V8.91h1.563zm5.01 4.084c.022.82.272 1.492.75 2.019.479.526 1.15.79 2.01.79.639 0 1.235-.176 1.788-.527v1.404c-.521.319-1.186.479-1.995.479-1.265 0-2.276-.4-3.031-1.197-.755-.798-1.133-1.792-1.133-2.984 0-1.16.38-2.151 1.14-2.975.761-.825 1.79-1.237 3.088-1.237.702 0 1.346.149 1.93.447v1.436a3.242 3.242 0 00-1.77-.495c-.84 0-1.513.266-2.019.798-.505.532-.758 1.213-.758 2.042zM40.24 5.72v4.579c.458-1 1.293-1.5 2.505-1.5.787 0 1.42.245 1.899.734.479.49.718 1.17.718 2.042V17h-1.564v-5.106c0-.553-.14-.98-.422-1.284-.282-.303-.652-.455-1.11-.455-.531 0-1.002.202-1.411.606-.41.405-.615 1.022-.615 1.851V17h-1.563V5.72h1.563zm14.966 10.02c.596 0 1.096-.253 1.5-.758.404-.506.606-1.157.606-1.955 0-.915-.202-1.62-.606-2.114-.404-.495-.92-.742-1.548-.742-.553 0-1.05.224-1.491.67-.442.447-.662 1.133-.662 2.058 0 .958.212 1.67.638 2.138.425.469.946.703 1.563.703zM53.004 5.72v4.42c.574-.894 1.388-1.341 2.44-1.341 1.022 0 1.857.383 2.506 1.149.649.766.973 1.781.973 3.047 0 1.138-.309 2.109-.925 2.912-.617.803-1.463 1.205-2.537 1.205-1.075 0-1.894-.447-2.457-1.34V17h-1.58V5.72h1.58zm9.908 11.104l-3.223-7.913h1.739l1.005 2.632 1.26 3.415c.096-.32.48-1.458 1.15-3.415l.909-2.632h1.66l-2.92 7.866c-.777 2.074-1.963 3.11-3.559 3.11a2.92 2.92 0 01-.734-.079v-1.34c.17.042.351.064.543.064 1.032 0 1.755-.57 2.17-1.708z' fill='%235D6494'/%3E%3Cpath d='M89.632 5.967v-.772a.978.978 0 00-.978-.977h-2.28a.978.978 0 00-.978.977v.793c0 .088.082.15.171.13a7.127 7.127 0 011.984-.28c.65 0 1.295.088 1.917.259.082.02.164-.04.164-.13m-6.248 1.01l-.39-.389a.977.977 0 00-1.382 0l-.465.465a.973.973 0 000 1.38l.383.383c.062.061.15.047.205-.014.226-.307.472-.601.746-.874.281-.28.568-.526.883-.751.068-.042.075-.137.02-.2m4.16 2.453v3.341c0 .096.104.165.192.117l2.97-1.537c.068-.034.089-.117.055-.184a3.695 3.695 0 00-3.08-1.866c-.068 0-.136.054-.136.13m0 8.048a4.489 4.489 0 01-4.49-4.482 4.488 4.488 0 014.49-4.482 4.488 4.488 0 014.489 4.482 4.484 4.484 0 01-4.49 4.482m0-10.85a6.363 6.363 0 100 12.729 6.37 6.37 0 006.372-6.368 6.358 6.358 0 00-6.371-6.36' fill='%23FFF'/%3E%3C/g%3E%3C/svg%3E");background-repeat:no-repeat;background-position:50%;background-size:100%;overflow:hidden;text-indent:-9000px;padding:0!important;width:100%;height:100%;display:block}.vue-component.loading-notice .loading:after{content:".";animation:dots 1.25s steps(5) infinite;font-size:1.5em;line-height:1em;font-weight:700}@keyframes dots{0%,20%{color:transparent;text-shadow:.25em 0 0 transparent,.5em 0 0 transparent}40%{color:#000;text-shadow:.25em 0 0 transparent,.5em 0 0 transparent}60%{text-shadow:.25em 0 0 #000,.5em 0 0 transparent}80%,to{text-shadow:.25em 0 0 #000,.5em 0 0 #000}}.vue-component.styled-description{line-height:1.25em}.vue-component.styled-description code{color:maroon;display:inline-block;padding:0 .1em}.vue-component.styled-description pre{background-color:#eee;width:100%;border:1px solid #ccc;max-height:15em;overflow-y:auto}.vue-component.styled-description pre code{background-color:transparent;display:block;margin:.5em}.vue-component.styled-description.compact pre{max-height:7em;width:auto;max-width:100%}.vue-component.styled-description.compact p{margin:.5em 0}.vue-component.styled-description.compact p:first-child{margin-top:0}.vue-component.styled-description.compact p:last-child{margin-bottom:0}.vue-component.process-example .content{border-left:5px solid #ccc;border-bottom:1px solid #ccc;padding:.5em;margin-left:3em;box-sizing:border-box}.vue-component.process-example .content .styled-description{margin-bottom:1em}.vue-component.process .namespace{font-weight:400;color:#aaa}.vue-component.process .process-bar{display:flex;align-items:baseline}.vue-component.process .process-bar .badges{margin-top:.75em}.vue-component.process .categories{flex:1}.vue-component.process .actions{text-align:right}.vue-component.process strong.deprecated{color:red}.vue-component.process strong.experimental{color:#8a2be2}.vue-component.process .exception{margin-top:.5em}.vue-component.process .exception code{font-weight:700}.vue-component.process .exception .styled-description{margin:.5em 0}.vue-component.process .exception .message{margin:.5em 0;font-size:.8em}.vue-component.process .signature{display:block;margin:1em 0}.vue-component.process .process-graph .graph{max-width:100%;height:300px;border:1px solid #ccc}.vue-component.process .process-graph .graph>.object-tree>ul{margin:0;padding:0}.vue-component.process .links:empty{display:none}.vue-component.searchable-list.expandable .heading{cursor:pointer;padding-left:1em}.vue-component.searchable-list.expandable .heading:before{content:"▸";margin-left:-1em;float:left;font-size:1em}.vue-component.searchable-list.expandable.expanded .heading:before{content:"▾"}.vue-component.searchable-list .action-bar{width:100%;display:flex;margin-bottom:1em;padding:1px;gap:.5em}.vue-component.searchable-list .action-bar:empty{display:none}.vue-component.searchable-list .action-bar>.search-box{min-width:150px;flex:1;margin:0}.vue-component.searchable-list .action-bar>.deprecated,.vue-component.searchable-list .action-bar>.experimental{white-space:nowrap;align-content:center}.vue-component.searchable-list .details{display:none}.vue-component.searchable-list .list .details h2,.vue-component.searchable-list .list .details h3,.vue-component.searchable-list .list .details h4,.vue-component.searchable-list .list .details h5,.vue-component.searchable-list .list .details h6{font-size:1em}.vue-component.searchable-list ul.list{margin-left:0;padding-left:0;list-style-type:none}.vue-component.searchable-list ul.list>li{margin-bottom:.5em}.vue-component.searchable-list ul.list>li>summary{margin-bottom:.5em;margin-left:1em;line-height:1.33em}.vue-component.searchable-list ul.list>li>summary strong{display:block;text-overflow:ellipsis;overflow:hidden}.vue-component.searchable-list ul.list>li>summary strong .copy{display:none}.vue-component.searchable-list ul.list>li>summary strong.inline{display:inline}.vue-component.searchable-list ul.list>li>summary.experimental strong{color:#8a2be2}.vue-component.searchable-list ul.list>li>summary.deprecated strong{text-decoration:line-through}.vue-component.searchable-list ul.list>li>summary:before{content:"▸";margin-left:-1em;float:left;font-size:1em}.vue-component.searchable-list ul.list>li>summary .badges.block{display:block}.vue-component.searchable-list ul.expandable>li>summary{cursor:pointer}.vue-component.searchable-list ul.expandable>li>summary:hover strong .copy{display:inline-block!important}.vue-component.searchable-list ul.expandable>li.expanded{margin-bottom:2em}.vue-component.searchable-list ul.expandable>li.expanded .details{display:block;margin-left:1em}.vue-component.searchable-list ul.expandable>li.expanded>summary:before{content:"▾"}.vue-component.searchable-list ul.expandable>li.expanded>summary .hideOnExpand{display:none}.vue-component.search-box{margin:0 1px 1em 0;display:flex;align-items:stretch}.vue-component.search-box .icon,.vue-component.search-box input{font-size:1em;margin:0}.vue-component.search-box input{flex-grow:1;padding:.3em .3em .3em 1.9em;z-index:1;border:1px solid #ccc;box-sizing:content-box;background-color:#fff;box-sizing:border-box;width:100%;margin-left:-1.3em}.vue-component.search-box .icon{display:flex;align-items:center;-webkit-user-select:none;user-select:none;margin-left:.3em;width:1em;z-index:2}.vue-component.search-box.compact{font-size:.9em;margin-bottom:0}.vue-component.search-box.compact input{padding-top:0;padding-bottom:0}.vue-component.search-box.compact .icon{margin-top:.1em;margin-left:.3em}.docgen{height:100%;font-family:Roboto Sans,sans-serif;margin:0;padding:0}.docgen code,.docgen pre .docgen kbd{font-family:Roboto Mono,Consolas,monospace}.docgen h2{font-size:1.75em;padding:.25em 0;margin:0 0 .75em;border-bottom:1px solid #ccc}.docgen h2 .copy{color:#856404;cursor:pointer}.docgen h2 .copy:hover{color:#000}.docgen h2 .copy.success{color:green;cursor:auto}.docgen h3{font-size:1.4em;margin:1.5em 0 .75em;padding:.25em 0;border-bottom:1px dotted #ccc}.docgen h4{margin:1.5em 0 .25em;font-size:1.2em}.docgen h5{margin:.5em 0 .25em;font-size:1.1em}.docgen h6{margin:.5em 0 .25em;font-size:1em}.docgen p{margin:0 0 .75em}.docgen td p{margin:.25em 0}.docgen li p{margin:0 0 .25em}.docgen a{color:#2f649a;text-decoration:none;cursor:pointer}.docgen a:hover{color:#000}.docgen .notice{margin:0 3rem 1rem 2rem;padding:1rem 3.5rem 1rem 1rem;border-radius:.25rem;position:fixed;bottom:0;color:#856404;background-color:#fff3cd;border:1px solid #856404}.docgen .notice p:last-of-type{margin-bottom:0}.docgen .notice .close{position:absolute;top:0;right:0;font-size:1.5em;padding:.5rem;margin:.5rem;font-weight:700;line-height:1;opacity:.5;background-color:transparent;border:0;color:inherit;cursor:pointer}.docgen .notice .close:hover{opacity:1;outline:0}.docgen .categories h2{display:block;text-transform:capitalize;font-size:1em;cursor:pointer;border:0;margin-top:0;margin-bottom:0}.docgen .categories ul.list{margin-left:.5em;margin-top:.25em}.docgen .categories ul.list li{margin-left:.5em}.docgen .categories .noResults{display:none}.docgen .process{margin:1em 1em 5em;padding:0}@media only screen and (min-width:1280px){.docgen .process{margin-bottom:10em}.docgen .process h3{margin-top:2em}}.docgen .no-processes-found{text-align:center;display:block}.docgen .fileChooser{width:100%;height:100%;display:flex;align-items:center;justify-content:center}.docgen .fileChooser p{width:25%}.docgen .fileChooser input{margin-top:.5em;width:100%}.docgen .menu-container section{margin:1em}.docgen .menu-container ul{list-style-type:square;display:block;padding:0}.docgen .menu-container summary{margin-bottom:.5em}.docgen .menu-container .controls{text-align:center;display:block;margin:1em 0;padding:0;list-style-type:none}.docgen .menu-container .controls li{display:inline-block}.docgen .menu-container .controls li a{font-weight:400;background-color:#d2691e;color:#fff;display:inline-block;margin:.25em .35em;padding:.25em .5em;border-radius:3px}.docgen .menu-container .controls li a:hover{background-color:#000}.docgen .vue-component.searchable-list ul.list>li>summary{line-height:inherit}.docgen .menu-container li a{font-weight:700}.docgen .content-container.toc{padding-top:3em}.docgen .related-links{margin-top:4em;margin-bottom:2em}.docgen .filters{display:flex;justify-content:center;flex-flow:row wrap}.docgen .filters .label,.docgen .filters .show-deprecated,.docgen .filters .show-experimental{align-content:center;display:inline-block;white-space:nowrap;margin:.25rem;font-size:.9em;cursor:pointer}.docgen .filters .label{cursor:default}@media only screen and (min-width:800px){.docgen .related-links{margin-top:3em;margin-bottom:0}.docgen .page-container{display:flex;height:100%}.docgen .content-container,.docgen .menu-container{height:100%;overflow-y:scroll}.docgen .content-container.toc{flex:1;padding-top:0}.docgen .menu-container{flex:1;min-width:250px;max-width:25%;border-right:1px dotted #ccc}}@media only screen and (min-width:1280px){.docgen .menu-container{max-width:20%}}.vue-component.process-parameter .details{margin-left:3em}.vue-component.process-parameter .default{font-weight:400}.vue-component.process-parameter h4 code{font-size:1.15em}.vue-component .json-schema{border-left:5px solid #ccc;padding:.5em;box-sizing:border-box}.vue-component .json-schema.composite{border-left:0;padding-left:0}.vue-component .json-schema .schemaProcessGraph,.vue-component .json-schema td,.vue-component .json-schema th{padding:.5em}.vue-component .json-schema .schemaProcessGraph h4{font-size:1.1em;margin-top:1em}.vue-component .json-schema .data-type{font-weight:700}.vue-component .json-schema .data-types-container>.json-schema{border-left:7px solid #ccc;border-bottom:1px solid #ccc;margin-bottom:1em;margin-left:.25em}.vue-component .json-schema .inline-schema-attrs .json-schema{border:0;padding:0;width:100%;background-color:transparent}.vue-component .json-schema .schema-name{display:inline-block;border-bottom:1px dotted #000}.vue-component .json-schema .schema-attrs{width:100%;margin:-.25em}.vue-component .json-schema .schema-attrs .key{white-space:nowrap}.vue-component .json-schema .schema-attrs .value{width:90%}.vue-component .json-schema .schema-attrs>tr>td>.styled-description{margin-bottom:1em}.vue-component .json-schema p.schema-attrs{margin:1em 0 .5em}.vue-component .json-schema p.schema-attrs:first-of-type{margin:0 0 1em}.vue-component .json-schema .data-types-heading,.vue-component .json-schema .object-prop-heading{text-align:left}.vue-component .json-schema .object-properties>tr>.key{font-style:italic;font-weight:700;min-width:80px;width:8%;vertical-align:top;padding-top:.75em;padding-left:1em}.vue-component .json-schema .object-properties>tr>.value{border-bottom:1px dotted #ccc}.vue-component .json-schema .object-properties>tr:last-of-type>.value{border-bottom:0}.vue-component .json-schema .object-properties>th{padding-top:1em}.vue-component.deprecation-notice{background-color:rgba(255,0,0,.1);border:1px solid red}.vue-component.deprecation-notice strong{display:block;color:red}.vue-component.experimental-notice{background-color:rgba(138,43,226,.1);border:1px solid #8a2be2}.vue-component.experimental-notice strong{color:#8a2be2}.vue-component.model-builder .block .connector{font-size:.9em;margin:.2em 0;white-space:nowrap}.vue-component.model-builder .block .connector.noValue{color:red}.vue-component.model-builder .block .connector.editable .label,.vue-component.model-builder .block .connector.editable .value{cursor:pointer}.vue-component.model-builder .block .connector span[title]{cursor:help}.vue-component.model-builder .block .connector .input{max-width:100%;overflow:hidden;text-overflow:ellipsis}.vue-component.model-builder .block .connector .output{text-align:right}.vue-component.model-builder .block .connector .unspecified{color:red;margin-right:.3em}.vue-component.model-builder .block .connector .circle{width:.8em;height:.8em;margin:0 .2em;border:1px solid #888;background-color:transparent;display:inline-block}.vue-component.model-builder .block .connector .circle.io_active{background-color:#ffc800}.vue-component.model-builder .block .connector .circle.io_selected{background-color:#00c800!important}.vue-component.model-builder .block .connector .circle.io_issues{background-color:red}.vue-component.model-builder.editable .circle{cursor:pointer}.vue-component.model-builder .block{position:absolute;border:2px solid #ccc;margin-left:0;margin-top:0;background-color:#fafafa;opacity:.8;font-size:14px;user-select:none;-moz-user-select:none;-khtml-user-select:none;-webkit-user-select:none;-o-user-select:none;color:#000}.vue-component.model-builder .block .description{display:none;width:200px;padding:3px;border:1px solid #083776;border-radius:5px;color:#001531;background-color:#91bcf6;margin-top:15px;position:absolute;font-weight:400}.vue-component.model-builder .block .blockTitle{display:flex;padding:.3em .1em;font-weight:700;background-color:#ddd;margin-bottom:.1em;cursor:move;font-size:.9em}.vue-component.model-builder .block .blockTitle .blockId{opacity:.4;margin-left:.25em;font-weight:400}.vue-component.model-builder .block .blockTitle .namespace{font-weight:400}.vue-component.model-builder .block .blockTitle .titleText{flex-grow:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.vue-component.model-builder .block .blockTitle .blockicon{white-space:nowrap;text-align:center}.vue-component.model-builder .block .blockTitle .blockicon i.fas{min-width:1.4em;cursor:pointer;opacity:.5;margin-left:.1em}.vue-component.model-builder .block .blockTitle .blockicon i.fas:hover{opacity:1}.vue-component.model-builder .block .invalid{color:red;cursor:help}.vue-component.model-builder .block .inout{display:flex}.vue-component.model-builder .block .inputs{flex-grow:1;max-width:100%;overflow:hidden;text-overflow:ellipsis}.vue-component.model-builder .block .editDescription{padding:.3em .2em;box-sizing:border-box;font-size:.9em;line-height:1em;overflow:auto;border:0;border-top:1px dotted #ccc;background-color:transparent;width:100%;max-width:100%;height:3.7em;min-height:2.5em;resize:none}.vue-component.model-builder .block .editDescription:focus{outline:0}.vue-component.model-builder .block_collection{border:2px solid #6b8daf}.vue-component.model-builder .block_collection .blockTitle{background-color:#a3b7cc}.vue-component.model-builder .block_collection .field_id{display:none}.vue-component.model-builder .block_result{border:2px solid #888}.vue-component.model-builder .block_result .field_output .circle{background-color:#888;cursor:auto}.vue-component.model-builder .block_argument{border:2px solid #b28c6b}.vue-component.model-builder .block_argument .blockTitle{background-color:#ccb7a3}.vue-component.model-builder .block_selected{border:2px solid #0a0!important}.vue-component.model-builder .block_selected .blockTitle{background-color:#0c0!important}.vue-component.model-builder .block_invalid{border:2px solid red!important}.vue-component.model-builder{width:100%;height:100%;position:relative}.vue-component.model-builder.editable.focus .blocks{border-color:rgba(22,102,182,.3)}.vue-component.model-builder .blocks:focus,.vue-component.model-builder .canvas:focus,.vue-component.model-builder:focus{outline:0}.vue-component.model-builder .canvas{width:100%;height:100%;position:absolute;z-index:1}.vue-component.model-builder .blocks{box-sizing:border-box;border:1px solid transparent;overflow:hidden;position:absolute;z-index:3;width:100%;height:100%}.vue-component.model-builder.compact .blockicon .addDescription,.vue-component.model-builder.compact .blockicon .delete,.vue-component.model-builder.compact .blockicon .info,.vue-component.model-builder.compact .blockId,.vue-component.model-builder.compact .editDescription,.vue-component.model-builder.scale_s .blockicon,.vue-component.model-builder.scale_xs .blockicon,.vue-component.model-builder.scale_xs .connector .text{display:none}.vue-component.model-builder .zoomInfo{position:absolute;top:0;right:0;display:inline-block;padding:.3em;background-color:#f9f9f9;color:#000;border-radius:0 0 0 .3em;z-index:5}.vue-component.model-builder.scale_xs .editDescription{visibility:hidden}.vue-component.federation-backends{background-color:rgba(184,134,11,.1);border:1px solid #b8860b}.vue-component.federation-backends>.header{color:#b8860b}.vue-component.federation-backends{background-color:rgba(255,69,0,.1);border:1px solid #ff4500}.vue-component.federation-backends>.header{color:#ff4500}.vue-component.federation-backends .fed-title{font-weight:400}.vue-component.federation-backends .retry{float:right}.vue-component.parameter-viewer{position:absolute;width:100%;height:100%;z-index:10;overflow:auto;padding:1em;box-sizing:border-box;background-color:#fff;color:#000}.vue-component.parameter-viewer>section>.model-builder{height:400px}.vue-component.parameter-viewer>section{border-top:1px dotted grey;margin:1em 0}.vue-component.parameter-viewer>section>.description{display:flex;align-items:center;justify-content:center;margin-top:1em}.vue-component.parameter-viewer>section>.description>i.fas{margin-right:.5em;color:grey}.vue-component.parameter-viewer>section>.description>.styled-description{flex-grow:1;font-size:.9em;border-left:1px solid grey;padding-left:.5em;color:grey}.vue-component.parameter-viewer .close{position:absolute;top:1.1em;right:1em}.vue-component.parameter-viewer header h2{margin-top:0;font-size:1.2em}.vue-component.parameter-viewer h3{font-size:1.1em}.vue-component.parameter-viewer .highlight h3{color:red}.vue-component .highlight-box{box-shadow:0 0 0 .2em #c8e1ff}.vue-component code.id{color:maroon}.vue-component abbr{-webkit-text-decoration:underline dotted 1px;text-decoration:underline dotted 1px}.vue-component .unit{opacity:.6}.vue-component .status[data-value=submitted]{color:#000}.vue-component .status[data-value=running]{color:#ff8c00}.vue-component .status[data-value=queued]{color:#00008b}.vue-component .status[data-value=finished]{color:#006400}.vue-component .status[data-value=canceled]{color:#a9a9a9}.vue-component .status[data-value=error]{color:red}.vue-component.inline.process{margin-left:1em}.vue-component.inline h1{font-size:1.17em}.vue-component.inline h2{font-size:1.1em}.vue-component.inline h3{font-size:1.05em}.vue-component.inline h4,.vue-component.inline h5,.vue-component.inline h6{font-size:1em}.vue-component .comma-separated-list{display:inline;list-style:none;padding:0}.vue-component .comma-separated-list li{display:inline;padding:0}.vue-component .comma-separated-list li:after{content:", "}.vue-component .comma-separated-list li:last-child:after{content:""}.vue-component .required{color:red;font-weight:700}.vue-component.message-block{margin:1em 0;padding:.5em}.vue-component.message-block>strong{display:block;margin-bottom:.5em}.vue-component.message-block>p{margin:0}.vue-component .param-name,.vue-component .process-name{color:#369}.vue-component .param-argument,.vue-component .return-value{color:#936}.vue-component .data-type{color:#693}.vue-component .param-optional{font-weight:700}.vue-component .badges{margin:0;padding:0;list-style-type:none;display:inline-block}.vue-component .badges .badge{display:inline-block;font-size:.8em;margin:.25em;padding:.35em .5em .25em;line-height:1em;text-align:center;white-space:nowrap;text-transform:uppercase;vertical-align:baseline;border-radius:.5em;color:#fff;background-color:#6c757d}.vue-component .badges:not(.inline){margin-left:-.25em;margin-right:-.25em}.vue-component .badges.small .badge{padding:.25em .35em .2em;font-size:.75em}.vue-component .badges.inline{margin-left:.5em;border-radius:.25em}.vue-component .badges.inline .badge{margin-top:0;margin-bottom:0}.vue-component .badges .badge a{color:#fff;border-bottom:1px dotted #fff;text-decoration:none}.vue-component .badges .badge a.badge-fill{margin:-.35em -.5em;padding:.35em .5em;display:block;border-bottom:0}.vue-component .badges.small .badge a.badge-fill{margin:-.2em -.3em;padding:.25em .35em}.vue-component .badges .badge a:hover{color:#fff;border-bottom-style:solid}.vue-component .badges .default{background-color:#555}.vue-component .badges .green{background-color:green}.vue-component .badges .red{background-color:maroon}.vue-component .badges .option1{background-color:#369}.vue-component .badges .option2{background-color:#693}.vue-component .badges .option3{background-color:#936}.vue-component .badges .option4{background-color:#963}.vue-component .badges .deprecated{background-color:red}.vue-component .badges .experimental{background-color:#8a2be2}.vue-component .badges .action{border:1px solid #000;background-color:#fff;color:#000;margin:.33em;cursor:pointer;text-transform:none}.vue-component .badges .action:hover{background-color:#000;color:#fff}.vue-component .badges .action:hover>a{color:#fff}.vue-component .badges .action>a{color:#000}.vue-component .badges .docker{background-color:#0db7ed}.vue-component .tabular{display:flex;margin:.2em 0;padding:1px}.vue-component .tabular label{flex:1;font-weight:700}.vue-component .tabular .value{flex:3}.vue-component .tabular .value>.formatted>ul,.vue-component .tabular .value>ul,.vue-component .tabular .value td>div,.vue-component .tabular ul.value{max-height:15em;overflow:auto}.vue-component .tabular .value pre{margin:0}.vue-component.stac .map{background:transparent;height:350px}.vue-component.stac .tabular{margin:.5em 0}.vue-component.stac .tabular.wrap{display:block}.vue-component.stac .tabular.wrap .value{margin-top:.5em;margin-left:1em;margin-bottom:.5em}.vue-component.stac .tabular .value ul{padding-left:20px}.assets.empty,.vue-component.stac .links:empty{display:none}.vue-component.stac .thumbnails{overflow-x:auto;overflow-y:hidden;width:100%;white-space:nowrap}.vue-component.stac .thumbnails a{margin:5px;display:inline-block}.vue-component.stac .thumbnails a img{padding:2px;max-height:200px;vertical-align:middle;border:2px solid transparent}.vue-component.stac .thumbnails a:hover img{border:2px solid rgba(0,0,0,.5)}.vue-component .federation>ul>li{margin-bottom:.5em}.vue-component .federation>ul>li>small{display:block}.vue-component .federation>ul>li>h4{margin:0}.vue-component .federation .fed-header{margin:.2em 0}.vue-component .federation .fed-header>.fed-title{display:inline-block;vertical-align:bottom}.vue-component.object-tree .inline{display:inline-block}.vue-component.object-tree ol{padding-left:2em;margin-bottom:.5em}.vue-component.object-tree ol>li:only-child{list-style-type:none;margin-left:-2em}.vue-component.object-tree ol>li>div>ul{padding-left:0}.vue-component.object-tree ul{padding-left:1em}.vue-component.object-tree ul>li{list-style-type:none}.vue-component.object-tree li{margin-bottom:.25em}.dropdown-wrapper{cursor:pointer}.dropdown-wrapper .dropdown-title{display:block;font-size:.9rem;font-family:inherit;cursor:inherit;padding:inherit;line-height:1.4rem;background:transparent;border:none;font-weight:500;color:#2c3e50}.dropdown-wrapper .dropdown-title:hover{border-color:transparent}.dropdown-wrapper .dropdown-title .arrow{vertical-align:middle;margin-top:-1px;margin-left:.4rem}.dropdown-wrapper .nav-dropdown .dropdown-item{color:inherit;line-height:1.7rem}.dropdown-wrapper .nav-dropdown .dropdown-item h4{margin:.45rem 0 0;border-top:1px solid #eee;padding:.45rem 1.5rem 0 1.25rem}.dropdown-wrapper .nav-dropdown .dropdown-item .dropdown-subitem-wrapper{padding:0;list-style:none}.dropdown-wrapper .nav-dropdown .dropdown-item .dropdown-subitem-wrapper .dropdown-subitem{font-size:.9em}.dropdown-wrapper .nav-dropdown .dropdown-item a{display:block;line-height:1.7rem;position:relative;border-bottom:none;font-weight:400;margin-bottom:0;padding:0 1.5rem 0 1.25rem}.dropdown-wrapper .nav-dropdown .dropdown-item a.router-link-active,.dropdown-wrapper .nav-dropdown .dropdown-item a:hover{color:#267cb9}.dropdown-wrapper .nav-dropdown .dropdown-item a.router-link-active:after{content:"";width:0;height:0;border-left:5px solid #267cb9;border-top:3px solid transparent;border-bottom:3px solid transparent;position:absolute;top:calc(50% - 2px);left:9px}.dropdown-wrapper .nav-dropdown .dropdown-item:first-child h4{margin-top:0;padding-top:0;border-top:0}@media (max-width:1024px){.dropdown-wrapper.open .dropdown-title{margin-bottom:.5rem}.dropdown-wrapper .dropdown-title{font-weight:600;font-size:inherit}.dropdown-wrapper .dropdown-title:hover{color:#267cb9}.dropdown-wrapper .nav-dropdown{transition:height .1s ease-out;overflow:hidden}.dropdown-wrapper .nav-dropdown .dropdown-item h4{border-top:0;margin-top:0;padding-top:0}.dropdown-wrapper .nav-dropdown .dropdown-item>a,.dropdown-wrapper .nav-dropdown .dropdown-item h4{font-size:15px;line-height:2rem}.dropdown-wrapper .nav-dropdown .dropdown-item .dropdown-subitem{font-size:14px;padding-left:1rem}}@media (min-width:1024px){.dropdown-wrapper{height:1.8rem}.dropdown-wrapper.open .nav-dropdown,.dropdown-wrapper:hover .nav-dropdown{display:block!important}.dropdown-wrapper.open:blur{display:none}.dropdown-wrapper .dropdown-title .arrow{border-left:4px solid transparent;border-right:4px solid transparent;border-top:6px solid #ccc;border-bottom:0}.dropdown-wrapper .nav-dropdown{display:none;height:auto!important;box-sizing:border-box;max-height:calc(100vh - 2.7rem);overflow-y:auto;position:absolute;top:100%;right:0;background-color:#fff;padding:.6rem 0;border:1px solid;border-color:#ddd #ddd #ccc;text-align:left;border-radius:.25rem;white-space:nowrap;margin:0}}.nav-links{display:inline-block}.nav-links a{line-height:1.4rem;color:inherit}.nav-links a.router-link-active,.nav-links a:hover{color:#267cb9}.nav-links .nav-item{position:relative;display:inline-block;margin-left:1.5rem;line-height:2rem}.nav-links .nav-item:first-child{margin-left:0}@media (min-width:1024px){.nav-links a.router-link-active,.nav-links a:hover{color:#2c3e50}.nav-item>a:not(.external).router-link-active,.nav-item>a:not(.external):hover{margin-bottom:-2px;border-bottom:2px solid #2a89cc}}.navbar{padding:.7rem 1.5rem;line-height:2.2rem}.navbar a,.navbar img,.navbar span{display:inline-block}.navbar .logo{height:2.2rem;min-width:2.2rem;margin-right:.8rem;vertical-align:top}.navbar .site-name{font-size:1.3rem;font-weight:600;color:#2c3e50;position:relative}.navbar .links{padding-left:1.5rem;box-sizing:border-box;background-color:#fff;white-space:nowrap;font-size:.9rem;position:absolute;right:1.5rem;top:.7rem;display:flex}.navbar .links .search-box{flex:0 0 auto;vertical-align:top}@media (max-width:1024px){.navbar{padding-left:4rem}.navbar .can-hide{display:none}.navbar .links{padding-left:1.5rem}.navbar .site-name{width:calc(100vw - 9.4rem);overflow:hidden;white-space:nowrap;text-overflow:ellipsis}}.page-edit{max-width:740px;margin:0 auto;padding:2rem 2.5rem}@media (max-width:1280px){.page-edit{padding:2rem}}@media (max-width:500px){.page-edit{padding:1.5rem}}.page-edit{padding-top:1rem;padding-bottom:1rem;overflow:auto;font-size:.9em}.page-edit .edit-link{display:inline-block;margin-right:1rem}.page-edit .edit-link a{color:#4e6e8e}.page-edit .last-updated{display:inline-block}.page-edit .last-updated .prefix{font-weight:500;color:#4e6e8e}.page-edit .last-updated .time{font-weight:400;color:#aaa}.page-edit .license{margin-top:.5em}@media (max-width:1024px){.page-edit{font-size:.8em}.page-edit .edit-link{margin-bottom:.5rem}.page-edit .last-updated{text-align:left}}.page-nav{max-width:740px;margin:0 auto;padding:2rem 2.5rem}@media (max-width:1280px){.page-nav{padding:2rem}}@media (max-width:500px){.page-nav{padding:1.5rem}}.page-nav{padding-top:1rem;padding-bottom:0}.page-nav .inner{min-height:2rem;margin-top:0;border-top:1px solid #eaecef;padding-top:1rem;overflow:auto}.page-nav .next{float:right}.page{padding-bottom:2rem;display:block}.sidebar-group .sidebar-group{padding-left:.5em}.sidebar-group:not(.collapsable) .sidebar-heading:not(.clickable){cursor:auto;color:inherit}.sidebar-group.is-sub-group{padding-left:0}.sidebar-group.is-sub-group>.sidebar-heading{font-size:.95em;line-height:1.4;font-weight:400;padding-left:2rem}.sidebar-group.is-sub-group>.sidebar-heading:not(.clickable){opacity:.5}.sidebar-group.is-sub-group>.sidebar-group-items{padding-left:1rem}.sidebar-group.is-sub-group>.sidebar-group-items>li>.sidebar-link{font-size:.95em;border-left:none}.sidebar-group.depth-2>.sidebar-heading{border-left:none}.sidebar-heading{color:#2c3e50;transition:color .15s ease;cursor:pointer;font-size:1.1em;font-weight:700;padding:.35rem 1.5rem .35rem 1.25rem;width:100%;box-sizing:border-box;margin:0;border-left:.25rem solid transparent}.sidebar-heading.open,.sidebar-heading:hover{color:inherit}.sidebar-heading .arrow{position:relative;top:-.12em;left:.5em}.sidebar-heading.clickable.active{font-weight:600;color:#267cb9;border-left-color:#267cb9}.sidebar-heading.clickable:hover{color:#267cb9}.sidebar-group-items{transition:height .1s ease-out;font-size:.95em;overflow:hidden}.sidebar .sidebar-sub-headers{padding-left:1rem;font-size:.95em}a.sidebar-link{font-size:1em;font-weight:400;display:inline-block;color:#2c3e50;border-left:.25rem solid transparent;padding:.35rem 1rem .35rem 1.25rem;line-height:1.4;width:100%;box-sizing:border-box}a.sidebar-link:hover{color:#267cb9}a.sidebar-link.active{font-weight:600;color:#267cb9;border-left-color:#267cb9}.sidebar-group a.sidebar-link{padding-left:2rem}.sidebar-sub-headers a.sidebar-link{padding-top:.25rem;padding-bottom:.25rem;border-left:none}.sidebar-sub-headers a.sidebar-link.active{font-weight:500}.sidebar ul{padding:0;margin:0;list-style-type:none}.sidebar a{display:inline-block}.sidebar .nav-links{display:none;border-bottom:1px solid #eaecef;padding:.5rem 0 .75rem}.sidebar .nav-links a{font-weight:600}.sidebar .nav-links .nav-item,.sidebar .nav-links .repo-link{display:block;line-height:1.25rem;font-size:1.1em;padding:.5rem 0 .5rem 1.5rem}.sidebar>.sidebar-links{padding:1.5rem 0}.sidebar>.sidebar-links>li>a.sidebar-link{font-size:1.1em;line-height:1.7;font-weight:700}.sidebar>.sidebar-links>li:not(:first-child){margin-top:.75rem}@media (max-width:1024px){.sidebar .nav-links{display:block}.sidebar .nav-links .dropdown-wrapper .nav-dropdown .dropdown-item a.router-link-active:after{top:calc(1rem - 2px)}.sidebar>.sidebar-links{padding:1rem 0}}@media (min-width:1024px){#docVersionChooser{display:inline-block;z-index:10;position:fixed;top:4.6rem;right:2rem;border-radius:.5em;border:1px solid #eaecef;background-color:#fff;font-size:.9rem}#docVersionChooser button{margin:.3rem .6rem}}@media (max-width:1024px){#docVersionChooser .dropdown-wrapper .dropdown-title:hover{color:#2c3e50}}#docVersionChooser a{color:#2c3e50}#docVersionChooser a:hover{color:#267cb9}.news-meta{margin-bottom:2em;display:block}.fullpage{width:100%;padding-top:3.6rem;height:calc(100vh - 3.6rem);border:0} \ No newline at end of file diff --git a/assets/css/0.styles.53d92970.css b/assets/css/0.styles.53d92970.css new file mode 100644 index 000000000..cb91d1b45 --- /dev/null +++ b/assets/css/0.styles.53d92970.css @@ -0,0 +1 @@ +svg[data-v-49140617]{position:absolute;right:7.5px;opacity:.75;cursor:pointer}svg.hover[data-v-49140617]{opacity:0}svg[data-v-49140617]:hover{opacity:1!important}span[data-v-49140617]{position:absolute;font-size:.85rem;line-height:.425rem;right:50px;opacity:0;transition:opacity .5s}.success[data-v-49140617]{opacity:1!important}.code-copy-added:hover>.code-copy svg{opacity:.75}code[class*=language-],pre[class*=language-]{color:#ccc;background:none;font-family:Consolas,Monaco,Andale Mono,Ubuntu Mono,monospace;font-size:1em;text-align:left;white-space:pre;word-spacing:normal;word-break:normal;word-wrap:normal;line-height:1.5;-moz-tab-size:4;-o-tab-size:4;tab-size:4;-webkit-hyphens:none;hyphens:none}pre[class*=language-]{padding:1em;margin:.5em 0;overflow:auto}:not(pre)>code[class*=language-],pre[class*=language-]{background:#2d2d2d}:not(pre)>code[class*=language-]{padding:.1em;border-radius:.3em;white-space:normal}.token.block-comment,.token.cdata,.token.comment,.token.doctype,.token.prolog{color:#999}.token.punctuation{color:#ccc}.token.attr-name,.token.deleted,.token.namespace,.token.tag{color:#e2777a}.token.function-name{color:#6196cc}.token.boolean,.token.function,.token.number{color:#f08d49}.token.class-name,.token.constant,.token.property,.token.symbol{color:#f8c555}.token.atrule,.token.builtin,.token.important,.token.keyword,.token.selector{color:#cc99cd}.token.attr-value,.token.char,.token.regex,.token.string,.token.variable{color:#7ec699}.token.entity,.token.operator,.token.url{color:#67cdcc}.token.bold,.token.important{font-weight:700}.token.italic{font-style:italic}.token.entity{cursor:help}.token.inserted{color:green}.theme-default-content code{color:#476582;padding:.25rem .5rem;margin:0;font-size:.85em;background-color:rgba(27,31,35,.05);border-radius:3px}.theme-default-content code .token.deleted{color:#ec5975}.theme-default-content code .token.inserted{color:#267cb9}.code-copy{position:absolute;bottom:0;right:0;z-index:3}.theme-default-content pre,.theme-default-content pre[class*=language-]{line-height:1.4;padding:1.25rem 1.5rem;margin:.85rem 0;background-color:#282c34;border-radius:6px;overflow:auto}.theme-default-content pre[class*=language-] code,.theme-default-content pre code{color:#fff;padding:0;background-color:transparent;border-radius:0}div[class*=language-]{position:relative;background-color:#282c34;border-radius:6px}div[class*=language-] .highlight-lines{-webkit-user-select:none;user-select:none;padding-top:1.3rem;position:absolute;top:0;left:0;width:100%;line-height:1.4}div[class*=language-] .highlight-lines .highlighted{background-color:rgba(0,0,0,.66)}div[class*=language-] pre,div[class*=language-] pre[class*=language-]{background:transparent;position:relative;z-index:1}div[class*=language-]:before{position:absolute;z-index:3;top:.8em;right:1em;font-size:.75rem;color:hsla(0,0%,100%,.4)}div[class*=language-]:not(.line-numbers-mode) .line-numbers-wrapper{display:none}div[class*=language-].line-numbers-mode .highlight-lines .highlighted{position:relative}div[class*=language-].line-numbers-mode .highlight-lines .highlighted:before{content:" ";position:absolute;z-index:3;left:0;top:0;display:block;width:3.5rem;height:100%;background-color:rgba(0,0,0,.66)}div[class*=language-].line-numbers-mode pre{padding-left:4.5rem;vertical-align:middle}div[class*=language-].line-numbers-mode .line-numbers-wrapper{position:absolute;top:0;width:3.5rem;text-align:center;color:hsla(0,0%,100%,.3);padding:1.25rem 0;line-height:1.4}div[class*=language-].line-numbers-mode .line-numbers-wrapper br{-webkit-user-select:none;user-select:none}div[class*=language-].line-numbers-mode .line-numbers-wrapper .line-number{position:relative;z-index:4;-webkit-user-select:none;user-select:none;font-size:.85em}div[class*=language-].line-numbers-mode:after{content:"";position:absolute;z-index:2;top:0;left:0;width:3.5rem;height:100%;border-radius:6px 0 0 6px;border-right:1px solid rgba(0,0,0,.66);background-color:#282c34}div[class~=language-js]:before{content:"js"}div[class~=language-ts]:before{content:"ts"}div[class~=language-html]:before{content:"html"}div[class~=language-md]:before{content:"md"}div[class~=language-vue]:before{content:"vue"}div[class~=language-css]:before{content:"css"}div[class~=language-sass]:before{content:"sass"}div[class~=language-scss]:before{content:"scss"}div[class~=language-less]:before{content:"less"}div[class~=language-stylus]:before{content:"stylus"}div[class~=language-go]:before{content:"go"}div[class~=language-java]:before{content:"java"}div[class~=language-c]:before{content:"c"}div[class~=language-sh]:before{content:"sh"}div[class~=language-yaml]:before{content:"yaml"}div[class~=language-py]:before{content:"py"}div[class~=language-docker]:before{content:"docker"}div[class~=language-dockerfile]:before{content:"dockerfile"}div[class~=language-makefile]:before{content:"makefile"}div[class~=language-javascript]:before{content:"js"}div[class~=language-typescript]:before{content:"ts"}div[class~=language-markup]:before{content:"html"}div[class~=language-markdown]:before{content:"md"}div[class~=language-json]:before{content:"json"}div[class~=language-ruby]:before{content:"rb"}div[class~=language-python]:before{content:"py"}div[class~=language-bash]:before{content:"sh"}div[class~=language-php]:before{content:"php"}.custom-block .custom-block-title{font-weight:600;margin-bottom:-.4rem}.custom-block.danger,.custom-block.tip,.custom-block.warning{padding:.1rem 1.5rem;border-left-width:.5rem;border-left-style:solid;margin:1rem 0}.custom-block.tip{background-color:#f3f5f7;border-color:#42b983}.custom-block.warning{background-color:rgba(255,229,100,.3);border-color:#e7c000;color:#6b5900}.custom-block.warning .custom-block-title{color:#b29400}.custom-block.warning a{color:#2c3e50}.custom-block.danger{background-color:#ffe6e6;border-color:#c00;color:#4d0000}.custom-block.danger .custom-block-title{color:#900}.custom-block.danger a{color:#2c3e50}.custom-block.details{display:block;position:relative;border-radius:2px;margin:1.6em 0;padding:1.6em;background-color:#eee}.custom-block.details h4{margin-top:0}.custom-block.details figure:last-child,.custom-block.details p:last-child{margin-bottom:0;padding-bottom:0}.custom-block.details summary{outline:none;cursor:pointer}.arrow{display:inline-block;width:0;height:0}.arrow.up{border-bottom:6px solid #ccc}.arrow.down,.arrow.up{border-left:4px solid transparent;border-right:4px solid transparent}.arrow.down{border-top:6px solid #ccc}.arrow.right{border-left:6px solid #ccc}.arrow.left,.arrow.right{border-top:4px solid transparent;border-bottom:4px solid transparent}.arrow.left{border-right:6px solid #ccc}.theme-default-content:not(.custom){max-width:740px;margin:0 auto;padding:2rem 2.5rem}@media (max-width:1280px){.theme-default-content:not(.custom){padding:2rem}}@media (max-width:500px){.theme-default-content:not(.custom){padding:1.5rem}}.table-of-contents .badge{vertical-align:middle}body,html{padding:0;margin:0;background-color:#fff}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:16px;color:#2c3e50}a{font-weight:500;color:#267cb9}a,a:hover{text-decoration:none}a:hover{color:#8a684f}.navbar{z-index:20;right:0;height:3.6rem;background-color:#fff;box-sizing:border-box;border-bottom:1px solid #eaecef}.navbar,.sidebar-mask{position:fixed;top:0;left:0}.sidebar-mask{z-index:9;width:100vw;height:100vh;display:none}.sidebar{font-size:16px;background-color:#fff;width:20rem;position:fixed;z-index:10;margin:0;top:3.6rem;left:0;bottom:0;box-sizing:border-box;border-right:1px solid #eaecef;overflow-y:auto}.sidebar .nav-links .nav-item{padding-left:0!important}.sidebar-heading{font-weight:600!important}.dropdown-wrapper{cursor:inherit!important}.dropdown-wrapper a,.dropdown-wrapper button{cursor:pointer}.dropdown-wrapper .nav-dropdown .dropdown-item em,.dropdown-wrapper .nav-dropdown .dropdown-item span{padding:0 1.5rem 0 1.25rem}.dropdown-wrapper .nav-dropdown .dropdown-subitem-wrapper .dropdown-subitem a,.dropdown-wrapper .nav-dropdown .dropdown-subitem-wrapper .dropdown-subitem em,.dropdown-wrapper .nav-dropdown .dropdown-subitem-wrapper .dropdown-subitem span{padding-left:2.2rem}.fullpage-content,.theme-default-content{height:100%}.fullpage-content img,.theme-default-content img{max-width:100%}.fullpage-content figure,.theme-default-content figure{max-width:130%;margin:0 -15%;text-align:center}.fullpage-content figcaption,.theme-default-content figcaption{margin:0 11.53%;font-style:italic;display:inline-block;text-align:left}.fullpage-content figcaption:before,.theme-default-content figcaption:before{content:"Figure: ";font-weight:700}@media (min-width:1600px){.fullpage-content img,.theme-default-content img{max-height:90%}.fullpage-content figure,.theme-default-content figure{max-width:150%;margin:0 -25%}.fullpage-content figcaption,.theme-default-content figcaption{margin:0 16.66%}}.theme-default-content:not(.custom)>:first-child{margin-top:3.6rem}.theme-default-content:not(.custom) p.demo{padding:1rem 1.5rem;border:1px solid #ddd;border-radius:4px}.theme-default-content.custom{padding:0;margin:0}.page{padding-left:20rem;padding-bottom:0}.page p a code{font-weight:400;color:#267cb9}.page kbd{background:#eee;border:.15rem solid #ddd;border-bottom:.25rem solid #ddd;border-radius:.15rem;padding:0 .15em}.page blockquote{font-size:1rem;color:#999;border-left:.2rem solid #dfe2e5;margin:1rem 0;padding:.25rem 0 .25rem 1rem}.page>p{margin:0}.page ol,.page ul{padding-left:1.2em}.page strong{font-weight:600}.page h1,.page h2,.page h3,.page h4,.page h5,.page h6{font-weight:600;line-height:1.25}.page h2,.page h3,.page h4{margin-top:-3.6rem;padding-top:3.6rem}.theme-default-content:not(.custom)>.page{margin-top:-3.1rem;padding-top:4.6rem;margin-bottom:0}.theme-default-content:not(.custom)>.page+.custom-block,.theme-default-content:not(.custom)>.page+p,.theme-default-content:not(.custom)>.page+pre,.theme-default-content:not(.custom)>.page:first-child,.theme-default-content:not(.custom)>.page margin-bottom 1rem,.theme-default-content:not(.custom)>.page margin-top -1.5rem{margin-top:2rem}.page:hover .header-anchor{opacity:1}.page h1{font-size:2.2rem}.page h2{font-size:1.65rem;padding-bottom:.3rem;border-bottom:1px solid #eaecef}.page h3{font-size:1.35rem}.page .line-number,.page code,.page kbd{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.page ol,.page p,.page ul{line-height:1.7}.page hr{border:0;border-top:1px solid #eaecef}.page table{border-collapse:collapse;margin:1rem 0;display:block;overflow-x:auto}.page tr{border-top:1px solid #dfe2e5}.page tr:nth-child(2n){background-color:#f6f8fa}.page td,.page th{border:1px solid #dfe2e5;padding:.6em 1em}a.header-anchor{font-size:.85em;float:left;margin-left:-.87em;padding-right:.23em;margin-top:.125em;opacity:0}a.header-anchor:hover{text-decoration:none}.theme-container.sidebar-open .sidebar-mask{display:block}.theme-container.no-navbar .theme-default-content:not(.custom)>h1,.theme-container.no-navbar h2,.theme-container.no-navbar h3,.theme-container.no-navbar h4,.theme-container.no-navbar h5,.theme-container.no-navbar h6{margin-top:1.5rem;padding-top:0}.theme-container.no-navbar .sidebar{top:0}@media (min-width:1025px){.theme-container.no-sidebar .sidebar{display:none}.theme-container.no-sidebar .page{padding-left:0}}.vue-component.search-box .icon{display:none}@media (max-width:1366px){.navbar .site-name{display:none}.fullpage-content figure,.theme-default-content figure{margin:0;max-width:100%}.fullpage-content figcaption,.theme-default-content figcaption{margin:0}}@media (max-width:1280px){.sidebar{font-size:15px;width:16.4rem}.page{padding-left:16.4rem}.navbar .nav-links .nav-item:first-of-type{display:none}}@media (max-width:1024px){.sidebar{top:0;padding-top:3.6rem;transform:translateX(-100%);transition:transform .2s ease}.page{padding-left:0}.theme-container.sidebar-open .sidebar{transform:translateX(0)}.theme-container.no-navbar .sidebar{padding-top:0}.navbar .site-name.can-hide{display:inline-block;width:auto}.nav-links .nav-item:first-child{margin-left:1.5rem!important}}@media (max-width:500px){.page h1{font-size:1.9rem}.theme-default-content div[class*=language-]{margin:.85rem -1.5rem;border-radius:0}}@media (max-width:300px){.navbar .site-name.can-hide{display:none}}#nprogress{pointer-events:none}#nprogress .bar{background:#267cb9;position:fixed;z-index:1031;top:0;left:0;width:100%;height:2px}#nprogress .peg{display:block;position:absolute;right:0;width:100px;height:100%;box-shadow:0 0 10px #267cb9,0 0 5px #267cb9;opacity:1;transform:rotate(3deg) translateY(-4px)}#nprogress .spinner{display:block;position:fixed;z-index:1031;top:15px;right:15px}#nprogress .spinner-icon{width:18px;height:18px;box-sizing:border-box;border-color:#267cb9 transparent transparent #267cb9;border-style:solid;border-width:2px;border-radius:50%;animation:nprogress-spinner .4s linear infinite}.nprogress-custom-parent{overflow:hidden;position:relative}.nprogress-custom-parent #nprogress .bar,.nprogress-custom-parent #nprogress .spinner{position:absolute}@keyframes nprogress-spinner{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.code-switcher div[class*=language-]:before{content:""}.code-switcher .tab-header ul{padding:0;text-align:right;margin-bottom:-5px;margin-top:20px}.code-switcher .tab-header li{display:inline-block;padding:0 10px;cursor:pointer;border-radius:4px;border:2px solid #eaecef;margin-left:5px;font-size:80%}.code-switcher .tab-header li.active{border-color:#267cb9}.icon.outbound{color:#aaa;display:inline-block;vertical-align:middle;position:relative;top:-1px}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}.home{padding-top:3.6rem;max-width:960px;margin:0 auto;display:block}.home .hero{text-align:center}.home .hero img{max-width:100%;max-height:179px;display:block;margin:1.5rem auto}.home .hero h1{font-size:3rem}.home .hero .action,.home .hero .description,.home .hero h1{margin:1.8rem auto}.home .hero .description{max-width:42rem;font-size:1.4rem;line-height:1.3;color:#6a8bad}.home .hero .description.small{font-size:1.1rem}.home .hero .description a{text-decoration:underline}.home .hero .action-button{display:inline-block;font-size:1.2rem;color:#fff;background-color:#267cb9;padding:.8rem 1.6rem;border-radius:4px;transition:background-color .1s ease;box-sizing:border-box;border-bottom:1px solid #2270a6}.home .hero .action-button:hover{background-color:#2b8cd1}.home .features{border-top:1px solid #eaecef;padding:1.2rem 0;margin-top:2.5rem;display:flex;flex-wrap:wrap;align-items:flex-start;align-content:stretch;justify-content:space-between}.home .feature{flex-grow:1;flex-basis:49%;max-width:49%}.home .feature h2{font-size:1.4rem;font-weight:500;border-bottom:none;padding-bottom:0;color:#3a5169}.home .feature p{color:#4e6e8e}@media (max-width:1024px){.home .features{flex-direction:column}.home .feature{max-width:100%;padding:0 2.5rem}}@media (max-width:500px){.home{padding-left:1.5rem;padding-right:1.5rem}.home .hero img{max-height:210px;margin:2rem auto 1.2rem}.home .hero h1{font-size:2rem}.home .hero .action,.home .hero .description,.home .hero h1{margin:1.2rem auto}.home .hero .description{font-size:1.2rem}.home .hero .action-button{font-size:1rem;padding:.6rem 1.2rem}.home .feature h2{font-size:1.25rem}}.algolia-search-wrapper>span{vertical-align:middle}.algolia-search-wrapper .algolia-autocomplete{line-height:normal}.algolia-search-wrapper .algolia-autocomplete .ds-dropdown-menu{background-color:#fff;border:1px solid #999;border-radius:4px;font-size:16px;margin:6px 0 0;padding:4px;text-align:left}.algolia-search-wrapper .algolia-autocomplete .ds-dropdown-menu:before{border-color:#999}.algolia-search-wrapper .algolia-autocomplete .ds-dropdown-menu [class*=ds-dataset-]{border:none;padding:0}.algolia-search-wrapper .algolia-autocomplete .ds-dropdown-menu .ds-suggestions{margin-top:0}.algolia-search-wrapper .algolia-autocomplete .ds-dropdown-menu .ds-suggestion{border-bottom:1px solid #eaecef}.algolia-search-wrapper .algolia-autocomplete .algolia-docsearch-suggestion--highlight{color:#2c815b}.algolia-search-wrapper .algolia-autocomplete .algolia-docsearch-suggestion{border-color:#eaecef;padding:0}.algolia-search-wrapper .algolia-autocomplete .algolia-docsearch-suggestion .algolia-docsearch-suggestion--category-header{padding:5px 10px;margin-top:0;background:#267cb9;color:#fff;font-weight:600}.algolia-search-wrapper .algolia-autocomplete .algolia-docsearch-suggestion .algolia-docsearch-suggestion--category-header .algolia-docsearch-suggestion--highlight{background:hsla(0,0%,100%,.6)}.algolia-search-wrapper .algolia-autocomplete .algolia-docsearch-suggestion .algolia-docsearch-suggestion--wrapper{padding:0}.algolia-search-wrapper .algolia-autocomplete .algolia-docsearch-suggestion .algolia-docsearch-suggestion--title{font-weight:600;margin-bottom:0;color:#2c3e50}.algolia-search-wrapper .algolia-autocomplete .algolia-docsearch-suggestion .algolia-docsearch-suggestion--subcategory-column{vertical-align:top;padding:5px 7px 5px 5px;border-color:#eaecef;background:#f1f3f5}.algolia-search-wrapper .algolia-autocomplete .algolia-docsearch-suggestion .algolia-docsearch-suggestion--subcategory-column:after{display:none}.algolia-search-wrapper .algolia-autocomplete .algolia-docsearch-suggestion .algolia-docsearch-suggestion--subcategory-column-text{color:#555}.algolia-search-wrapper .algolia-autocomplete .algolia-docsearch-footer{border-color:#eaecef}.algolia-search-wrapper .algolia-autocomplete .ds-cursor .algolia-docsearch-suggestion--content{background-color:#e7edf3!important;color:#2c3e50}@media (min-width:1024px){.algolia-search-wrapper .algolia-autocomplete .algolia-docsearch-suggestion .algolia-docsearch-suggestion--subcategory-column{float:none;width:150px;min-width:150px;display:table-cell}.algolia-search-wrapper .algolia-autocomplete .algolia-docsearch-suggestion .algolia-docsearch-suggestion--content{float:none;display:table-cell;width:100%;vertical-align:top}.algolia-search-wrapper .algolia-autocomplete .algolia-docsearch-suggestion .ds-dropdown-menu{min-width:515px!important}}@media (max-width:1024px){.algolia-search-wrapper .ds-dropdown-menu{min-width:calc(100vw - 4rem)!important;max-width:calc(100vw - 4rem)!important}.algolia-search-wrapper .algolia-docsearch-suggestion--wrapper{padding:5px 7px 5px 5px!important}.algolia-search-wrapper .algolia-docsearch-suggestion--subcategory-column{padding:0!important;background:#fff!important}.algolia-search-wrapper .algolia-docsearch-suggestion--subcategory-column-text:after{content:" > ";font-size:10px;line-height:14.4px;display:inline-block;width:5px;margin:-3px 3px 0;vertical-align:middle}}.search-box{display:inline-block;position:relative;margin-right:1rem}.search-box input{cursor:text;width:10rem;height:2rem;color:#4e6e8e;display:inline-block;border:1px solid #cfd4db;border-radius:2rem;font-size:.9rem;line-height:2rem;padding:0 .5rem 0 2rem;outline:none;transition:all .2s ease;background:#fff url(/assets/img/search.83621669.svg) .6rem .5rem no-repeat;background-size:1rem}.search-box input:focus{cursor:auto;border-color:#267cb9}.search-box .suggestions{background:#fff;width:20rem;position:absolute;top:2rem;border:1px solid #cfd4db;border-radius:6px;padding:.4rem;list-style-type:none}.search-box .suggestions.align-right{right:0}.search-box .suggestion{line-height:1.4;padding:.4rem .6rem;border-radius:4px;cursor:pointer}.search-box .suggestion a{white-space:normal;color:#5d82a6}.search-box .suggestion a .page-title{font-weight:600}.search-box .suggestion a .header{font-size:.9em;margin-left:.25em}.search-box .suggestion.focused{background-color:#f3f4f5}.search-box .suggestion.focused a{color:#267cb9}@media (max-width:1280px){.search-box input{cursor:pointer;width:0;border-color:transparent;position:relative}.search-box input:focus{cursor:text;left:0;width:10rem}}@media (-ms-high-contrast:none){.search-box input{height:2rem}}@media (max-width:1280px) and (min-width:1024px){.search-box .suggestions{left:0}}@media (max-width:1024px){.search-box{margin-right:0}.search-box input{left:1rem}.search-box .suggestions{right:0}}@media (max-width:500px){.search-box .suggestions{width:calc(100vw - 4rem)}.search-box input:focus{width:8rem}}.sidebar-button{cursor:pointer;display:none;width:1.25rem;height:1.25rem;position:absolute;padding:.6rem;top:.6rem;left:1rem}.sidebar-button .icon{display:block;width:1.25rem;height:1.25rem}@media (max-width:1024px){.sidebar-button{display:block}}.dropdown-enter,.dropdown-leave-to{height:0!important}.badge[data-v-385f24c3]{display:inline-block;font-size:14px;height:18px;line-height:18px;border-radius:3px;padding:0 6px;color:#fff;background-color:#42b983}.badge.green[data-v-385f24c3],.badge.tip[data-v-385f24c3]{background-color:#267cb9}.badge.error[data-v-385f24c3]{background-color:#da5961}.badge.warn[data-v-385f24c3],.badge.warning[data-v-385f24c3],.badge.yellow[data-v-385f24c3]{background-color:#e7c000}.badge+.badge[data-v-385f24c3]{margin-left:5px}.channels{display:flex}.channels ul{margin:0 1em 0 0;padding:0;list-style-type:none;line-height:1.9;flex-grow:1}.channels a,.channels a:hover{text-decoration:none}.channels img{vertical-align:middle;height:20px;width:20px;filter:invert(1);background-color:#d3c1af;padding:2px;margin-top:-2px;border-radius:3px}.channels .gitter img{background-color:#12e69a}.channels .julia img{background-color:#6aa74d}.channels .github img{background-color:#e7e8e8}.channels .linkedin img{background-color:#ff884a}.channels .youtube img{background-color:#0ff}.channels .x img{background-color:#fff}.channels .r img{background-color:#d8923c}.channels .pypi img{background-color:#c88a56}.channels .conda img{background-color:#bb57cc}.channels .npm img{background-color:#34c7c8}.channels .qgis img{background-color:#a769cd}iframe.stretch{width:100%;height:100%;border:0}.docgen section.action-bar{display:none!important}.searchbox{display:inline-block;position:relative;width:200px;height:32px!important;white-space:nowrap;box-sizing:border-box;visibility:visible!important}.searchbox .algolia-autocomplete{display:block;width:100%;height:100%}.searchbox__wrapper{width:100%;height:100%;z-index:999;position:relative}.searchbox__input{display:inline-block;box-sizing:border-box;transition:box-shadow .4s ease,background .4s ease;border:0;border-radius:16px;box-shadow:inset 0 0 0 1px #ccc;background:#fff!important;padding:0 26px 0 32px;width:100%;height:100%;vertical-align:middle;white-space:normal;font-size:12px;-webkit-appearance:none;-moz-appearance:none;appearance:none}.searchbox__input::-webkit-search-cancel-button,.searchbox__input::-webkit-search-decoration,.searchbox__input::-webkit-search-results-button,.searchbox__input::-webkit-search-results-decoration{display:none}.searchbox__input:hover{box-shadow:inset 0 0 0 1px #b3b3b3}.searchbox__input:active,.searchbox__input:focus{outline:0;box-shadow:inset 0 0 0 1px #aaa;background:#fff}.searchbox__input::-moz-placeholder{color:#aaa}.searchbox__input::placeholder{color:#aaa}.searchbox__submit{position:absolute;top:0;margin:0;border:0;border-radius:16px 0 0 16px;background-color:rgba(69,142,225,0);padding:0;width:32px;height:100%;vertical-align:middle;text-align:center;font-size:inherit;-webkit-user-select:none;-moz-user-select:none;user-select:none;right:inherit;left:0}.searchbox__submit:before{display:inline-block;margin-right:-4px;height:100%;vertical-align:middle;content:""}.searchbox__submit:active,.searchbox__submit:hover{cursor:pointer}.searchbox__submit:focus{outline:0}.searchbox__submit svg{width:14px;height:14px;vertical-align:middle;fill:#6d7e96}.searchbox__reset{display:block;position:absolute;top:8px;right:8px;margin:0;border:0;background:none;cursor:pointer;padding:0;font-size:inherit;-webkit-user-select:none;-moz-user-select:none;user-select:none;fill:rgba(0,0,0,.5)}.searchbox__reset.hide{display:none}.searchbox__reset:focus{outline:0}.searchbox__reset svg{display:block;margin:4px;width:8px;height:8px}.searchbox__input:valid~.searchbox__reset{display:block;animation-name:sbx-reset-in;animation-duration:.15s}@keyframes sbx-reset-in{0%{transform:translate3d(-20%,0,0);opacity:0}to{transform:none;opacity:1}}.algolia-autocomplete.algolia-autocomplete-right .ds-dropdown-menu{right:0!important;left:inherit!important}.algolia-autocomplete.algolia-autocomplete-right .ds-dropdown-menu:before{right:48px}.algolia-autocomplete.algolia-autocomplete-left .ds-dropdown-menu{left:0!important;right:inherit!important}.algolia-autocomplete.algolia-autocomplete-left .ds-dropdown-menu:before{left:48px}.algolia-autocomplete .ds-dropdown-menu{top:-6px;border-radius:4px;margin:6px 0 0;padding:0;text-align:left;height:auto;position:relative;background:transparent;border:none;z-index:999;max-width:600px;min-width:500px;box-shadow:0 1px 0 0 rgba(0,0,0,.2),0 2px 3px 0 rgba(0,0,0,.1)}.algolia-autocomplete .ds-dropdown-menu:before{display:block;position:absolute;content:"";width:14px;height:14px;background:#fff;z-index:1000;top:-7px;border-top:1px solid #d9d9d9;border-right:1px solid #d9d9d9;transform:rotate(-45deg);border-radius:2px}.algolia-autocomplete .ds-dropdown-menu .ds-suggestions{position:relative;z-index:1000;margin-top:8px}.algolia-autocomplete .ds-dropdown-menu .ds-suggestions a:hover{text-decoration:none}.algolia-autocomplete .ds-dropdown-menu .ds-suggestion{cursor:pointer}.algolia-autocomplete .ds-dropdown-menu .ds-suggestion.ds-cursor .algolia-docsearch-suggestion.suggestion-layout-simple,.algolia-autocomplete .ds-dropdown-menu .ds-suggestion.ds-cursor .algolia-docsearch-suggestion:not(.suggestion-layout-simple) .algolia-docsearch-suggestion--content{background-color:rgba(69,142,225,.05)}.algolia-autocomplete .ds-dropdown-menu [class^=ds-dataset-]{position:relative;border:1px solid #d9d9d9;background:#fff;border-radius:4px;overflow:auto;padding:0 8px 8px}.algolia-autocomplete .ds-dropdown-menu *{box-sizing:border-box}.algolia-autocomplete .algolia-docsearch-suggestion{display:block;position:relative;padding:0 8px;background:#fff;color:#02060c;overflow:hidden}.algolia-autocomplete .algolia-docsearch-suggestion--highlight{color:#174d8c;background:rgba(143,187,237,.1);padding:.1em .05em}.algolia-autocomplete .algolia-docsearch-suggestion--category-header .algolia-docsearch-suggestion--category-header-lvl0 .algolia-docsearch-suggestion--highlight,.algolia-autocomplete .algolia-docsearch-suggestion--category-header .algolia-docsearch-suggestion--category-header-lvl1 .algolia-docsearch-suggestion--highlight,.algolia-autocomplete .algolia-docsearch-suggestion--text .algolia-docsearch-suggestion--highlight{padding:0 0 1px;background:inherit;box-shadow:inset 0 -2px 0 0 rgba(69,142,225,.8);color:inherit}.algolia-autocomplete .algolia-docsearch-suggestion--content{display:block;float:right;width:70%;position:relative;padding:5.33333px 0 5.33333px 10.66667px;cursor:pointer}.algolia-autocomplete .algolia-docsearch-suggestion--content:before{content:"";position:absolute;display:block;top:0;height:100%;width:1px;background:#ddd;left:-1px}.algolia-autocomplete .algolia-docsearch-suggestion--category-header{position:relative;border-bottom:1px solid #ddd;display:none;margin-top:8px;padding:4px 0;font-size:1em;color:#33363d}.algolia-autocomplete .algolia-docsearch-suggestion--wrapper{width:100%;float:left;padding:8px 0 0}.algolia-autocomplete .algolia-docsearch-suggestion--subcategory-column{float:left;width:30%;text-align:right;position:relative;padding:5.33333px 10.66667px;color:#a4a7ae;font-size:.9em;word-wrap:break-word}.algolia-autocomplete .algolia-docsearch-suggestion--subcategory-column:before{content:"";position:absolute;display:block;top:0;height:100%;width:1px;background:#ddd;right:0}.algolia-autocomplete .algolia-docsearch-suggestion--subcategory-inline{display:none}.algolia-autocomplete .algolia-docsearch-suggestion--title{margin-bottom:4px;color:#02060c;font-size:.9em;font-weight:700}.algolia-autocomplete .algolia-docsearch-suggestion--text{display:block;line-height:1.2em;font-size:.85em;color:#63676d}.algolia-autocomplete .algolia-docsearch-suggestion--no-results{width:100%;padding:8px 0;text-align:center;font-size:1.2em}.algolia-autocomplete .algolia-docsearch-suggestion--no-results:before{display:none}.algolia-autocomplete .algolia-docsearch-suggestion code{padding:1px 5px;font-size:90%;border:none;color:#222;background-color:#ebebeb;border-radius:3px;font-family:Menlo,Monaco,Consolas,Courier New,monospace}.algolia-autocomplete .algolia-docsearch-suggestion code .algolia-docsearch-suggestion--highlight{background:none}.algolia-autocomplete .algolia-docsearch-suggestion.algolia-docsearch-suggestion__main .algolia-docsearch-suggestion--category-header,.algolia-autocomplete .algolia-docsearch-suggestion.algolia-docsearch-suggestion__secondary{display:block}@media (min-width:768px){.algolia-autocomplete .algolia-docsearch-suggestion .algolia-docsearch-suggestion--subcategory-column{display:block}}@media (max-width:768px){.algolia-autocomplete .algolia-docsearch-suggestion .algolia-docsearch-suggestion--subcategory-column{display:inline-block;width:auto;float:left;padding:0;color:#02060c;font-size:.9em;font-weight:700;text-align:left;opacity:.5}.algolia-autocomplete .algolia-docsearch-suggestion .algolia-docsearch-suggestion--subcategory-column:before{display:none}.algolia-autocomplete .algolia-docsearch-suggestion .algolia-docsearch-suggestion--subcategory-column:after{content:"|"}.algolia-autocomplete .algolia-docsearch-suggestion .algolia-docsearch-suggestion--content{display:inline-block;width:auto;text-align:left;float:left;padding:0}.algolia-autocomplete .algolia-docsearch-suggestion .algolia-docsearch-suggestion--content:before{display:none}}.algolia-autocomplete .suggestion-layout-simple.algolia-docsearch-suggestion{border-bottom:1px solid #eee;padding:8px;margin:0}.algolia-autocomplete .suggestion-layout-simple .algolia-docsearch-suggestion--content{width:100%;padding:0}.algolia-autocomplete .suggestion-layout-simple .algolia-docsearch-suggestion--content:before{display:none}.algolia-autocomplete .suggestion-layout-simple .algolia-docsearch-suggestion--category-header{margin:0;padding:0;display:block;width:100%;border:none}.algolia-autocomplete .suggestion-layout-simple .algolia-docsearch-suggestion--category-header-lvl0,.algolia-autocomplete .suggestion-layout-simple .algolia-docsearch-suggestion--category-header-lvl1{opacity:.6;font-size:.85em}.algolia-autocomplete .suggestion-layout-simple .algolia-docsearch-suggestion--category-header-lvl1:before{background-image:url('data:image/svg+xml;utf8,');content:"";width:10px;height:10px;display:inline-block}.algolia-autocomplete .suggestion-layout-simple .algolia-docsearch-suggestion--wrapper{width:100%;float:left;margin:0;padding:0}.algolia-autocomplete .suggestion-layout-simple .algolia-docsearch-suggestion--duplicate-content,.algolia-autocomplete .suggestion-layout-simple .algolia-docsearch-suggestion--subcategory-inline{display:none!important}.algolia-autocomplete .suggestion-layout-simple .algolia-docsearch-suggestion--title{margin:0;color:#458ee1;font-size:.9em;font-weight:400}.algolia-autocomplete .suggestion-layout-simple .algolia-docsearch-suggestion--title:before{content:"#";font-weight:700;color:#458ee1;display:inline-block}.algolia-autocomplete .suggestion-layout-simple .algolia-docsearch-suggestion--text{margin:4px 0 0;display:block;line-height:1.4em;padding:5.33333px 8px;background:#f8f8f8;font-size:.85em;opacity:.8}.algolia-autocomplete .suggestion-layout-simple .algolia-docsearch-suggestion--text .algolia-docsearch-suggestion--highlight{color:#3f4145;font-weight:700;box-shadow:none}.algolia-autocomplete .algolia-docsearch-footer{width:134px;height:20px;z-index:2000;margin-top:10.66667px;float:right;font-size:0;line-height:0}.algolia-autocomplete .algolia-docsearch-footer--logo{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg width='168' height='24' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cpath d='M78.988.938h16.594a2.968 2.968 0 012.966 2.966V20.5a2.967 2.967 0 01-2.966 2.964H78.988a2.967 2.967 0 01-2.966-2.964V3.897A2.961 2.961 0 0178.988.938zm41.937 17.866c-4.386.02-4.386-3.54-4.386-4.106l-.007-13.336 2.675-.424v13.254c0 .322 0 2.358 1.718 2.364v2.248zm-10.846-2.18c.821 0 1.43-.047 1.855-.129v-2.719a6.334 6.334 0 00-1.574-.199 5.7 5.7 0 00-.897.069 2.699 2.699 0 00-.814.24c-.24.116-.439.28-.582.491-.15.212-.219.335-.219.656 0 .628.219.991.616 1.23s.938.362 1.615.362zm-.233-9.7c.883 0 1.629.109 2.231.328.602.218 1.088.525 1.444.915.363.396.609.922.76 1.483.157.56.232 1.175.232 1.85v6.874a32.5 32.5 0 01-1.868.314c-.834.123-1.772.185-2.813.185-.69 0-1.327-.069-1.895-.198a4.001 4.001 0 01-1.471-.636 3.085 3.085 0 01-.951-1.134c-.226-.465-.343-1.12-.343-1.803 0-.656.13-1.073.384-1.525a3.24 3.24 0 011.047-1.106c.445-.287.95-.492 1.532-.615a8.8 8.8 0 011.82-.185 8.404 8.404 0 011.972.24v-.438c0-.307-.035-.6-.11-.874a1.88 1.88 0 00-.384-.73 1.784 1.784 0 00-.724-.493 3.164 3.164 0 00-1.143-.205c-.616 0-1.177.075-1.69.164a7.735 7.735 0 00-1.26.307l-.321-2.192c.335-.117.834-.233 1.478-.349a10.98 10.98 0 012.073-.178zm52.842 9.626c.822 0 1.43-.048 1.854-.13V13.7a6.347 6.347 0 00-1.574-.199c-.294 0-.595.021-.896.069a2.7 2.7 0 00-.814.24 1.46 1.46 0 00-.582.491c-.15.212-.218.335-.218.656 0 .628.218.991.615 1.23.404.245.938.362 1.615.362zm-.226-9.694c.883 0 1.629.108 2.231.327.602.219 1.088.526 1.444.915.355.39.609.923.759 1.483a6.8 6.8 0 01.233 1.852v6.873c-.41.088-1.034.19-1.868.314-.834.123-1.772.184-2.813.184-.69 0-1.327-.068-1.895-.198a4.001 4.001 0 01-1.471-.635 3.085 3.085 0 01-.951-1.134c-.226-.465-.343-1.12-.343-1.804 0-.656.13-1.073.384-1.524.26-.45.608-.82 1.047-1.107.445-.286.95-.491 1.532-.614a8.803 8.803 0 012.751-.13c.329.034.671.096 1.04.185v-.437a3.3 3.3 0 00-.109-.875 1.873 1.873 0 00-.384-.731 1.784 1.784 0 00-.724-.492 3.165 3.165 0 00-1.143-.205c-.616 0-1.177.075-1.69.164a7.75 7.75 0 00-1.26.307l-.321-2.193c.335-.116.834-.232 1.478-.348a11.633 11.633 0 012.073-.177zm-8.034-1.271a1.626 1.626 0 01-1.628-1.62c0-.895.725-1.62 1.628-1.62.904 0 1.63.725 1.63 1.62 0 .895-.733 1.62-1.63 1.62zm1.348 13.22h-2.689V7.27l2.69-.423v11.956zm-4.714 0c-4.386.02-4.386-3.54-4.386-4.107l-.008-13.336 2.676-.424v13.254c0 .322 0 2.358 1.718 2.364v2.248zm-8.698-5.903c0-1.156-.253-2.119-.746-2.788-.493-.677-1.183-1.01-2.067-1.01-.882 0-1.574.333-2.065 1.01-.493.676-.733 1.632-.733 2.788 0 1.168.246 1.953.74 2.63.492.683 1.183 1.018 2.066 1.018.882 0 1.574-.342 2.067-1.019.492-.683.738-1.46.738-2.63zm2.737-.007c0 .902-.13 1.584-.397 2.33a5.52 5.52 0 01-1.128 1.906 4.986 4.986 0 01-1.752 1.223c-.685.286-1.739.45-2.265.45-.528-.006-1.574-.157-2.252-.45a5.096 5.096 0 01-1.744-1.223c-.487-.527-.863-1.162-1.137-1.906a6.345 6.345 0 01-.41-2.33c0-.902.123-1.77.397-2.508a5.554 5.554 0 011.15-1.892 5.133 5.133 0 011.75-1.216c.679-.287 1.425-.423 2.232-.423.808 0 1.553.142 2.237.423a4.88 4.88 0 011.753 1.216 5.644 5.644 0 011.135 1.892c.287.738.431 1.606.431 2.508zm-20.138 0c0 1.12.246 2.363.738 2.882.493.52 1.13.78 1.91.78.424 0 .828-.062 1.204-.178.377-.116.677-.253.917-.417V9.33a10.476 10.476 0 00-1.766-.226c-.971-.028-1.71.37-2.23 1.004-.513.636-.773 1.75-.773 2.788zm7.438 5.274c0 1.824-.466 3.156-1.404 4.004-.936.846-2.367 1.27-4.296 1.27-.705 0-2.17-.137-3.34-.396l.431-2.118c.98.205 2.272.26 2.95.26 1.074 0 1.84-.219 2.299-.656.459-.437.684-1.086.684-1.948v-.437a8.07 8.07 0 01-1.047.397c-.43.13-.93.198-1.492.198-.739 0-1.41-.116-2.018-.349a4.206 4.206 0 01-1.567-1.025c-.431-.45-.774-1.017-1.013-1.694-.24-.677-.363-1.885-.363-2.773 0-.834.13-1.88.384-2.577.26-.696.629-1.298 1.129-1.796.493-.498 1.095-.881 1.8-1.162a6.605 6.605 0 012.428-.457c.87 0 1.67.109 2.45.24.78.129 1.444.265 1.985.415V18.17z' fill='%235468FF'/%3E%3Cpath d='M6.972 6.677v1.627c-.712-.446-1.52-.67-2.425-.67-.585 0-1.045.13-1.38.391a1.24 1.24 0 00-.502 1.03c0 .425.164.765.494 1.02.33.256.835.532 1.516.83.447.192.795.356 1.045.495.25.138.537.332.862.582.324.25.563.548.718.894.154.345.23.741.23 1.188 0 .947-.334 1.691-1.004 2.234-.67.542-1.537.814-2.601.814-1.18 0-2.16-.229-2.936-.686v-1.708c.84.628 1.814.942 2.92.942.585 0 1.048-.136 1.388-.407.34-.271.51-.646.51-1.125 0-.287-.1-.55-.302-.79-.203-.24-.42-.42-.655-.542-.234-.123-.585-.29-1.053-.503a61.27 61.27 0 01-.582-.271 13.67 13.67 0 01-.55-.287 4.275 4.275 0 01-.567-.351 6.92 6.92 0 01-.455-.4c-.18-.17-.31-.34-.39-.51-.08-.17-.155-.37-.224-.598a2.553 2.553 0 01-.104-.742c0-.915.333-1.638.998-2.17.664-.532 1.523-.798 2.576-.798.968 0 1.793.17 2.473.51zm7.468 5.696v-.287c-.022-.607-.187-1.088-.495-1.444-.309-.357-.75-.535-1.324-.535-.532 0-.99.194-1.373.583-.382.388-.622.949-.717 1.683h3.909zm1.005 2.792v1.404c-.596.34-1.383.51-2.362.51-1.255 0-2.255-.377-3-1.132-.744-.755-1.116-1.744-1.116-2.968 0-1.297.34-2.316 1.021-3.055.68-.74 1.548-1.11 2.6-1.11 1.033 0 1.852.323 2.458.966.606.644.91 1.572.91 2.784 0 .33-.033.676-.096 1.038h-5.314c.107.702.405 1.239.894 1.611.49.372 1.106.558 1.85.558.862 0 1.58-.202 2.155-.606zm6.605-1.77h-1.212c-.596 0-1.045.116-1.349.35-.303.234-.454.532-.454.894 0 .372.117.664.35.877.235.213.575.32 1.022.32.51 0 .912-.142 1.204-.424.293-.281.44-.651.44-1.108v-.91zm-4.068-2.554V9.325c.627-.361 1.457-.542 2.489-.542 2.116 0 3.175 1.026 3.175 3.08V17h-1.548v-.957c-.415.68-1.143 1.02-2.186 1.02-.766 0-1.38-.22-1.843-.661-.462-.442-.694-1.003-.694-1.684 0-.776.293-1.38.878-1.81.585-.431 1.404-.647 2.457-.647h1.34V11.8c0-.554-.133-.971-.399-1.253-.266-.282-.707-.423-1.324-.423a4.07 4.07 0 00-2.345.718zm9.333-1.93v1.42c.394-1 1.101-1.5 2.123-1.5.148 0 .313.016.494.048v1.531a1.885 1.885 0 00-.75-.143c-.542 0-.989.24-1.34.718-.351.479-.527 1.048-.527 1.707V17h-1.563V8.91h1.563zm5.01 4.084c.022.82.272 1.492.75 2.019.479.526 1.15.79 2.01.79.639 0 1.235-.176 1.788-.527v1.404c-.521.319-1.186.479-1.995.479-1.265 0-2.276-.4-3.031-1.197-.755-.798-1.133-1.792-1.133-2.984 0-1.16.38-2.151 1.14-2.975.761-.825 1.79-1.237 3.088-1.237.702 0 1.346.149 1.93.447v1.436a3.242 3.242 0 00-1.77-.495c-.84 0-1.513.266-2.019.798-.505.532-.758 1.213-.758 2.042zM40.24 5.72v4.579c.458-1 1.293-1.5 2.505-1.5.787 0 1.42.245 1.899.734.479.49.718 1.17.718 2.042V17h-1.564v-5.106c0-.553-.14-.98-.422-1.284-.282-.303-.652-.455-1.11-.455-.531 0-1.002.202-1.411.606-.41.405-.615 1.022-.615 1.851V17h-1.563V5.72h1.563zm14.966 10.02c.596 0 1.096-.253 1.5-.758.404-.506.606-1.157.606-1.955 0-.915-.202-1.62-.606-2.114-.404-.495-.92-.742-1.548-.742-.553 0-1.05.224-1.491.67-.442.447-.662 1.133-.662 2.058 0 .958.212 1.67.638 2.138.425.469.946.703 1.563.703zM53.004 5.72v4.42c.574-.894 1.388-1.341 2.44-1.341 1.022 0 1.857.383 2.506 1.149.649.766.973 1.781.973 3.047 0 1.138-.309 2.109-.925 2.912-.617.803-1.463 1.205-2.537 1.205-1.075 0-1.894-.447-2.457-1.34V17h-1.58V5.72h1.58zm9.908 11.104l-3.223-7.913h1.739l1.005 2.632 1.26 3.415c.096-.32.48-1.458 1.15-3.415l.909-2.632h1.66l-2.92 7.866c-.777 2.074-1.963 3.11-3.559 3.11a2.92 2.92 0 01-.734-.079v-1.34c.17.042.351.064.543.064 1.032 0 1.755-.57 2.17-1.708z' fill='%235D6494'/%3E%3Cpath d='M89.632 5.967v-.772a.978.978 0 00-.978-.977h-2.28a.978.978 0 00-.978.977v.793c0 .088.082.15.171.13a7.127 7.127 0 011.984-.28c.65 0 1.295.088 1.917.259.082.02.164-.04.164-.13m-6.248 1.01l-.39-.389a.977.977 0 00-1.382 0l-.465.465a.973.973 0 000 1.38l.383.383c.062.061.15.047.205-.014.226-.307.472-.601.746-.874.281-.28.568-.526.883-.751.068-.042.075-.137.02-.2m4.16 2.453v3.341c0 .096.104.165.192.117l2.97-1.537c.068-.034.089-.117.055-.184a3.695 3.695 0 00-3.08-1.866c-.068 0-.136.054-.136.13m0 8.048a4.489 4.489 0 01-4.49-4.482 4.488 4.488 0 014.49-4.482 4.488 4.488 0 014.489 4.482 4.484 4.484 0 01-4.49 4.482m0-10.85a6.363 6.363 0 100 12.729 6.37 6.37 0 006.372-6.368 6.358 6.358 0 00-6.371-6.36' fill='%23FFF'/%3E%3C/g%3E%3C/svg%3E");background-repeat:no-repeat;background-position:50%;background-size:100%;overflow:hidden;text-indent:-9000px;padding:0!important;width:100%;height:100%;display:block}.vue-component.loading-notice .loading:after{content:".";animation:dots 1.25s steps(5) infinite;font-size:1.5em;line-height:1em;font-weight:700}@keyframes dots{0%,20%{color:transparent;text-shadow:.25em 0 0 transparent,.5em 0 0 transparent}40%{color:#000;text-shadow:.25em 0 0 transparent,.5em 0 0 transparent}60%{text-shadow:.25em 0 0 #000,.5em 0 0 transparent}80%,to{text-shadow:.25em 0 0 #000,.5em 0 0 #000}}.vue-component.styled-description{line-height:1.25em}.vue-component.styled-description code{color:maroon;display:inline-block;padding:0 .1em}.vue-component.styled-description pre{background-color:#eee;width:100%;border:1px solid #ccc;max-height:15em;overflow-y:auto}.vue-component.styled-description pre code{background-color:transparent;display:block;margin:.5em}.vue-component.styled-description.compact pre{max-height:7em;width:auto;max-width:100%}.vue-component.styled-description.compact p{margin:.5em 0}.vue-component.styled-description.compact p:first-child{margin-top:0}.vue-component.styled-description.compact p:last-child{margin-bottom:0}.vue-component.process-example .content{border-left:5px solid #ccc;border-bottom:1px solid #ccc;padding:.5em;margin-left:3em;box-sizing:border-box}.vue-component.process-example .content .styled-description{margin-bottom:1em}.vue-component.process .namespace{font-weight:400;color:#aaa}.vue-component.process .process-bar{display:flex;align-items:baseline}.vue-component.process .process-bar .badges{margin-top:.75em}.vue-component.process .categories{flex:1}.vue-component.process .actions{text-align:right}.vue-component.process strong.deprecated{color:red}.vue-component.process strong.experimental{color:#8a2be2}.vue-component.process .exception{margin-top:.5em}.vue-component.process .exception code{font-weight:700}.vue-component.process .exception .styled-description{margin:.5em 0}.vue-component.process .exception .message{margin:.5em 0;font-size:.8em}.vue-component.process .signature{display:block;margin:1em 0}.vue-component.process .process-graph .graph{max-width:100%;height:300px;border:1px solid #ccc}.vue-component.process .process-graph .graph>.object-tree>ul{margin:0;padding:0}.vue-component.process .links:empty{display:none}.vue-component.searchable-list.expandable .heading{cursor:pointer;padding-left:1em}.vue-component.searchable-list.expandable .heading:before{content:"▸";margin-left:-1em;float:left;font-size:1em}.vue-component.searchable-list.expandable.expanded .heading:before{content:"▾"}.vue-component.searchable-list .action-bar{width:100%;display:flex;margin-bottom:1em;padding:1px;gap:.5em}.vue-component.searchable-list .action-bar:empty{display:none}.vue-component.searchable-list .action-bar>.search-box{min-width:150px;flex:1;margin:0}.vue-component.searchable-list .action-bar>.deprecated,.vue-component.searchable-list .action-bar>.experimental{white-space:nowrap;align-content:center}.vue-component.searchable-list .details{display:none}.vue-component.searchable-list .list .details h2,.vue-component.searchable-list .list .details h3,.vue-component.searchable-list .list .details h4,.vue-component.searchable-list .list .details h5,.vue-component.searchable-list .list .details h6{font-size:1em}.vue-component.searchable-list ul.list{margin-left:0;padding-left:0;list-style-type:none}.vue-component.searchable-list ul.list>li{margin-bottom:.5em}.vue-component.searchable-list ul.list>li>summary{margin-bottom:.5em;margin-left:1em;line-height:1.33em}.vue-component.searchable-list ul.list>li>summary strong{display:block;text-overflow:ellipsis;overflow:hidden}.vue-component.searchable-list ul.list>li>summary strong .copy{display:none}.vue-component.searchable-list ul.list>li>summary strong.inline{display:inline}.vue-component.searchable-list ul.list>li>summary.experimental strong{color:#8a2be2}.vue-component.searchable-list ul.list>li>summary.deprecated strong{text-decoration:line-through}.vue-component.searchable-list ul.list>li>summary:before{content:"▸";margin-left:-1em;float:left;font-size:1em}.vue-component.searchable-list ul.list>li>summary .badges.block{display:block}.vue-component.searchable-list ul.expandable>li>summary{cursor:pointer}.vue-component.searchable-list ul.expandable>li>summary:hover strong .copy{display:inline-block!important}.vue-component.searchable-list ul.expandable>li.expanded{margin-bottom:2em}.vue-component.searchable-list ul.expandable>li.expanded .details{display:block;margin-left:1em}.vue-component.searchable-list ul.expandable>li.expanded>summary:before{content:"▾"}.vue-component.searchable-list ul.expandable>li.expanded>summary .hideOnExpand{display:none}.vue-component.search-box{margin:0 1px 1em 0;display:flex;align-items:stretch}.vue-component.search-box .icon,.vue-component.search-box input{font-size:1em;margin:0}.vue-component.search-box input{flex-grow:1;padding:.3em .3em .3em 1.9em;z-index:1;border:1px solid #ccc;box-sizing:content-box;background-color:#fff;box-sizing:border-box;width:100%;margin-left:-1.3em}.vue-component.search-box .icon{display:flex;align-items:center;-webkit-user-select:none;user-select:none;margin-left:.3em;width:1em;z-index:2}.vue-component.search-box.compact{font-size:.9em;margin-bottom:0}.vue-component.search-box.compact input{padding-top:0;padding-bottom:0}.vue-component.search-box.compact .icon{margin-top:.1em;margin-left:.3em}.docgen{height:100%;font-family:Roboto Sans,sans-serif;margin:0;padding:0}.docgen code,.docgen pre .docgen kbd{font-family:Roboto Mono,Consolas,monospace}.docgen h2{font-size:1.75em;padding:.25em 0;margin:0 0 .75em;border-bottom:1px solid #ccc}.docgen h2 .copy{color:#856404;cursor:pointer}.docgen h2 .copy:hover{color:#000}.docgen h2 .copy.success{color:green;cursor:auto}.docgen h3{font-size:1.4em;margin:1.5em 0 .75em;padding:.25em 0;border-bottom:1px dotted #ccc}.docgen h4{margin:1.5em 0 .25em;font-size:1.2em}.docgen h5{margin:.5em 0 .25em;font-size:1.1em}.docgen h6{margin:.5em 0 .25em;font-size:1em}.docgen p{margin:0 0 .75em}.docgen td p{margin:.25em 0}.docgen li p{margin:0 0 .25em}.docgen a{color:#2f649a;text-decoration:none;cursor:pointer}.docgen a:hover{color:#000}.docgen .notice{margin:0 3rem 1rem 2rem;padding:1rem 3.5rem 1rem 1rem;border-radius:.25rem;position:fixed;bottom:0;color:#856404;background-color:#fff3cd;border:1px solid #856404}.docgen .notice p:last-of-type{margin-bottom:0}.docgen .notice .close{position:absolute;top:0;right:0;font-size:1.5em;padding:.5rem;margin:.5rem;font-weight:700;line-height:1;opacity:.5;background-color:transparent;border:0;color:inherit;cursor:pointer}.docgen .notice .close:hover{opacity:1;outline:0}.docgen .categories h2{display:block;text-transform:capitalize;font-size:1em;cursor:pointer;border:0;margin-top:0;margin-bottom:0}.docgen .categories ul.list{margin-left:.5em;margin-top:.25em}.docgen .categories ul.list li{margin-left:.5em}.docgen .categories .noResults{display:none}.docgen .process{margin:1em 1em 5em;padding:0}@media only screen and (min-width:1280px){.docgen .process{margin-bottom:10em}.docgen .process h3{margin-top:2em}}.docgen .no-processes-found{text-align:center;display:block}.docgen .fileChooser{width:100%;height:100%;display:flex;align-items:center;justify-content:center}.docgen .fileChooser p{width:25%}.docgen .fileChooser input{margin-top:.5em;width:100%}.docgen .menu-container section{margin:1em}.docgen .menu-container ul{list-style-type:square;display:block;padding:0}.docgen .menu-container summary{margin-bottom:.5em}.docgen .menu-container .controls{text-align:center;display:block;margin:1em 0;padding:0;list-style-type:none}.docgen .menu-container .controls li{display:inline-block}.docgen .menu-container .controls li a{font-weight:400;background-color:#d2691e;color:#fff;display:inline-block;margin:.25em .35em;padding:.25em .5em;border-radius:3px}.docgen .menu-container .controls li a:hover{background-color:#000}.docgen .vue-component.searchable-list ul.list>li>summary{line-height:inherit}.docgen .menu-container li a{font-weight:700}.docgen .content-container.toc{padding-top:3em}.docgen .related-links{margin-top:4em;margin-bottom:2em}.docgen .filters{display:flex;justify-content:center;flex-flow:row wrap}.docgen .filters .label,.docgen .filters .show-deprecated,.docgen .filters .show-experimental{align-content:center;display:inline-block;white-space:nowrap;margin:.25rem;font-size:.9em;cursor:pointer}.docgen .filters .label{cursor:default}@media only screen and (min-width:800px){.docgen .related-links{margin-top:3em;margin-bottom:0}.docgen .page-container{display:flex;height:100%}.docgen .content-container,.docgen .menu-container{height:100%;overflow-y:scroll}.docgen .content-container.toc{flex:1;padding-top:0}.docgen .menu-container{flex:1;min-width:250px;max-width:25%;border-right:1px dotted #ccc}}@media only screen and (min-width:1280px){.docgen .menu-container{max-width:20%}}.vue-component.process-parameter .details{margin-left:3em}.vue-component.process-parameter .default{font-weight:400}.vue-component.process-parameter h4 code{font-size:1.15em}.vue-component .json-schema{border-left:5px solid #ccc;padding:.5em;box-sizing:border-box}.vue-component .json-schema.composite{border-left:0;padding-left:0}.vue-component .json-schema .schemaProcessGraph,.vue-component .json-schema td,.vue-component .json-schema th{padding:.5em}.vue-component .json-schema .schemaProcessGraph h4{font-size:1.1em;margin-top:1em}.vue-component .json-schema .data-type{font-weight:700}.vue-component .json-schema .data-types-container>.json-schema{border-left:7px solid #ccc;border-bottom:1px solid #ccc;margin-bottom:1em;margin-left:.25em}.vue-component .json-schema .inline-schema-attrs .json-schema{border:0;padding:0;width:100%;background-color:transparent}.vue-component .json-schema .schema-name{display:inline-block;border-bottom:1px dotted #000}.vue-component .json-schema .schema-attrs{width:100%;margin:-.25em}.vue-component .json-schema .schema-attrs .key{white-space:nowrap}.vue-component .json-schema .schema-attrs .value{width:90%}.vue-component .json-schema .schema-attrs>tr>td>.styled-description{margin-bottom:1em}.vue-component .json-schema p.schema-attrs{margin:1em 0 .5em}.vue-component .json-schema p.schema-attrs:first-of-type{margin:0 0 1em}.vue-component .json-schema .data-types-heading,.vue-component .json-schema .object-prop-heading{text-align:left}.vue-component .json-schema .object-properties>tr>.key{font-style:italic;font-weight:700;min-width:80px;width:8%;vertical-align:top;padding-top:.75em;padding-left:1em}.vue-component .json-schema .object-properties>tr>.value{border-bottom:1px dotted #ccc}.vue-component .json-schema .object-properties>tr:last-of-type>.value{border-bottom:0}.vue-component .json-schema .object-properties>th{padding-top:1em}.vue-component.deprecation-notice{background-color:rgba(255,0,0,.1);border:1px solid red}.vue-component.deprecation-notice strong{display:block;color:red}.vue-component.experimental-notice{background-color:rgba(138,43,226,.1);border:1px solid #8a2be2}.vue-component.experimental-notice strong{color:#8a2be2}.vue-component.model-builder .block .connector{font-size:.9em;margin:.2em 0;white-space:nowrap}.vue-component.model-builder .block .connector.noValue{color:red}.vue-component.model-builder .block .connector.editable .label,.vue-component.model-builder .block .connector.editable .value{cursor:pointer}.vue-component.model-builder .block .connector span[title]{cursor:help}.vue-component.model-builder .block .connector .input{max-width:100%;overflow:hidden;text-overflow:ellipsis}.vue-component.model-builder .block .connector .output{text-align:right}.vue-component.model-builder .block .connector .unspecified{color:red;margin-right:.3em}.vue-component.model-builder .block .connector .circle{width:.8em;height:.8em;margin:0 .2em;border:1px solid #888;background-color:transparent;display:inline-block}.vue-component.model-builder .block .connector .circle.io_active{background-color:#ffc800}.vue-component.model-builder .block .connector .circle.io_selected{background-color:#00c800!important}.vue-component.model-builder .block .connector .circle.io_issues{background-color:red}.vue-component.model-builder.editable .circle{cursor:pointer}.vue-component.model-builder .block{position:absolute;border:2px solid #ccc;margin-left:0;margin-top:0;background-color:#fafafa;opacity:.8;font-size:14px;user-select:none;-moz-user-select:none;-khtml-user-select:none;-webkit-user-select:none;-o-user-select:none;color:#000}.vue-component.model-builder .block .description{display:none;width:200px;padding:3px;border:1px solid #083776;border-radius:5px;color:#001531;background-color:#91bcf6;margin-top:15px;position:absolute;font-weight:400}.vue-component.model-builder .block .blockTitle{display:flex;padding:.3em .1em;font-weight:700;background-color:#ddd;margin-bottom:.1em;cursor:move;font-size:.9em}.vue-component.model-builder .block .blockTitle .blockId{opacity:.4;margin-left:.25em;font-weight:400}.vue-component.model-builder .block .blockTitle .namespace{font-weight:400}.vue-component.model-builder .block .blockTitle .titleText{flex-grow:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.vue-component.model-builder .block .blockTitle .blockicon{white-space:nowrap;text-align:center}.vue-component.model-builder .block .blockTitle .blockicon i.fas{min-width:1.4em;cursor:pointer;opacity:.5;margin-left:.1em}.vue-component.model-builder .block .blockTitle .blockicon i.fas:hover{opacity:1}.vue-component.model-builder .block .invalid{color:red;cursor:help}.vue-component.model-builder .block .inout{display:flex}.vue-component.model-builder .block .inputs{flex-grow:1;max-width:100%;overflow:hidden;text-overflow:ellipsis}.vue-component.model-builder .block .editDescription{padding:.3em .2em;box-sizing:border-box;font-size:.9em;line-height:1em;overflow:auto;border:0;border-top:1px dotted #ccc;background-color:transparent;width:100%;max-width:100%;height:3.7em;min-height:2.5em;resize:none}.vue-component.model-builder .block .editDescription:focus{outline:0}.vue-component.model-builder .block_collection{border:2px solid #6b8daf}.vue-component.model-builder .block_collection .blockTitle{background-color:#a3b7cc}.vue-component.model-builder .block_collection .field_id{display:none}.vue-component.model-builder .block_result{border:2px solid #888}.vue-component.model-builder .block_result .field_output .circle{background-color:#888;cursor:auto}.vue-component.model-builder .block_argument{border:2px solid #b28c6b}.vue-component.model-builder .block_argument .blockTitle{background-color:#ccb7a3}.vue-component.model-builder .block_selected{border:2px solid #0a0!important}.vue-component.model-builder .block_selected .blockTitle{background-color:#0c0!important}.vue-component.model-builder .block_invalid{border:2px solid red!important}.vue-component.model-builder{width:100%;height:100%;position:relative}.vue-component.model-builder.editable.focus .blocks{border-color:rgba(22,102,182,.3)}.vue-component.model-builder .blocks:focus,.vue-component.model-builder .canvas:focus,.vue-component.model-builder:focus{outline:0}.vue-component.model-builder .canvas{width:100%;height:100%;position:absolute;z-index:1}.vue-component.model-builder .blocks{box-sizing:border-box;border:1px solid transparent;overflow:hidden;position:absolute;z-index:3;width:100%;height:100%}.vue-component.model-builder.compact .blockicon .addDescription,.vue-component.model-builder.compact .blockicon .delete,.vue-component.model-builder.compact .blockicon .info,.vue-component.model-builder.compact .blockId,.vue-component.model-builder.compact .editDescription,.vue-component.model-builder.scale_s .blockicon,.vue-component.model-builder.scale_xs .blockicon,.vue-component.model-builder.scale_xs .connector .text{display:none}.vue-component.model-builder .zoomInfo{position:absolute;top:0;right:0;display:inline-block;padding:.3em;background-color:#f9f9f9;color:#000;border-radius:0 0 0 .3em;z-index:5}.vue-component.model-builder.scale_xs .editDescription{visibility:hidden}.vue-component.federation-backends{background-color:rgba(184,134,11,.1);border:1px solid #b8860b}.vue-component.federation-backends>.header{color:#b8860b}.vue-component.federation-backends{background-color:rgba(255,69,0,.1);border:1px solid #ff4500}.vue-component.federation-backends>.header{color:#ff4500}.vue-component.federation-backends .fed-title{font-weight:400}.vue-component.federation-backends .retry{float:right}.vue-component.parameter-viewer{position:absolute;width:100%;height:100%;z-index:10;overflow:auto;padding:1em;box-sizing:border-box;background-color:#fff;color:#000}.vue-component.parameter-viewer>section>.model-builder{height:400px}.vue-component.parameter-viewer>section{border-top:1px dotted grey;margin:1em 0}.vue-component.parameter-viewer>section>.description{display:flex;align-items:center;justify-content:center;margin-top:1em}.vue-component.parameter-viewer>section>.description>i.fas{margin-right:.5em;color:grey}.vue-component.parameter-viewer>section>.description>.styled-description{flex-grow:1;font-size:.9em;border-left:1px solid grey;padding-left:.5em;color:grey}.vue-component.parameter-viewer .close{position:absolute;top:1.1em;right:1em}.vue-component.parameter-viewer header h2{margin-top:0;font-size:1.2em}.vue-component.parameter-viewer h3{font-size:1.1em}.vue-component.parameter-viewer .highlight h3{color:red}.vue-component .highlight-box{box-shadow:0 0 0 .2em #c8e1ff}.vue-component code.id{color:maroon}.vue-component abbr{-webkit-text-decoration:underline dotted 1px;text-decoration:underline dotted 1px}.vue-component .unit{opacity:.6}.vue-component .status[data-value=submitted]{color:#000}.vue-component .status[data-value=running]{color:#ff8c00}.vue-component .status[data-value=queued]{color:#00008b}.vue-component .status[data-value=finished]{color:#006400}.vue-component .status[data-value=canceled]{color:#a9a9a9}.vue-component .status[data-value=error]{color:red}.vue-component.inline.process{margin-left:1em}.vue-component.inline h1{font-size:1.17em}.vue-component.inline h2{font-size:1.1em}.vue-component.inline h3{font-size:1.05em}.vue-component.inline h4,.vue-component.inline h5,.vue-component.inline h6{font-size:1em}.vue-component .comma-separated-list{display:inline;list-style:none;padding:0}.vue-component .comma-separated-list li{display:inline;padding:0}.vue-component .comma-separated-list li:after{content:", "}.vue-component .comma-separated-list li:last-child:after{content:""}.vue-component .required{color:red;font-weight:700}.vue-component.message-block{margin:1em 0;padding:.5em}.vue-component.message-block>strong{display:block;margin-bottom:.5em}.vue-component.message-block>p{margin:0}.vue-component .param-name,.vue-component .process-name{color:#369}.vue-component .param-argument,.vue-component .return-value{color:#936}.vue-component .data-type{color:#693}.vue-component .param-optional{font-weight:700}.vue-component .badges{margin:0;padding:0;list-style-type:none;display:inline-block}.vue-component .badges .badge{display:inline-block;font-size:.8em;margin:.25em;padding:.35em .5em .25em;line-height:1em;text-align:center;white-space:nowrap;text-transform:uppercase;vertical-align:baseline;border-radius:.5em;color:#fff;background-color:#6c757d}.vue-component .badges:not(.inline){margin-left:-.25em;margin-right:-.25em}.vue-component .badges.small .badge{padding:.25em .35em .2em;font-size:.75em}.vue-component .badges.inline{margin-left:.5em;border-radius:.25em}.vue-component .badges.inline .badge{margin-top:0;margin-bottom:0}.vue-component .badges .badge a{color:#fff;border-bottom:1px dotted #fff;text-decoration:none}.vue-component .badges .badge a.badge-fill{margin:-.35em -.5em;padding:.35em .5em;display:block;border-bottom:0}.vue-component .badges.small .badge a.badge-fill{margin:-.2em -.3em;padding:.25em .35em}.vue-component .badges .badge a:hover{color:#fff;border-bottom-style:solid}.vue-component .badges .default{background-color:#555}.vue-component .badges .green{background-color:green}.vue-component .badges .red{background-color:maroon}.vue-component .badges .option1{background-color:#369}.vue-component .badges .option2{background-color:#693}.vue-component .badges .option3{background-color:#936}.vue-component .badges .option4{background-color:#963}.vue-component .badges .deprecated{background-color:red}.vue-component .badges .experimental{background-color:#8a2be2}.vue-component .badges .action{border:1px solid #000;background-color:#fff;color:#000;margin:.33em;cursor:pointer;text-transform:none}.vue-component .badges .action:hover{background-color:#000;color:#fff}.vue-component .badges .action:hover>a{color:#fff}.vue-component .badges .action>a{color:#000}.vue-component .badges .docker{background-color:#0db7ed}.vue-component .tabular{display:flex;margin:.2em 0;padding:1px}.vue-component .tabular label{flex:1;font-weight:700}.vue-component .tabular .value{flex:3}.vue-component .tabular .value>.formatted>ul,.vue-component .tabular .value>ul,.vue-component .tabular .value td>div,.vue-component .tabular ul.value{max-height:15em;overflow:auto}.vue-component .tabular .value pre{margin:0}.vue-component.stac .map{background:transparent;height:350px}.vue-component.stac .tabular{margin:.5em 0}.vue-component.stac .tabular.wrap{display:block}.vue-component.stac .tabular.wrap .value{margin-top:.5em;margin-left:1em;margin-bottom:.5em}.vue-component.stac .tabular .value ul{padding-left:20px}.assets.empty,.vue-component.stac .links:empty{display:none}.vue-component.stac .thumbnails{overflow-x:auto;overflow-y:hidden;width:100%;white-space:nowrap}.vue-component.stac .thumbnails a{margin:5px;display:inline-block}.vue-component.stac .thumbnails a img{padding:2px;max-height:200px;vertical-align:middle;border:2px solid transparent}.vue-component.stac .thumbnails a:hover img{border:2px solid rgba(0,0,0,.5)}.vue-component .federation>ul>li{margin-bottom:.5em}.vue-component .federation>ul>li>small{display:block}.vue-component .federation>ul>li>h4{margin:0}.vue-component .federation .fed-header{margin:.2em 0}.vue-component .federation .fed-header>.fed-title{display:inline-block;vertical-align:bottom}.vue-component.object-tree .inline{display:inline-block}.vue-component.object-tree ol{padding-left:2em;margin-bottom:.5em}.vue-component.object-tree ol>li:only-child{list-style-type:none;margin-left:-2em}.vue-component.object-tree ol>li>div>ul{padding-left:0}.vue-component.object-tree ul{padding-left:1em}.vue-component.object-tree ul>li{list-style-type:none}.vue-component.object-tree li{margin-bottom:.25em}.dropdown-wrapper{cursor:pointer}.dropdown-wrapper .dropdown-title{display:block;font-size:.9rem;font-family:inherit;cursor:inherit;padding:inherit;line-height:1.4rem;background:transparent;border:none;font-weight:500;color:#2c3e50}.dropdown-wrapper .dropdown-title:hover{border-color:transparent}.dropdown-wrapper .dropdown-title .arrow{vertical-align:middle;margin-top:-1px;margin-left:.4rem}.dropdown-wrapper .nav-dropdown .dropdown-item{color:inherit;line-height:1.7rem}.dropdown-wrapper .nav-dropdown .dropdown-item h4{margin:.45rem 0 0;border-top:1px solid #eee;padding:.45rem 1.5rem 0 1.25rem}.dropdown-wrapper .nav-dropdown .dropdown-item .dropdown-subitem-wrapper{padding:0;list-style:none}.dropdown-wrapper .nav-dropdown .dropdown-item .dropdown-subitem-wrapper .dropdown-subitem{font-size:.9em}.dropdown-wrapper .nav-dropdown .dropdown-item a{display:block;line-height:1.7rem;position:relative;border-bottom:none;font-weight:400;margin-bottom:0;padding:0 1.5rem 0 1.25rem}.dropdown-wrapper .nav-dropdown .dropdown-item a.router-link-active,.dropdown-wrapper .nav-dropdown .dropdown-item a:hover{color:#267cb9}.dropdown-wrapper .nav-dropdown .dropdown-item a.router-link-active:after{content:"";width:0;height:0;border-left:5px solid #267cb9;border-top:3px solid transparent;border-bottom:3px solid transparent;position:absolute;top:calc(50% - 2px);left:9px}.dropdown-wrapper .nav-dropdown .dropdown-item:first-child h4{margin-top:0;padding-top:0;border-top:0}@media (max-width:1024px){.dropdown-wrapper.open .dropdown-title{margin-bottom:.5rem}.dropdown-wrapper .dropdown-title{font-weight:600;font-size:inherit}.dropdown-wrapper .dropdown-title:hover{color:#267cb9}.dropdown-wrapper .nav-dropdown{transition:height .1s ease-out;overflow:hidden}.dropdown-wrapper .nav-dropdown .dropdown-item h4{border-top:0;margin-top:0;padding-top:0}.dropdown-wrapper .nav-dropdown .dropdown-item>a,.dropdown-wrapper .nav-dropdown .dropdown-item h4{font-size:15px;line-height:2rem}.dropdown-wrapper .nav-dropdown .dropdown-item .dropdown-subitem{font-size:14px;padding-left:1rem}}@media (min-width:1024px){.dropdown-wrapper{height:1.8rem}.dropdown-wrapper.open .nav-dropdown,.dropdown-wrapper:hover .nav-dropdown{display:block!important}.dropdown-wrapper.open:blur{display:none}.dropdown-wrapper .dropdown-title .arrow{border-left:4px solid transparent;border-right:4px solid transparent;border-top:6px solid #ccc;border-bottom:0}.dropdown-wrapper .nav-dropdown{display:none;height:auto!important;box-sizing:border-box;max-height:calc(100vh - 2.7rem);overflow-y:auto;position:absolute;top:100%;right:0;background-color:#fff;padding:.6rem 0;border:1px solid;border-color:#ddd #ddd #ccc;text-align:left;border-radius:.25rem;white-space:nowrap;margin:0}}.nav-links{display:inline-block}.nav-links a{line-height:1.4rem;color:inherit}.nav-links a.router-link-active,.nav-links a:hover{color:#267cb9}.nav-links .nav-item{position:relative;display:inline-block;margin-left:1.5rem;line-height:2rem}.nav-links .nav-item:first-child{margin-left:0}@media (min-width:1024px){.nav-links a.router-link-active,.nav-links a:hover{color:#2c3e50}.nav-item>a:not(.external).router-link-active,.nav-item>a:not(.external):hover{margin-bottom:-2px;border-bottom:2px solid #2a89cc}}.navbar{padding:.7rem 1.5rem;line-height:2.2rem}.navbar a,.navbar img,.navbar span{display:inline-block}.navbar .logo{height:2.2rem;min-width:2.2rem;margin-right:.8rem;vertical-align:top}.navbar .site-name{font-size:1.3rem;font-weight:600;color:#2c3e50;position:relative}.navbar .links{padding-left:1.5rem;box-sizing:border-box;background-color:#fff;white-space:nowrap;font-size:.9rem;position:absolute;right:1.5rem;top:.7rem;display:flex}.navbar .links .search-box{flex:0 0 auto;vertical-align:top}@media (max-width:1024px){.navbar{padding-left:4rem}.navbar .can-hide{display:none}.navbar .links{padding-left:1.5rem}.navbar .site-name{width:calc(100vw - 9.4rem);overflow:hidden;white-space:nowrap;text-overflow:ellipsis}}.page-edit{max-width:740px;margin:0 auto;padding:2rem 2.5rem}@media (max-width:1280px){.page-edit{padding:2rem}}@media (max-width:500px){.page-edit{padding:1.5rem}}.page-edit{padding-top:1rem;padding-bottom:1rem;overflow:auto;font-size:.9em}.page-edit .edit-link{display:inline-block;margin-right:1rem}.page-edit .edit-link a{color:#4e6e8e}.page-edit .last-updated{display:inline-block}.page-edit .last-updated .prefix{font-weight:500;color:#4e6e8e}.page-edit .last-updated .time{font-weight:400;color:#aaa}.page-edit .license{margin-top:.5em}@media (max-width:1024px){.page-edit{font-size:.8em}.page-edit .edit-link{margin-bottom:.5rem}.page-edit .last-updated{text-align:left}}.page-nav{max-width:740px;margin:0 auto;padding:2rem 2.5rem}@media (max-width:1280px){.page-nav{padding:2rem}}@media (max-width:500px){.page-nav{padding:1.5rem}}.page-nav{padding-top:1rem;padding-bottom:0}.page-nav .inner{min-height:2rem;margin-top:0;border-top:1px solid #eaecef;padding-top:1rem;overflow:auto}.page-nav .next{float:right}.page{padding-bottom:2rem;display:block}.sidebar-group .sidebar-group{padding-left:.5em}.sidebar-group:not(.collapsable) .sidebar-heading:not(.clickable){cursor:auto;color:inherit}.sidebar-group.is-sub-group{padding-left:0}.sidebar-group.is-sub-group>.sidebar-heading{font-size:.95em;line-height:1.4;font-weight:400;padding-left:2rem}.sidebar-group.is-sub-group>.sidebar-heading:not(.clickable){opacity:.5}.sidebar-group.is-sub-group>.sidebar-group-items{padding-left:1rem}.sidebar-group.is-sub-group>.sidebar-group-items>li>.sidebar-link{font-size:.95em;border-left:none}.sidebar-group.depth-2>.sidebar-heading{border-left:none}.sidebar-heading{color:#2c3e50;transition:color .15s ease;cursor:pointer;font-size:1.1em;font-weight:700;padding:.35rem 1.5rem .35rem 1.25rem;width:100%;box-sizing:border-box;margin:0;border-left:.25rem solid transparent}.sidebar-heading.open,.sidebar-heading:hover{color:inherit}.sidebar-heading .arrow{position:relative;top:-.12em;left:.5em}.sidebar-heading.clickable.active{font-weight:600;color:#267cb9;border-left-color:#267cb9}.sidebar-heading.clickable:hover{color:#267cb9}.sidebar-group-items{transition:height .1s ease-out;font-size:.95em;overflow:hidden}.sidebar .sidebar-sub-headers{padding-left:1rem;font-size:.95em}a.sidebar-link{font-size:1em;font-weight:400;display:inline-block;color:#2c3e50;border-left:.25rem solid transparent;padding:.35rem 1rem .35rem 1.25rem;line-height:1.4;width:100%;box-sizing:border-box}a.sidebar-link:hover{color:#267cb9}a.sidebar-link.active{font-weight:600;color:#267cb9;border-left-color:#267cb9}.sidebar-group a.sidebar-link{padding-left:2rem}.sidebar-sub-headers a.sidebar-link{padding-top:.25rem;padding-bottom:.25rem;border-left:none}.sidebar-sub-headers a.sidebar-link.active{font-weight:500}.sidebar ul{padding:0;margin:0;list-style-type:none}.sidebar a{display:inline-block}.sidebar .nav-links{display:none;border-bottom:1px solid #eaecef;padding:.5rem 0 .75rem}.sidebar .nav-links a{font-weight:600}.sidebar .nav-links .nav-item,.sidebar .nav-links .repo-link{display:block;line-height:1.25rem;font-size:1.1em;padding:.5rem 0 .5rem 1.5rem}.sidebar>.sidebar-links{padding:1.5rem 0}.sidebar>.sidebar-links>li>a.sidebar-link{font-size:1.1em;line-height:1.7;font-weight:700}.sidebar>.sidebar-links>li:not(:first-child){margin-top:.75rem}@media (max-width:1024px){.sidebar .nav-links{display:block}.sidebar .nav-links .dropdown-wrapper .nav-dropdown .dropdown-item a.router-link-active:after{top:calc(1rem - 2px)}.sidebar>.sidebar-links{padding:1rem 0}}@media (min-width:1024px){#docVersionChooser{display:inline-block;z-index:10;position:fixed;top:4.6rem;right:2rem;border-radius:.5em;border:1px solid #eaecef;background-color:#fff;font-size:.9rem}#docVersionChooser button{margin:.3rem .6rem}}@media (max-width:1024px){#docVersionChooser .dropdown-wrapper .dropdown-title:hover{color:#2c3e50}}#docVersionChooser a{color:#2c3e50}#docVersionChooser a:hover{color:#267cb9}.news-meta{margin-bottom:2em;display:block}.fullpage{width:100%;padding-top:3.6rem;height:calc(100vh - 3.6rem);border:0} \ No newline at end of file diff --git a/assets/js/100.d9a1c32c.js b/assets/js/100.563c9377.js similarity index 95% rename from assets/js/100.d9a1c32c.js rename to assets/js/100.563c9377.js index 7729f568a..c906fa53f 100644 --- a/assets/js/100.d9a1c32c.js +++ b/assets/js/100.563c9377.js @@ -1 +1 @@ -(window.webpackJsonp=window.webpackJsonp||[]).push([[100],{549:function(e,t,n){"use strict";n.r(t);var r=n(4),a=Object(r.a)({},(function(){var e=this,t=e._self._c;return t("ContentSlotsDistributor",{attrs:{"slot-key":e.$parent.slotKey}},[t("p",[e._v("Today, the newly established "),t("RouterLink",{attrs:{to:"/psc.html"}},[e._v("openEO Project Steering Committee")]),e._v("\nreleased a new version 1.0.1 of the openEO API. This doesn't include any new\nfunctionality, but clarifies ambiguous parts of the specification and changes\nthe API's recommendation regarding CORS headers to avoid potential security\nissues with credentials in web browsers. Back-ends are advised to check their\nimplementations against the new specification and update the CORS headers\naccordingly. The web clients have already been updated accordingly.")],1),e._v(" "),t("p",[e._v("More details about the release:")]),e._v(" "),t("ul",[t("li",[e._v("Details on the "),t("a",{attrs:{href:"https://github.com/Open-EO/PSC/issues/7",target:"_blank",rel:"noopener noreferrer"}},[e._v("CORS issue"),t("OutboundLink")],1)]),e._v(" "),t("li",[t("a",{attrs:{href:"https://github.com/Open-EO/openeo-api/tree/1.0.1/CHANGELOG.md",target:"_blank",rel:"noopener noreferrer"}},[e._v("Changelog"),t("OutboundLink")],1)]),e._v(" "),t("li",[t("a",{attrs:{href:"https://api.openeo.org/",target:"_blank",rel:"noopener noreferrer"}},[e._v("API documentation"),t("OutboundLink")],1)])])])}),[],!1,null,null,null);t.default=a.exports}}]); \ No newline at end of file +(window.webpackJsonp=window.webpackJsonp||[]).push([[100],{550:function(e,t,n){"use strict";n.r(t);var r=n(4),a=Object(r.a)({},(function(){var e=this,t=e._self._c;return t("ContentSlotsDistributor",{attrs:{"slot-key":e.$parent.slotKey}},[t("p",[e._v("Today, the newly established "),t("RouterLink",{attrs:{to:"/psc.html"}},[e._v("openEO Project Steering Committee")]),e._v("\nreleased a new version 1.0.1 of the openEO API. This doesn't include any new\nfunctionality, but clarifies ambiguous parts of the specification and changes\nthe API's recommendation regarding CORS headers to avoid potential security\nissues with credentials in web browsers. Back-ends are advised to check their\nimplementations against the new specification and update the CORS headers\naccordingly. The web clients have already been updated accordingly.")],1),e._v(" "),t("p",[e._v("More details about the release:")]),e._v(" "),t("ul",[t("li",[e._v("Details on the "),t("a",{attrs:{href:"https://github.com/Open-EO/PSC/issues/7",target:"_blank",rel:"noopener noreferrer"}},[e._v("CORS issue"),t("OutboundLink")],1)]),e._v(" "),t("li",[t("a",{attrs:{href:"https://github.com/Open-EO/openeo-api/tree/1.0.1/CHANGELOG.md",target:"_blank",rel:"noopener noreferrer"}},[e._v("Changelog"),t("OutboundLink")],1)]),e._v(" "),t("li",[t("a",{attrs:{href:"https://api.openeo.org/",target:"_blank",rel:"noopener noreferrer"}},[e._v("API documentation"),t("OutboundLink")],1)])])])}),[],!1,null,null,null);t.default=a.exports}}]); \ No newline at end of file diff --git a/assets/js/101.e97b44c1.js b/assets/js/101.038a234d.js similarity index 96% rename from assets/js/101.e97b44c1.js rename to assets/js/101.038a234d.js index 36167d92d..5cfc62a97 100644 --- a/assets/js/101.e97b44c1.js +++ b/assets/js/101.038a234d.js @@ -1 +1 @@ -(window.webpackJsonp=window.webpackJsonp||[]).push([[101],{552:function(e,t,n){"use strict";n.r(t);var a=n(4),r=Object(a.a)({},(function(){var e=this,t=e._self._c;return t("ContentSlotsDistributor",{attrs:{"slot-key":e.$parent.slotKey}},[t("p",[e._v("Today, we released a new version 1.1.0 of the openEO API.")]),e._v(" "),t("p",[e._v("It features a number of relatively minor, but interesting new features.\nThe OpenID Connect authentication process has been made easier by providing negotiating client IDs automatically.\nJobs, Services, and Logs can provide detailed usage metrics to users\nso that they can monitor memory usage, CPU usage, data transfer, and other metrics.\nFor synchronous processing, a recommendation has been added on how to deliver multiple\nfiles (via TAR archives). Overall, we also aligned better with the STAC specification,\nwhich recently has been released in 1.0.0 release candidate state.\nFor several parts exposed by the API can now be declared to be experimental\nor deprecated.\nFinally, the API specification also clarifies several ambiguous parts of the specification.")]),e._v(" "),t("p",[e._v("Back-ends and clients are advised to check their implementations against the new specification and update accordingly.")]),e._v(" "),t("p",[e._v("More details about the release:")]),e._v(" "),t("ul",[t("li",[t("a",{attrs:{href:"https://github.com/Open-EO/openeo-api/tree/1.1.0/CHANGELOG.md",target:"_blank",rel:"noopener noreferrer"}},[e._v("Changelog"),t("OutboundLink")],1)]),e._v(" "),t("li",[t("a",{attrs:{href:"https://api.openeo.org/",target:"_blank",rel:"noopener noreferrer"}},[e._v("API documentation"),t("OutboundLink")],1)])])])}),[],!1,null,null,null);t.default=r.exports}}]); \ No newline at end of file +(window.webpackJsonp=window.webpackJsonp||[]).push([[101],{551:function(e,t,n){"use strict";n.r(t);var a=n(4),r=Object(a.a)({},(function(){var e=this,t=e._self._c;return t("ContentSlotsDistributor",{attrs:{"slot-key":e.$parent.slotKey}},[t("p",[e._v("Today, we released a new version 1.1.0 of the openEO API.")]),e._v(" "),t("p",[e._v("It features a number of relatively minor, but interesting new features.\nThe OpenID Connect authentication process has been made easier by providing negotiating client IDs automatically.\nJobs, Services, and Logs can provide detailed usage metrics to users\nso that they can monitor memory usage, CPU usage, data transfer, and other metrics.\nFor synchronous processing, a recommendation has been added on how to deliver multiple\nfiles (via TAR archives). Overall, we also aligned better with the STAC specification,\nwhich recently has been released in 1.0.0 release candidate state.\nFor several parts exposed by the API can now be declared to be experimental\nor deprecated.\nFinally, the API specification also clarifies several ambiguous parts of the specification.")]),e._v(" "),t("p",[e._v("Back-ends and clients are advised to check their implementations against the new specification and update accordingly.")]),e._v(" "),t("p",[e._v("More details about the release:")]),e._v(" "),t("ul",[t("li",[t("a",{attrs:{href:"https://github.com/Open-EO/openeo-api/tree/1.1.0/CHANGELOG.md",target:"_blank",rel:"noopener noreferrer"}},[e._v("Changelog"),t("OutboundLink")],1)]),e._v(" "),t("li",[t("a",{attrs:{href:"https://api.openeo.org/",target:"_blank",rel:"noopener noreferrer"}},[e._v("API documentation"),t("OutboundLink")],1)])])])}),[],!1,null,null,null);t.default=r.exports}}]); \ No newline at end of file diff --git a/assets/js/102.0420b8ba.js b/assets/js/102.11f27837.js similarity index 96% rename from assets/js/102.0420b8ba.js rename to assets/js/102.11f27837.js index abe17dbff..0646a2daa 100644 --- a/assets/js/102.0420b8ba.js +++ b/assets/js/102.11f27837.js @@ -1 +1 @@ -(window.webpackJsonp=window.webpackJsonp||[]).push([[102],{551:function(e,t,n){"use strict";n.r(t);var r=n(4),a=Object(r.a)({},(function(){var e=this,t=e._self._c;return t("ContentSlotsDistributor",{attrs:{"slot-key":e.$parent.slotKey}},[t("p",[e._v("Today, we released a new version 1.1.0 of the openEO R Client, which features a couple of "),t("a",{attrs:{href:"https://github.com/Open-EO/openeo-r-client/blob/master/NEWS.md#version-110",target:"_blank",rel:"noopener noreferrer"}},[e._v("improvements and bug fixes"),t("OutboundLink")],1),e._v(".")]),e._v(" "),t("p",[e._v("At the same time, the R client has been published on CRAN, too: "),t("a",{attrs:{href:"https://cran.r-project.org/package=openeo",target:"_blank",rel:"noopener noreferrer"}},[e._v("openeo"),t("OutboundLink")],1),e._v("\nThis means you can now install the R client more easily and directly through CRAN with the following command:")]),e._v(" "),t("div",{staticClass:"language-r extra-class"},[t("pre",{pre:!0,attrs:{class:"language-r"}},[t("code",[e._v("install.packages"),t("span",{pre:!0,attrs:{class:"token punctuation"}},[e._v("(")]),t("span",{pre:!0,attrs:{class:"token string"}},[e._v('"openeo"')]),t("span",{pre:!0,attrs:{class:"token punctuation"}},[e._v(")")]),e._v("\n")])])]),t("p",[e._v("If you have trouble installing or working with the package, feel free to leave an issue in the "),t("a",{attrs:{href:"https://github.com/Open-EO/openeo-r-client/issues",target:"_blank",rel:"noopener noreferrer"}},[e._v("GitHub issue tracker"),t("OutboundLink")],1),e._v(".")])])}),[],!1,null,null,null);t.default=a.exports}}]); \ No newline at end of file +(window.webpackJsonp=window.webpackJsonp||[]).push([[102],{552:function(e,t,n){"use strict";n.r(t);var r=n(4),a=Object(r.a)({},(function(){var e=this,t=e._self._c;return t("ContentSlotsDistributor",{attrs:{"slot-key":e.$parent.slotKey}},[t("p",[e._v("Today, we released a new version 1.1.0 of the openEO R Client, which features a couple of "),t("a",{attrs:{href:"https://github.com/Open-EO/openeo-r-client/blob/master/NEWS.md#version-110",target:"_blank",rel:"noopener noreferrer"}},[e._v("improvements and bug fixes"),t("OutboundLink")],1),e._v(".")]),e._v(" "),t("p",[e._v("At the same time, the R client has been published on CRAN, too: "),t("a",{attrs:{href:"https://cran.r-project.org/package=openeo",target:"_blank",rel:"noopener noreferrer"}},[e._v("openeo"),t("OutboundLink")],1),e._v("\nThis means you can now install the R client more easily and directly through CRAN with the following command:")]),e._v(" "),t("div",{staticClass:"language-r extra-class"},[t("pre",{pre:!0,attrs:{class:"language-r"}},[t("code",[e._v("install.packages"),t("span",{pre:!0,attrs:{class:"token punctuation"}},[e._v("(")]),t("span",{pre:!0,attrs:{class:"token string"}},[e._v('"openeo"')]),t("span",{pre:!0,attrs:{class:"token punctuation"}},[e._v(")")]),e._v("\n")])])]),t("p",[e._v("If you have trouble installing or working with the package, feel free to leave an issue in the "),t("a",{attrs:{href:"https://github.com/Open-EO/openeo-r-client/issues",target:"_blank",rel:"noopener noreferrer"}},[e._v("GitHub issue tracker"),t("OutboundLink")],1),e._v(".")])])}),[],!1,null,null,null);t.default=a.exports}}]); \ No newline at end of file diff --git a/assets/js/107.80c93013.js b/assets/js/107.83d14bd4.js similarity index 96% rename from assets/js/107.80c93013.js rename to assets/js/107.83d14bd4.js index c5558cfcb..335b7d68a 100644 --- a/assets/js/107.80c93013.js +++ b/assets/js/107.83d14bd4.js @@ -1 +1 @@ -(window.webpackJsonp=window.webpackJsonp||[]).push([[107],{559:function(e,o,t){"use strict";t.r(o);var n=t(4),s=Object(n.a)({},(function(){var e=this,o=e._self._c;return o("ContentSlotsDistributor",{attrs:{"slot-key":e.$parent.slotKey}},[o("p",[e._v("The openEO PSC is happy to share that we have submitted openEO to OGC for consideration as an OGC community standard.\nMore specifically, the "),o("a",{attrs:{href:"https://github.com/Open-EO/PSC/blob/main/documents/ogc-submission.adoc",target:"_blank",rel:"noopener noreferrer"}},[e._v("submission document"),o("OutboundLink")],1),e._v(" justifies why the openEO API specification (version 1.2.0) and the openEO process specification (version 1.2.0) are - from our point of view - a good candidate for an OGC community standard.\nWe hope OGC accepts our documents and establishes the corresponding procedures soon.")]),e._v(" "),o("p",[e._v("The members of the openEO PSC voted to submit the justification document to OGC by unanimous consent.\nWe are glad that the following OGC members confirmed to support the OCG submmissin of openEO:")]),e._v(" "),o("ul",[o("li",[e._v("University of Münster - Institute for Geoinformatics")]),e._v(" "),o("li",[e._v("Eurac Research")]),e._v(" "),o("li",[e._v("VITO (Flemish Institute for Technological Research)")]),e._v(" "),o("li",[e._v("GeoConnections - Natural Resources Canada")]),e._v(" "),o("li",[e._v("EUMETSAT")]),e._v(" "),o("li",[e._v("European Space Agency (ESA)")]),e._v(" "),o("li",[e._v("EOX IT Services GmbH")]),e._v(" "),o("li",[e._v("Telespazio VEGA UK Ltd")]),e._v(" "),o("li",[e._v("Planet Labs PBC")]),e._v(" "),o("li",[e._v("German Aerospace Center – DLR")]),e._v(" "),o("li",[e._v("Matthias Mohr - Softwareentwicklung")])]),e._v(" "),o("p",[e._v("We'll keep you updated about the progress. The next step is likely a public request for comments.")])])}),[],!1,null,null,null);o.default=s.exports}}]); \ No newline at end of file +(window.webpackJsonp=window.webpackJsonp||[]).push([[107],{558:function(e,o,t){"use strict";t.r(o);var n=t(4),s=Object(n.a)({},(function(){var e=this,o=e._self._c;return o("ContentSlotsDistributor",{attrs:{"slot-key":e.$parent.slotKey}},[o("p",[e._v("The openEO PSC is happy to share that we have submitted openEO to OGC for consideration as an OGC community standard.\nMore specifically, the "),o("a",{attrs:{href:"https://github.com/Open-EO/PSC/blob/main/documents/ogc-submission.adoc",target:"_blank",rel:"noopener noreferrer"}},[e._v("submission document"),o("OutboundLink")],1),e._v(" justifies why the openEO API specification (version 1.2.0) and the openEO process specification (version 1.2.0) are - from our point of view - a good candidate for an OGC community standard.\nWe hope OGC accepts our documents and establishes the corresponding procedures soon.")]),e._v(" "),o("p",[e._v("The members of the openEO PSC voted to submit the justification document to OGC by unanimous consent.\nWe are glad that the following OGC members confirmed to support the OCG submmissin of openEO:")]),e._v(" "),o("ul",[o("li",[e._v("University of Münster - Institute for Geoinformatics")]),e._v(" "),o("li",[e._v("Eurac Research")]),e._v(" "),o("li",[e._v("VITO (Flemish Institute for Technological Research)")]),e._v(" "),o("li",[e._v("GeoConnections - Natural Resources Canada")]),e._v(" "),o("li",[e._v("EUMETSAT")]),e._v(" "),o("li",[e._v("European Space Agency (ESA)")]),e._v(" "),o("li",[e._v("EOX IT Services GmbH")]),e._v(" "),o("li",[e._v("Telespazio VEGA UK Ltd")]),e._v(" "),o("li",[e._v("Planet Labs PBC")]),e._v(" "),o("li",[e._v("German Aerospace Center – DLR")]),e._v(" "),o("li",[e._v("Matthias Mohr - Softwareentwicklung")])]),e._v(" "),o("p",[e._v("We'll keep you updated about the progress. The next step is likely a public request for comments.")])])}),[],!1,null,null,null);o.default=s.exports}}]); \ No newline at end of file diff --git a/assets/js/108.4ab828dd.js b/assets/js/108.1922640d.js similarity index 94% rename from assets/js/108.4ab828dd.js rename to assets/js/108.1922640d.js index 632ccd9a8..798b5db57 100644 --- a/assets/js/108.4ab828dd.js +++ b/assets/js/108.1922640d.js @@ -1 +1 @@ -(window.webpackJsonp=window.webpackJsonp||[]).push([[108],{560:function(e,t,n){"use strict";n.r(t);var o=n(4),s=Object(o.a)({},(function(){var e=this,t=e._self._c;return t("ContentSlotsDistributor",{attrs:{"slot-key":e.$parent.slotKey}},[t("p",[e._v("After submitting openEO to OGC for consideration as an OGC community standard two months ago,\nOGC now seeks public comment on the potential adoption of openEO as an OGC Community Standard.\nComments are due by February 27, 2024.")]),e._v(" "),t("p",[e._v("For more details, please read the press release that was published today by OGC:\n"),t("strong",[t("a",{attrs:{href:"https://www.ogc.org/requests/ogc-considering-openeo-as-a-community-standard-comment-sought-on-its-adoption/",target:"_blank",rel:"noopener noreferrer"}},[e._v("Request for Comments: OGC considering openEO as a Community Standard; comment sought on its adoption"),t("OutboundLink")],1)])]),e._v(" "),t("p",[e._v("openEO will also be presented at the next OGC member meeting in Delft on Thu, 28 Mar 2024 during the closing planery.")]),e._v(" "),t("p",[e._v("We'll keep you updated about the progress.")])])}),[],!1,null,null,null);t.default=s.exports}}]); \ No newline at end of file +(window.webpackJsonp=window.webpackJsonp||[]).push([[108],{559:function(e,t,n){"use strict";n.r(t);var o=n(4),s=Object(o.a)({},(function(){var e=this,t=e._self._c;return t("ContentSlotsDistributor",{attrs:{"slot-key":e.$parent.slotKey}},[t("p",[e._v("After submitting openEO to OGC for consideration as an OGC community standard two months ago,\nOGC now seeks public comment on the potential adoption of openEO as an OGC Community Standard.\nComments are due by February 27, 2024.")]),e._v(" "),t("p",[e._v("For more details, please read the press release that was published today by OGC:\n"),t("strong",[t("a",{attrs:{href:"https://www.ogc.org/requests/ogc-considering-openeo-as-a-community-standard-comment-sought-on-its-adoption/",target:"_blank",rel:"noopener noreferrer"}},[e._v("Request for Comments: OGC considering openEO as a Community Standard; comment sought on its adoption"),t("OutboundLink")],1)])]),e._v(" "),t("p",[e._v("openEO will also be presented at the next OGC member meeting in Delft on Thu, 28 Mar 2024 during the closing planery.")]),e._v(" "),t("p",[e._v("We'll keep you updated about the progress.")])])}),[],!1,null,null,null);t.default=s.exports}}]); \ No newline at end of file diff --git a/assets/js/109.6b245bde.js b/assets/js/109.5402abca.js similarity index 95% rename from assets/js/109.6b245bde.js rename to assets/js/109.5402abca.js index 117996af6..ab5f4045e 100644 --- a/assets/js/109.6b245bde.js +++ b/assets/js/109.5402abca.js @@ -1 +1 @@ -(window.webpackJsonp=window.webpackJsonp||[]).push([[109],{558:function(e,t,o){"use strict";o.r(t);var s=o(4),n=Object(s.a)({},(function(){var e=this._self._c;return e("ContentSlotsDistributor",{attrs:{"slot-key":this.$parent.slotKey}},[e("p",[this._v("The latest EO college course “Cubes and Clouds” explores the newest concepts in Earth Observation through engaging lectures, videos, animated content, and hands-on exercises!")]),this._v(" "),e("p",[this._v("openEO plays a main role in the course due to its standardized API for homogenizing cloud processing. It allows for portablility of the created workflow between different cloud providers, reproducibility and sharing of the workflow which is enriched with valuable metadata. The idea behind and need for openEO are tought in a dedicated lecture. All hands-on exercises use openEO, guiding participants from basic processes to carrying out end-to-end EO workflows and sharing their results!")]),this._v(" "),e("p",[this._v("You can subscribe to the course for free and learn about cloud native EO at "),e("a",{attrs:{href:"https://eo-college.org/courses/cubes-and-clouds/",target:"_blank",rel:"noopener noreferrer"}},[this._v("Cubes & Clouds – EO College (eo-college.org)"),e("OutboundLink")],1),this._v(".")])])}),[],!1,null,null,null);t.default=n.exports}}]); \ No newline at end of file +(window.webpackJsonp=window.webpackJsonp||[]).push([[109],{561:function(e,t,o){"use strict";o.r(t);var s=o(4),n=Object(s.a)({},(function(){var e=this._self._c;return e("ContentSlotsDistributor",{attrs:{"slot-key":this.$parent.slotKey}},[e("p",[this._v("The latest EO college course “Cubes and Clouds” explores the newest concepts in Earth Observation through engaging lectures, videos, animated content, and hands-on exercises!")]),this._v(" "),e("p",[this._v("openEO plays a main role in the course due to its standardized API for homogenizing cloud processing. It allows for portablility of the created workflow between different cloud providers, reproducibility and sharing of the workflow which is enriched with valuable metadata. The idea behind and need for openEO are tought in a dedicated lecture. All hands-on exercises use openEO, guiding participants from basic processes to carrying out end-to-end EO workflows and sharing their results!")]),this._v(" "),e("p",[this._v("You can subscribe to the course for free and learn about cloud native EO at "),e("a",{attrs:{href:"https://eo-college.org/courses/cubes-and-clouds/",target:"_blank",rel:"noopener noreferrer"}},[this._v("Cubes & Clouds – EO College (eo-college.org)"),e("OutboundLink")],1),this._v(".")])])}),[],!1,null,null,null);t.default=n.exports}}]); \ No newline at end of file diff --git a/assets/js/110.30647715.js b/assets/js/110.35cab91c.js similarity index 85% rename from assets/js/110.30647715.js rename to assets/js/110.35cab91c.js index 67c71e8b1..24500487d 100644 --- a/assets/js/110.30647715.js +++ b/assets/js/110.35cab91c.js @@ -1 +1 @@ -(window.webpackJsonp=window.webpackJsonp||[]).push([[110],{561:function(t,s,e){"use strict";e.r(s);var n=e(4),r=Object(n.a)({},(function(){var t=this._self._c;return t("ContentSlotsDistributor",{attrs:{"slot-key":this.$parent.slotKey}},[t("h1",{attrs:{id:"news"}},[t("a",{staticClass:"header-anchor",attrs:{href:"#news"}},[this._v("#")]),this._v(" News")]),this._v(" "),t("News")],1)}),[],!1,null,null,null);s.default=r.exports}}]); \ No newline at end of file +(window.webpackJsonp=window.webpackJsonp||[]).push([[110],{560:function(t,s,e){"use strict";e.r(s);var n=e(4),r=Object(n.a)({},(function(){var t=this._self._c;return t("ContentSlotsDistributor",{attrs:{"slot-key":this.$parent.slotKey}},[t("h1",{attrs:{id:"news"}},[t("a",{staticClass:"header-anchor",attrs:{href:"#news"}},[this._v("#")]),this._v(" News")]),this._v(" "),t("News")],1)}),[],!1,null,null,null);s.default=r.exports}}]); \ No newline at end of file diff --git a/assets/js/13.e06540fe.js b/assets/js/13.028d555b.js similarity index 95% rename from assets/js/13.e06540fe.js rename to assets/js/13.028d555b.js index 4c8f1b3d8..22d90d9ed 100644 --- a/assets/js/13.e06540fe.js +++ b/assets/js/13.028d555b.js @@ -1 +1 @@ -(window.webpackJsonp=window.webpackJsonp||[]).push([[13],{303:function(e,t,a){e.exports=a.p+"assets/img/dc_timeseries.c2c7a902.png"},304:function(e,t,a){e.exports=a.p+"assets/img/dc_flat.01dc91de.png"},305:function(e,t,a){e.exports=a.p+"assets/img/vector.201588fe.png"},306:function(e,t,a){e.exports=a.p+"assets/img/dc_filter.bdafa6d0.png"},307:function(e,t,a){e.exports=a.p+"assets/img/dc_apply_unary.f69f840c.png"},308:function(e,t,a){e.exports=a.p+"assets/img/dc_apply_kernel.4013a72c.png"},309:function(e,t,a){e.exports=a.p+"assets/img/dc_apply_ts.4f9449f6.png"},310:function(e,t,a){e.exports=a.p+"assets/img/dc_apply_dim_ts.c895aa81.png"},311:function(e,t,a){e.exports=a.p+"assets/img/dc_resample_time.987e797c.png"},312:function(e,t,a){e.exports=a.p+"assets/img/dc_resample_space.417f814b.png"},313:function(e,t,a){e.exports=a.p+"assets/img/dc_reduce.872f16c2.png"},314:function(e,t,a){e.exports=a.p+"assets/img/dc_aggregate_space.ae550945.png"},512:function(e,t,a){"use strict";a.r(t);var s=a(4),i=Object(s.a)({},(function(){var e=this,t=e._self._c;return t("ContentSlotsDistributor",{attrs:{"slot-key":e.$parent.slotKey}},[t("h1",{attrs:{id:"datacubes"}},[t("a",{staticClass:"header-anchor",attrs:{href:"#datacubes"}},[e._v("#")]),e._v(" Datacubes")]),e._v(" "),t("h2",{attrs:{id:"what-are-datacubes"}},[t("a",{staticClass:"header-anchor",attrs:{href:"#what-are-datacubes"}},[e._v("#")]),e._v(" What are Datacubes?")]),e._v(" "),t("p",[e._v("Data is represented as datacubes in openEO, which are multi-dimensional arrays with additional information about their dimensionality. Datacubes can provide a nice and tidy interface for spatiotemporal data as well as for the operations you may want to execute on them. As they are arrays, it might be easiest to look at raster data as an example, even though datacubes can hold vector data as well. Our example data however consists of a 6x7 raster with 4 bands ["),t("code",[e._v("blue")]),e._v(", "),t("code",[e._v("green")]),e._v(", "),t("code",[e._v("red")]),e._v(", "),t("code",[e._v("near-infrared")]),e._v("] and 3 timesteps ["),t("code",[e._v("2020-10-01")]),e._v(", "),t("code",[e._v("2020-10-13")]),e._v(", "),t("code",[e._v("2020-10-25")]),e._v("], displayed here in an orderly, timeseries-like manner:")]),e._v(" "),t("figure",[t("img",{attrs:{src:a(303),alt:"Raster datacube timeseries: 12 imagery tiles are depicted, grouped by 3 dates along a timeline (time dimension). Each date has a blue, green, red and near-infrared band (bands dimension). Each single tile has the dimensions x and y (spatial dimensions)."}}),e._v(" "),t("figcaption",[e._v("An examplary raster datacube with 4 dimensions: x, y, bands and time.")])]),e._v(" "),t("p",[e._v("It is important to understand that datacubes are designed to make things easier for us, and are not literally a cube, meaning that the above plot is just as good a representation as any other. That is why we can switch the dimensions around and display them in whatever way we want, including the view below:")]),e._v(" "),t("figure",[t("img",{attrs:{src:a(304),alt:"Raster datacube flat representation: The 12 imagery tiles are now laid out flat as a 4 by 3 grid (bands by timesteps). All dimension labels are depicted (The timestamps, the band names and the x, y coordinates)."}}),e._v(" "),t("figcaption",[e._v("This is the 'raw' data collection that is our example datacube. The grayscale images are colored for understandability, and dimension labels are displayed.")])]),e._v(" "),t("p",[e._v("A vector datacube on the other hand could look like this:")]),e._v(" "),t("figure",[t("img",{attrs:{src:a(305),alt:"An examplary vector datacube with 3 dimensions: 2 geometries are given for the `geometries` dimension, along with 3 timesteps for the temporal dimension `time` and 4 bands in the `bands` dimension."}}),e._v(" "),t("figcaption",[e._v("An examplary vector datacube with 3 dimensions: 2 geometries are given for the "),t("code",[e._v("geometries")]),e._v(" dimension, along with 3 timesteps for the temporal dimension "),t("code",[e._v("time")]),e._v(" and 4 bands in the "),t("code",[e._v("bands")]),e._v(" dimension.")])]),e._v(" "),t("p",[t("a",{attrs:{href:"https://r-spatial.org/r/2022/09/12/vdc.html",target:"_blank",rel:"noopener noreferrer"}},[e._v("Vector datacubes"),t("OutboundLink")],1),e._v(" and raster datacubes are common cases of datacubes in the EO domain.\nA raster datacube has at least two spatial dimensions (usually named "),t("code",[e._v("x")]),e._v(" and "),t("code",[e._v("y")]),e._v(") and a vector datacube has at least one geometry dimension (usually named "),t("code",[e._v("geometry")]),e._v(').\nThe purpose of these distinctions is simply to make it easier to describe "special" cases of datacubes, but you can also define other types such as a temporal datacube that has at least one temporal dimension (usually named '),t("code",[e._v("t")]),e._v(").")]),e._v(" "),t("p",[e._v("The following additional information are usually available for datacubes:")]),e._v(" "),t("ul",[t("li",[e._v("the dimensions (see "),t("a",{attrs:{href:"#dimensions"}},[e._v("below")]),e._v(")")]),e._v(" "),t("li",[e._v("a sampling method (see "),t("a",{attrs:{href:"#values-in-a-datacube"}},[e._v("below")]),e._v(")")]),e._v(" "),t("li",[e._v("a unit for the values")])]),e._v(" "),t("p",[e._v("All these information are usually provided through the datacube metadata.")]),e._v(" "),t("h2",{attrs:{id:"dimensions"}},[t("a",{staticClass:"header-anchor",attrs:{href:"#dimensions"}},[e._v("#")]),e._v(" Dimensions")]),e._v(" "),t("p",[e._v("A dimension refers to a certain axis of a datacube. This includes all variables (e.g. bands), which are represented as dimensions. Our exemplary raster datacube has the spatial dimensions "),t("code",[e._v("x")]),e._v(" and "),t("code",[e._v("y")]),e._v(", and the temporal dimension "),t("code",[e._v("t")]),e._v(". Furthermore, it has a "),t("code",[e._v("bands")]),e._v(" dimension, extending into the realm of "),t("em",[e._v("what kind of information")]),e._v(" is contained in the cube.")]),e._v(" "),t("p",[e._v("The following properties are usually available for dimensions:")]),e._v(" "),t("ul",[t("li",[e._v("name")]),e._v(" "),t("li",[e._v("type (potential types include: spatial (raster or vector data), temporal and other data such as bands)")]),e._v(" "),t("li",[e._v("axis (for spatial dimensions) / number")]),e._v(" "),t("li",[e._v("labels (usually exposed through textual or numerical representations, in the metadata as nominal values and/or extents)")]),e._v(" "),t("li",[e._v("reference system / projection")]),e._v(" "),t("li",[e._v("resolution / step size")]),e._v(" "),t("li",[e._v("unit for the labels (either explicitly specified or implicitly provided by the reference system)")]),e._v(" "),t("li",[e._v("additional information specific to the dimension type (e.g. the geometry types for a dimension containing geometries)")])]),e._v(" "),t("p",[e._v("All these information are usually provided through the datacube metadata.")]),e._v(" "),t("p",[e._v("Here is an overview of the dimensions contained in our example raster datacube above:")]),e._v(" "),t("table",[t("thead",[t("tr",[t("th",[e._v("#")]),e._v(" "),t("th",[e._v("name")]),e._v(" "),t("th",[e._v("type")]),e._v(" "),t("th",[e._v("labels")]),e._v(" "),t("th",[e._v("resolution")]),e._v(" "),t("th",[e._v("reference system")])])]),e._v(" "),t("tbody",[t("tr",[t("td",[e._v("1")]),e._v(" "),t("td",[t("code",[e._v("x")])]),e._v(" "),t("td",[e._v("spatial")]),e._v(" "),t("td",[t("code",[e._v("466380")]),e._v(", "),t("code",[e._v("466580")]),e._v(", "),t("code",[e._v("466780")]),e._v(", "),t("code",[e._v("466980")]),e._v(", "),t("code",[e._v("467180")]),e._v(", "),t("code",[e._v("467380")])]),e._v(" "),t("td",[e._v("200m")]),e._v(" "),t("td",[t("a",{attrs:{href:"https://epsg.io/32627",target:"_blank",rel:"noopener noreferrer"}},[e._v("EPSG:32627"),t("OutboundLink")],1)])]),e._v(" "),t("tr",[t("td",[e._v("2")]),e._v(" "),t("td",[t("code",[e._v("y")])]),e._v(" "),t("td",[e._v("spatial")]),e._v(" "),t("td",[t("code",[e._v("7167130")]),e._v(", "),t("code",[e._v("7166930")]),e._v(", "),t("code",[e._v("7166730")]),e._v(", "),t("code",[e._v("7166530")]),e._v(", "),t("code",[e._v("7166330")]),e._v(", "),t("code",[e._v("7166130")]),e._v(", "),t("code",[e._v("7165930")])]),e._v(" "),t("td",[e._v("200m")]),e._v(" "),t("td",[t("a",{attrs:{href:"https://epsg.io/32627",target:"_blank",rel:"noopener noreferrer"}},[e._v("EPSG:32627"),t("OutboundLink")],1)])]),e._v(" "),t("tr",[t("td",[e._v("3")]),e._v(" "),t("td",[t("code",[e._v("bands")])]),e._v(" "),t("td",[e._v("bands")]),e._v(" "),t("td",[t("code",[e._v("blue")]),e._v(", "),t("code",[e._v("green")]),e._v(", "),t("code",[e._v("red")]),e._v(", "),t("code",[e._v("nir")])]),e._v(" "),t("td",[e._v("4 bands")]),e._v(" "),t("td",[e._v("-")])]),e._v(" "),t("tr",[t("td",[e._v("4")]),e._v(" "),t("td",[t("code",[e._v("t")])]),e._v(" "),t("td",[e._v("temporal")]),e._v(" "),t("td",[t("code",[e._v("2020-10-01")]),e._v(", "),t("code",[e._v("2020-10-13")]),e._v(", "),t("code",[e._v("2020-10-25")])]),e._v(" "),t("td",[e._v("12 days")]),e._v(" "),t("td",[e._v("Gregorian calendar / UTC")])])])]),e._v(" "),t("p",[e._v('Dimension labels are usually either numerical or text (also known as "strings"), which also includes textual representations of timestamps or geometries for example.\nFor example, temporal labels are usually encoded as '),t("a",{attrs:{href:"https://en.wikipedia.org/wiki/ISO_8601",target:"_blank",rel:"noopener noreferrer"}},[e._v("ISO 8601"),t("OutboundLink")],1),e._v(" compatible dates and/or times and similarly geometries can be encoded as "),t("a",{attrs:{href:"https://en.wikipedia.org/wiki/Well-known_text_representation_of_geometry",target:"_blank",rel:"noopener noreferrer"}},[e._v("Well-known Text (WKT)"),t("OutboundLink")],1),e._v(" or be represented by their IDs.")]),e._v(" "),t("p",[e._v("Dimensions with a natural/inherent order (usually all temporal and spatial raster dimensions) are always sorted. Dimensions without inherent order (usually "),t("code",[e._v("bands")]),e._v("), retain the order in which they have been defined in metadata or processes (e.g. through "),t("a",{attrs:{href:"https://processes.openeo.org/#filter_bands",target:"_blank",rel:"noopener noreferrer"}},[t("code",[e._v("filter_bands")]),t("OutboundLink")],1),e._v("), with new labels simply being appended to the existing labels.")]),e._v(" "),t("p",[e._v("A geometry dimension is not included in the example raster datacube above and it is not used in the following examples, but to show how a vector dimension with two polygons could look like:")]),e._v(" "),t("table",[t("thead",[t("tr",[t("th",[e._v("name")]),e._v(" "),t("th",[e._v("type")]),e._v(" "),t("th",[e._v("labels")]),e._v(" "),t("th",[e._v("reference system")])])]),e._v(" "),t("tbody",[t("tr",[t("td",[t("code",[e._v("geometry")])]),e._v(" "),t("td",[e._v("vector")]),e._v(" "),t("td",[t("code",[e._v("POLYGON((-122.4 37.6,-122.35 37.6,-122.35 37.64,-122.4 37.64,-122.4 37.6))")]),e._v(", "),t("code",[e._v("POLYGON((-122.51 37.5,-122.48 37.5,-122.48 37.52,-122.51 37.52,-122.51 37.5))")])]),e._v(" "),t("td",[t("a",{attrs:{href:"https://epsg.io/4326",target:"_blank",rel:"noopener noreferrer"}},[e._v("EPSG:4326"),t("OutboundLink")],1)])])])]),e._v(" "),t("p",[e._v("A dimension with geometries can consist of points, linestrings, polygons, multi points, multi linestrings, or multi polygons.\nIt is not possible to mix geometry types, but the single geometry type with their corresponding multi type can be combined in a dimension (e.g. points and multi points).\nEmpty geometries (such as GeoJSON features with a "),t("code",[e._v("null")]),e._v(" geometry or GeoJSON geometries with an empty coordinates array) are allowed and can sometimes also be the result of certain vector operations such as a negative buffer.")]),e._v(" "),t("h3",{attrs:{id:"applying-processes-on-dimensions"}},[t("a",{staticClass:"header-anchor",attrs:{href:"#applying-processes-on-dimensions"}},[e._v("#")]),e._v(" Applying Processes on Dimensions")]),e._v(" "),t("p",[e._v('Some processes are typically applied "along a dimension". You can imagine said dimension as an arrow and whatever is happening as a parallel process to that arrow. It simply means: "we focus on '),t("em",[e._v("this")]),e._v(' dimension right now".')]),e._v(" "),t("h3",{attrs:{id:"resolution"}},[t("a",{staticClass:"header-anchor",attrs:{href:"#resolution"}},[e._v("#")]),e._v(" Resolution")]),e._v(" "),t("p",[e._v("The resolution of a dimension gives information about what interval lies between observations. This is most obvious with the temporal resolution, where the intervals depict how often observations were made. Spatial resolution gives information about the pixel spacing, meaning how many 'real world meters' are contained in a pixel. The number of bands and their wavelength intervals give information about the spectral resolution.")]),e._v(" "),t("h3",{attrs:{id:"coordinate-reference-system-as-a-dimension"}},[t("a",{staticClass:"header-anchor",attrs:{href:"#coordinate-reference-system-as-a-dimension"}},[e._v("#")]),e._v(" Coordinate Reference System as a Dimension")]),e._v(" "),t("p",[e._v("In the example above, "),t("em",[e._v("x")]),e._v(" and "),t("em",[e._v("y")]),e._v(" dimension values have a "),t("em",[e._v("unique")]),e._v(" relationship to world coordinates through their coordinate reference system (CRS). This implies that a single coordinate reference system is associated with these "),t("em",[e._v("x")]),e._v(" and "),t("em",[e._v("y")]),e._v(" dimensions. If we want to create a data cube from multiple tiles spanning different coordinate reference systems (e.g. Sentinel-2: different UTM zones), we would "),t("em",[e._v("have")]),e._v(" to resample/warp those to a single coordinate reference system. In many cases, this is wanted because we want to be able to "),t("em",[e._v("look")]),e._v(" at the result, meaning it is available in a single coordinate reference system.")]),e._v(" "),t("p",[e._v("Resampling is however costly, involves (some) data loss, and is in general not reversible. Suppose that we want to work only on the spectral and temporal dimensions of a data cube, and do not want to do any resampling. In that case, one could create one data cube for each coordinate reference system. An alternative would be to create one "),t("em",[e._v("single")]),e._v(" data cube containing all tiles that has an "),t("em",[e._v("additional dimension")]),e._v(" with the coordinate reference system. In that data cube, "),t("em",[e._v("x")]),e._v(" and "),t("em",[e._v("y")]),e._v(" no longer point to a unique world coordinate, because identical "),t("em",[e._v("x")]),e._v(" and "),t("em",[e._v("y")]),e._v(" coordinate pairs occur in each UTM zone. Now, only the combination ("),t("em",[e._v("x")]),e._v(", "),t("em",[e._v("y")]),e._v(", "),t("em",[e._v("crs")]),e._v(") has a unique relationship to the world coordinates.")]),e._v(" "),t("p",[e._v("On such a "),t("em",[e._v("crs-dimensioned data cube")]),e._v(", several operations make perfect sense, such as "),t("code",[e._v("apply")]),e._v(" or "),t("code",[e._v("reduce_dimension")]),e._v(" on spectral and/or temporal dimensions. A simple reduction over the "),t("code",[e._v("crs")]),e._v(" dimension, using "),t("em",[e._v("sum")]),e._v(" or "),t("em",[e._v("mean")]),e._v(' would typically not make sense. The "reduction" (removal) of the '),t("code",[e._v("crs")]),e._v(" dimension that is meaningful involves the resampling/warping of all sub-cubes for the "),t("code",[e._v("crs")]),e._v(" dimension to a single, common target coordinate reference system.")]),e._v(" "),t("h2",{attrs:{id:"values-in-a-datacube"}},[t("a",{staticClass:"header-anchor",attrs:{href:"#values-in-a-datacube"}},[e._v("#")]),e._v(" Values in a datacube")]),e._v(" "),t("p",[e._v("openEO datacubes contain scalar values (e.g. strings, numbers or boolean values), with all other associated attributes stored in dimensions (e.g. coordinates or timestamps). Attributes such as the CRS or the sensor can also be turned into dimensions. Be advised that in such a case, the uniqueness of pixel coordinates may be affected. When usually, "),t("code",[e._v("(x, y)")]),e._v(" refers to a unique location, that changes to "),t("code",[e._v("(x, y, CRS)")]),e._v(" when "),t("code",[e._v("(x, y)")]),e._v(" values are reused in other coordinate reference systems (e.g. two neighboring UTM zones).")]),e._v(" "),t("div",{staticClass:"custom-block tip"},[t("p",{staticClass:"custom-block-title"},[e._v("Be Careful with Data Types")]),e._v(" "),t("p",[e._v("As stated above, datacubes only contain scalar values. However, implementations may differ in their ability to handle or convert them. Implementations may also not allow mixing data types in a datacube. For example, returning a boolean value for a reducer on a numerical datacube may result in an error on some back-ends. The recommendation is to not change the data type of values in a datacube unless the back-end supports it explicitly.")])]),e._v(" "),t("p",[e._v("Data cube values can be sampled in two different ways. The values are either area or point samples.")]),e._v(" "),t("ul",[t("li",[e._v("Area sampling aggregates measurements over defined regions, i.e. the grid cells for raster data or polygons/lines for vector data.")]),e._v(" "),t("li",[e._v("Point sampling collects data at specific locations, providing detailed information for specific points.")])]),e._v(" "),t("h2",{attrs:{id:"processes-on-datacubes"}},[t("a",{staticClass:"header-anchor",attrs:{href:"#processes-on-datacubes"}},[e._v("#")]),e._v(" Processes on Datacubes")]),e._v(" "),t("p",[e._v("In the following part, the basic processes for manipulating datacubes are introduced.")]),e._v(" "),t("h3",{attrs:{id:"filter"}},[t("a",{staticClass:"header-anchor",attrs:{href:"#filter"}},[e._v("#")]),e._v(" Filter")]),e._v(" "),t("p",[e._v("When filtering data (e.g. "),t("a",{attrs:{href:"https://processes.openeo.org/#filter_spatial",target:"_blank",rel:"noopener noreferrer"}},[t("code",[e._v("filter_spatial")]),t("OutboundLink")],1),e._v(", "),t("a",{attrs:{href:"https://processes.openeo.org/#filter_temporal",target:"_blank",rel:"noopener noreferrer"}},[t("code",[e._v("filter_temporal")]),t("OutboundLink")],1),e._v(", "),t("a",{attrs:{href:"https://processes.openeo.org/#filter_bands",target:"_blank",rel:"noopener noreferrer"}},[t("code",[e._v("filter_bands")]),t("OutboundLink")],1),e._v("), only the data that satisfies a condition is returned. For example, this condition could be a timestamp or interval, (a set of) coordinates, or specific bands. By applying filtering the datacube becomes smaller, according to the selected data.")]),e._v(" "),t("div",{staticClass:"custom-block tip"},[t("p",{staticClass:"custom-block-title"},[e._v("Simplified")]),e._v(" "),t("p",[t("span",{attrs:{title:"Filtering vegetarian options from [corn, potato, pig] returns [corn, potato].\n"}},[t("code",[e._v("filter([🌽, 🥔, 🐷], isVegetarian) => [🌽, 🥔]")])])])]),e._v(" "),t("p",[e._v("In the image, the example datacube can be seen at the top with labeled dimensions. The filtering techniques are displayed separately below. On the left, the datacube is filtered temporally with the interval "),t("code",[e._v('["2020-10-15", "2020-10-27"]')]),e._v(". The result is a cube with only the rasters for the timestep that lies within that interval ("),t("code",[e._v('"2020-10-25"')]),e._v(") and unchanged bands and spatial dimensions. Likewise, the original cube is filtered for a specific band "),t("code",[e._v('["nir"]')]),e._v(" in the middle and a specific spatial region "),t("code",[e._v("[Polygon(...)]")]),e._v(" on the right.")]),e._v(" "),t("figure",[t("img",{attrs:{src:a(306),alt:"Datacube filtering: From the datacube 4 by 3 grid, arrows depict what happens if the grid is filtered. Temporal filtering results in data for one timestep with all four bands, filtering bands results in data with one band with all three timesteps, and spatial filtering results in all timesteps and bands being preserved, but all with a smaller area."}}),e._v(" "),t("figcaption",[e._v("Filtering the sample datacube. It is displayed at the top with dimensions labels. Filtered results are shown at the bottom.")])]),e._v(" "),t("h3",{attrs:{id:"apply"}},[t("a",{staticClass:"header-anchor",attrs:{href:"#apply"}},[e._v("#")]),e._v(" Apply")]),e._v(" "),t("p",[e._v("The "),t("code",[e._v("apply*")]),e._v(" functions (e.g. "),t("a",{attrs:{href:"https://processes.openeo.org/#apply",target:"_blank",rel:"noopener noreferrer"}},[t("code",[e._v("apply")]),t("OutboundLink")],1),e._v(", "),t("a",{attrs:{href:"https://processes.openeo.org/#apply_neighborhood",target:"_blank",rel:"noopener noreferrer"}},[t("code",[e._v("apply_neighborhood")]),t("OutboundLink")],1),e._v(", "),t("a",{attrs:{href:"https://processes.openeo.org/#apply_dimension",target:"_blank",rel:"noopener noreferrer"}},[t("code",[e._v("apply_dimension")]),t("OutboundLink")],1),e._v(") employ a process on the datacube that calculates new pixel values for each pixel, based on "),t("code",[e._v("n")]),e._v(" other pixels. Please note that several programming languages use the name "),t("code",[e._v("map")]),e._v(" instead of "),t("code",[e._v("apply")]),e._v(", but they describe the same type of function.")]),e._v(" "),t("div",{staticClass:"custom-block tip"},[t("p",{staticClass:"custom-block-title"},[e._v("Simplified")]),e._v(" "),t("p",[t("span",{attrs:{title:"Applying the process 'cook' to [corn, potato, pig] returns [popcorn, fries, meat]."}},[t("code",[e._v("apply([🌽, 🥔, 🐷], cook) => [🍿, 🍟, 🍖]")])])])]),e._v(" "),t("p",[e._v("For the case "),t("code",[e._v("n = 1")]),e._v(" this is called a unary function and means that only the pixel itself is considered when calculating the new pixel value. A prominent example is the "),t("code",[e._v("absolute()")]),e._v(" function, calculating the absolute value of the input pixel value.")]),e._v(" "),t("figure",[t("img",{attrs:{src:a(307),alt:"Datacube apply unary: 3 example tiles hold values below and above 0. after applying the process 'absolute', all values in the three example tiles have changed to their absolute values above 0."}}),e._v(" "),t("figcaption",[e._v("Applying an unary process. Only the pixel itself is considered for calculating the new pixel value.")])]),e._v(" "),t("p",[e._v("If "),t("code",[e._v("n")]),e._v(" is larger than 1, the function is called n-ary. In practice, this means that the pixel neighbourhood is taken into account to calculate the new pixel value. Such neighbourhoods can be of spatial and/or temporal nature. A spatial function works on a kernel that weights the surrounding pixels (e.g. smoothing values with nearby observations), a temporal function works on a time series at a certain pixel location (e.g. smoothing values over time). Combinations of types to n-dimensional neighbourhoods are also possible.")]),e._v(" "),t("p",[e._v("In the example below, an example weighted kernel (shown in the middle) is applied to the cube (via "),t("a",{attrs:{href:"https://processes.openeo.org/#apply_kernel",target:"_blank",rel:"noopener noreferrer"}},[t("code",[e._v("apply_kernel")]),t("OutboundLink")],1),e._v("). To avoid edge effects (affecting pixels on the edge of the image with less neighbours), a padding has been added in the background.")]),e._v(" "),t("figure",[t("img",{attrs:{src:a(308),alt:"Datacube apply spatial kernel: Three example tiles hold some values with a lot of variance. A spatial kernel (a cell plus it's 4 direct neighbours) is applied to all pixels, and the result appears to be spatially smoothed, with less variance."}}),e._v(" "),t("figcaption",[e._v("Applying a spatial kernel. For calculating each new pixel value, the defined weighted neighbourhood is used.")])]),e._v(" "),t("p",[e._v("Of course this also works for temporal neighbourhoods (timeseries), considering neighbours before and after a pixel. To be able to show the effect, two timesteps were added in this example figure. A moving average of window size 3 is then applied, meaning that for each pixel the average is calculated out of the previous, the next, and the timestep in question (t"),t("sub",[e._v("n-1")]),e._v(", t"),t("sub",[e._v("n")]),e._v(" and t"),t("sub",[e._v("n+1")]),e._v("). No padding was added which is why we observe edge effects (NA values are returned for t"),t("sub",[e._v("1")]),e._v(" and t"),t("sub",[e._v("5")]),e._v(", because their temporal neighbourhood is missing input timesteps).")]),e._v(" "),t("figure",[t("img",{attrs:{src:a(309),alt:"Datacube apply temporal moving average: Smoothing is applied to 5 example tiles by calculating the mean of 3 timesteps of every single pixel. The resulting tiles for the timestamps look much more alike."}}),e._v(" "),t("figcaption",[e._v("Applying a moving average (temporal smoothing) by averaging the direct temporal neighbourhoods of pixels. No padding is used, which leads to edge effects.")])]),e._v(" "),t("p",[e._v("Alternatively, a process can also be applied along a dimension of the datacube, meaning the input is no longer a neighbourhood of some sort but all pixels along that dimension ("),t("code",[e._v("n")]),e._v(" equals the complete dimension). If a process is applied along the "),t("code",[e._v("time")]),e._v(" dimension (e.g. a breakpoint detection), the complete pixel timeseries are the input. If a process is applied along the "),t("code",[e._v("spatial")]),e._v(" dimensions (e.g. a "),t("code",[e._v("mean")]),e._v("), all pixels of an image are the input. The process is then applied to all pixels along that dimension and the dimension continues to exist. This is in contrast to "),t("a",{attrs:{href:"#reduce"}},[e._v("reduce")]),e._v(". In the image below, a "),t("code",[e._v("mean")]),e._v(" is applied to the "),t("code",[e._v("time")]),e._v(" dimension. An example pixel timeseries is highlighted by a green line and processed step-by-step.")]),e._v(" "),t("figure",[t("img",{attrs:{src:a(310),alt:"Datacube apply dimension time: The mean of all 5 timesteps is calculated for every single pixel. The resulting 5 tiles look exaclty the same, as they have been averaged."}}),e._v(" "),t("figcaption",[e._v("Applying a mean to the temporal dimension.")])]),e._v(" "),t("h3",{attrs:{id:"resample"}},[t("a",{staticClass:"header-anchor",attrs:{href:"#resample"}},[e._v("#")]),e._v(" Resample")]),e._v(" "),t("p",[e._v("In a resampling processes (e.g. "),t("a",{attrs:{href:"https://processes.openeo.org/#resample_cube_spatial",target:"_blank",rel:"noopener noreferrer"}},[t("code",[e._v("resample_cube_spatial")]),t("OutboundLink")],1),e._v(", "),t("a",{attrs:{href:"https://processes.openeo.org/#resample_cube_temporal",target:"_blank",rel:"noopener noreferrer"}},[t("code",[e._v("resample_cube_temporal")]),t("OutboundLink")],1),e._v("), the "),t("em",[e._v("layout")]),e._v(" of a certain dimension is changed into another "),t("em",[e._v("layout")]),e._v(", most likely also changing the resolution of that dimension. This is done by mapping values of the source (old) datacube to the new layout of the target (new) datacube. During that process, resolutions can be "),t("em",[e._v("upscaled")]),e._v(" or "),t("em",[e._v("downscaled")]),e._v(" (also called "),t("em",[e._v("upsampling")]),e._v(" and "),t("em",[e._v("downsampling")]),e._v("), depending on whether they have a finer or a coarser spacing afterwards. A function is then needed to translate the existing data into the new resolution. A prominent example is to reproject a datacube into the coordinate reference system of another datacube, for example in order to merge the two cubes.")]),e._v(" "),t("div",{staticClass:"custom-block tip"},[t("p",{staticClass:"custom-block-title"},[e._v("Simplified")]),e._v(" "),t("p",[t("span",{attrs:{title:"Downscaling a raster image (to infinity) returns one pixel."}},[t("code",[e._v("resample(🖼️, downscale) => 🟦")])])]),e._v(" "),t("p",[t("span",{attrs:{title:"Reprojecting a globe results into a map."}},[t("code",[e._v("resample(🌍, reproject) => 🗺️")])])])]),e._v(" "),t("p",[e._v("The first figure gives an overview of temporal resampling. How exactly the input timesteps are rescaled to the output timesteps depends on the resampling function.")]),e._v(" "),t("figure",[t("img",{attrs:{src:a(311),alt:"Datacube temporal resampling (up and down): Downsampling: To a timeline-representation of the example tiles, another timeline with only 2 steps at different dates is applied. The result has tiles only at those new timesteps. In Upsampling, the existing 3 timesteps are sampled into 5 result timesteps."}}),e._v(" "),t("figcaption",[e._v("Temporal downsampling is seen on the left, upsampling on the right. The temporal layout that the cubes are resampled to is displayed in the middle.")])]),e._v(" "),t("p",[e._v("The second figure displays spatial resampling. Observe how in the upsampling process, the output datacube has not gained in information value. The resulting grid still carries the same pixel information, but in higher spatial resolution. Other upsampling methods may yield smoother results, e.g. by using interpolation.")]),e._v(" "),t("figure",[t("img",{attrs:{src:a(312),alt:"Datacube spatial resampling (up and down): Downsampling: The resulting tiles have a lower spatial resolution than the input tiles. Upsampling: The resulting tiles have a higher spatial resolution than the input tiles, but contain the same image than before (no information added)."}}),e._v(" "),t("figcaption",[e._v("Spatial resampling. The geometry which the input cube is resampled to is displayed in the middle. The output cube then contains the same information, but in the resampled spatial layout.")])]),e._v(" "),t("h3",{attrs:{id:"reduce"}},[t("a",{staticClass:"header-anchor",attrs:{href:"#reduce"}},[e._v("#")]),e._v(" Reduce")]),e._v(" "),t("p",[e._v("The "),t("a",{attrs:{href:"https://processes.openeo.org/#reduce_dimension",target:"_blank",rel:"noopener noreferrer"}},[t("code",[e._v("reduce_dimension")]),t("OutboundLink")],1),e._v(" process "),t("em",[e._v("collapses")]),e._v(" a whole dimension of the datacube. It does so by using some sort of "),t("strong",[e._v("reducer")]),e._v(", which is a function that calculates a single result from an amount of values, as e.g. "),t("code",[e._v("mean()")]),e._v(", "),t("code",[e._v("min()")]),e._v(" and "),t("code",[e._v("max()")]),e._v(" are. For example we can reduce the time dimension ("),t("code",[e._v("t")]),e._v(") of a timeseries by calculating the mean value of all timesteps for each pixel. We are left with a cube that has no time dimension, because all values of that dimension are compressed into a single mean value. The same goes for e.g. the spatial dimensions: If we calculate the mean along the "),t("code",[e._v("x")]),e._v(" and "),t("code",[e._v("y")]),e._v(" dimensions, we are left without any spatial dimensions, but a mean value for each instance that previously was a raster is returned. In the image below, the dimensions that are reduced are crossed out in the result.")]),e._v(" "),t("div",{staticClass:"custom-block tip"},[t("p",{staticClass:"custom-block-title"},[e._v("Simplified")]),e._v(" "),t("p",[t("span",{attrs:{title:"Reducing [mixed greens, cucumber, tomato, onion] returns a salad."}},[t("code",[e._v("reduce([🥬, 🥒, 🍅, 🧅], prepare) => 🥗")])])])]),e._v(" "),t("p",[e._v("Think of it as a waste press that does math instead of using brute force. Given a representation of our example datacube, let's see how it is affected.")]),e._v(" "),t("figure",[t("img",{attrs:{src:a(313),alt:"Datacube reduce: Three arrows depict what happens to the 12 example tiles, if they are reduced: Reducing timesteps leads to four tiles (one for each band), and the time dimension is deleted. Reducing bands lead to one tile per timestep, and the bands dimension is deleted. Reducing spatially leads to the original 4 by 3 bands by time layout, but the result has no spatial dimension and thus, the tiles have been turned into single values, per tile."}}),e._v(" "),t("figcaption",[e._v("Overview of reducing the sample datacube. Dimensions that are reduced are crossed out in the result images. Their information value has been compressed by a reducer function.")])]),e._v(" "),t("h3",{attrs:{id:"aggregate"}},[t("a",{staticClass:"header-anchor",attrs:{href:"#aggregate"}},[e._v("#")]),e._v(" Aggregate")]),e._v(" "),t("p",[e._v("An aggregation of a datacube can be thought of as a grouped reduce. That means it consists of two steps:")]),e._v(" "),t("ol",[t("li",[e._v("Grouping via a grouping variable, i.e. spatial geometries or temporal intervals")]),e._v(" "),t("li",[e._v("Reducing these groups along the grouped dimension with a certain reducer function, e.g. calculating the mean pixel value per polygon or the maximum pixel values per month")])]),e._v(" "),t("p",[e._v("While the layout of the reduced dimension is changed, other dimensions keep their resolution and geometry. But in contrast to pure "),t("code",[e._v("reduce")]),e._v(", the dimensions along which the reducer function is applied still exist after the operation.")]),e._v(" "),t("div",{staticClass:"custom-block tip"},[t("p",{staticClass:"custom-block-title"},[e._v("Simplified")]),e._v(" "),t("p",[t("span",{attrs:{title:"Aggregating different family representations with 3, 2 and 4 members with the function 'countFamilyMembers' returns [3, 2, 4]."}},[t("code",[e._v("aggregate(👪 👩‍👦 👨‍👩‍👦‍👦, countFamilyMembers) => [3️⃣, 2️⃣, 4️⃣]")])])])]),e._v(" "),t("p",[e._v("A temporal aggregation (e.g. "),t("a",{attrs:{href:"https://processes.openeo.org/#aggregate_temporal",target:"_blank",rel:"noopener noreferrer"}},[t("code",[e._v("aggregate_temporal")]),t("OutboundLink")],1),e._v(") is similar to the downsampling process, as it can be seen in the according image above. Intervals for grouping can either be set manually, or periods can be chosen: monthly, yearly, etc. All timesteps in an interval are then collapsed via a reducer function ("),t("code",[e._v("mean")]),e._v(", "),t("code",[e._v("max")]),e._v(", etc.) and assigned to the given new labels.")]),e._v(" "),t("p",[e._v("A spatial aggregation (e.g. "),t("a",{attrs:{href:"https://processes.openeo.org/#aggregate_spatial",target:"_blank",rel:"noopener noreferrer"}},[t("code",[e._v("aggregate_spatial")]),t("OutboundLink")],1),e._v(") works in a similar manner. Polygons, lines and points can be selected for grouping. Their spatial dimension is then reduced by a given process and thus, a vector cube is returned. The vector cube then has dimensions containing features, attributes and time. In the graphic below, the grouping is only shown for the first timestep.")]),e._v(" "),t("figure",[t("img",{attrs:{src:a(314),alt:"Datacube spatial aggregation: A line and a polygon are selected from the original example tiles. The pixels covered by these geometries are aggregated and the result consists no longer of imagery tiles but of an array with values for 2 geometries by 4 bands by 3 timesteps."}}),e._v(" "),t("figcaption",[e._v("When aggregating spatially, pixels are grouped (cut out) based on geometries, and then collapsed with a reducer function. A vector datacube is returned (as shown with dimensions names and labels). Please note that this visualization shows aggregation on a data cube with four dimensions, but "),t("code",[e._v("aggregate_spatial")]),e._v(" specifically can only handle data cubes with three dimensions as of now.")])])])}),[],!1,null,null,null);t.default=i.exports}}]); \ No newline at end of file +(window.webpackJsonp=window.webpackJsonp||[]).push([[13],{310:function(e,t,a){e.exports=a.p+"assets/img/dc_timeseries.c2c7a902.png"},311:function(e,t,a){e.exports=a.p+"assets/img/dc_flat.01dc91de.png"},312:function(e,t,a){e.exports=a.p+"assets/img/vector.201588fe.png"},313:function(e,t,a){e.exports=a.p+"assets/img/dc_filter.bdafa6d0.png"},314:function(e,t,a){e.exports=a.p+"assets/img/dc_apply_unary.f69f840c.png"},315:function(e,t,a){e.exports=a.p+"assets/img/dc_apply_kernel.4013a72c.png"},316:function(e,t,a){e.exports=a.p+"assets/img/dc_apply_ts.4f9449f6.png"},317:function(e,t,a){e.exports=a.p+"assets/img/dc_apply_dim_ts.c895aa81.png"},318:function(e,t,a){e.exports=a.p+"assets/img/dc_resample_time.987e797c.png"},319:function(e,t,a){e.exports=a.p+"assets/img/dc_resample_space.417f814b.png"},320:function(e,t,a){e.exports=a.p+"assets/img/dc_reduce.872f16c2.png"},321:function(e,t,a){e.exports=a.p+"assets/img/dc_aggregate_space.ae550945.png"},513:function(e,t,a){"use strict";a.r(t);var s=a(4),i=Object(s.a)({},(function(){var e=this,t=e._self._c;return t("ContentSlotsDistributor",{attrs:{"slot-key":e.$parent.slotKey}},[t("h1",{attrs:{id:"datacubes"}},[t("a",{staticClass:"header-anchor",attrs:{href:"#datacubes"}},[e._v("#")]),e._v(" Datacubes")]),e._v(" "),t("h2",{attrs:{id:"what-are-datacubes"}},[t("a",{staticClass:"header-anchor",attrs:{href:"#what-are-datacubes"}},[e._v("#")]),e._v(" What are Datacubes?")]),e._v(" "),t("p",[e._v("Data is represented as datacubes in openEO, which are multi-dimensional arrays with additional information about their dimensionality. Datacubes can provide a nice and tidy interface for spatiotemporal data as well as for the operations you may want to execute on them. As they are arrays, it might be easiest to look at raster data as an example, even though datacubes can hold vector data as well. Our example data however consists of a 6x7 raster with 4 bands ["),t("code",[e._v("blue")]),e._v(", "),t("code",[e._v("green")]),e._v(", "),t("code",[e._v("red")]),e._v(", "),t("code",[e._v("near-infrared")]),e._v("] and 3 timesteps ["),t("code",[e._v("2020-10-01")]),e._v(", "),t("code",[e._v("2020-10-13")]),e._v(", "),t("code",[e._v("2020-10-25")]),e._v("], displayed here in an orderly, timeseries-like manner:")]),e._v(" "),t("figure",[t("img",{attrs:{src:a(310),alt:"Raster datacube timeseries: 12 imagery tiles are depicted, grouped by 3 dates along a timeline (time dimension). Each date has a blue, green, red and near-infrared band (bands dimension). Each single tile has the dimensions x and y (spatial dimensions)."}}),e._v(" "),t("figcaption",[e._v("An examplary raster datacube with 4 dimensions: x, y, bands and time.")])]),e._v(" "),t("p",[e._v("It is important to understand that datacubes are designed to make things easier for us, and are not literally a cube, meaning that the above plot is just as good a representation as any other. That is why we can switch the dimensions around and display them in whatever way we want, including the view below:")]),e._v(" "),t("figure",[t("img",{attrs:{src:a(311),alt:"Raster datacube flat representation: The 12 imagery tiles are now laid out flat as a 4 by 3 grid (bands by timesteps). All dimension labels are depicted (The timestamps, the band names and the x, y coordinates)."}}),e._v(" "),t("figcaption",[e._v("This is the 'raw' data collection that is our example datacube. The grayscale images are colored for understandability, and dimension labels are displayed.")])]),e._v(" "),t("p",[e._v("A vector datacube on the other hand could look like this:")]),e._v(" "),t("figure",[t("img",{attrs:{src:a(312),alt:"An examplary vector datacube with 3 dimensions: 2 geometries are given for the `geometries` dimension, along with 3 timesteps for the temporal dimension `time` and 4 bands in the `bands` dimension."}}),e._v(" "),t("figcaption",[e._v("An examplary vector datacube with 3 dimensions: 2 geometries are given for the "),t("code",[e._v("geometries")]),e._v(" dimension, along with 3 timesteps for the temporal dimension "),t("code",[e._v("time")]),e._v(" and 4 bands in the "),t("code",[e._v("bands")]),e._v(" dimension.")])]),e._v(" "),t("p",[t("a",{attrs:{href:"https://r-spatial.org/r/2022/09/12/vdc.html",target:"_blank",rel:"noopener noreferrer"}},[e._v("Vector datacubes"),t("OutboundLink")],1),e._v(" and raster datacubes are common cases of datacubes in the EO domain.\nA raster datacube has at least two spatial dimensions (usually named "),t("code",[e._v("x")]),e._v(" and "),t("code",[e._v("y")]),e._v(") and a vector datacube has at least one geometry dimension (usually named "),t("code",[e._v("geometry")]),e._v(').\nThe purpose of these distinctions is simply to make it easier to describe "special" cases of datacubes, but you can also define other types such as a temporal datacube that has at least one temporal dimension (usually named '),t("code",[e._v("t")]),e._v(").")]),e._v(" "),t("p",[e._v("The following additional information are usually available for datacubes:")]),e._v(" "),t("ul",[t("li",[e._v("the dimensions (see "),t("a",{attrs:{href:"#dimensions"}},[e._v("below")]),e._v(")")]),e._v(" "),t("li",[e._v("a sampling method (see "),t("a",{attrs:{href:"#values-in-a-datacube"}},[e._v("below")]),e._v(")")]),e._v(" "),t("li",[e._v("a unit for the values")])]),e._v(" "),t("p",[e._v("All these information are usually provided through the datacube metadata.")]),e._v(" "),t("h2",{attrs:{id:"dimensions"}},[t("a",{staticClass:"header-anchor",attrs:{href:"#dimensions"}},[e._v("#")]),e._v(" Dimensions")]),e._v(" "),t("p",[e._v("A dimension refers to a certain axis of a datacube. This includes all variables (e.g. bands), which are represented as dimensions. Our exemplary raster datacube has the spatial dimensions "),t("code",[e._v("x")]),e._v(" and "),t("code",[e._v("y")]),e._v(", and the temporal dimension "),t("code",[e._v("t")]),e._v(". Furthermore, it has a "),t("code",[e._v("bands")]),e._v(" dimension, extending into the realm of "),t("em",[e._v("what kind of information")]),e._v(" is contained in the cube.")]),e._v(" "),t("p",[e._v("The following properties are usually available for dimensions:")]),e._v(" "),t("ul",[t("li",[e._v("name")]),e._v(" "),t("li",[e._v("type (potential types include: spatial (raster or vector data), temporal and other data such as bands)")]),e._v(" "),t("li",[e._v("axis (for spatial dimensions) / number")]),e._v(" "),t("li",[e._v("labels (usually exposed through textual or numerical representations, in the metadata as nominal values and/or extents)")]),e._v(" "),t("li",[e._v("reference system / projection")]),e._v(" "),t("li",[e._v("resolution / step size")]),e._v(" "),t("li",[e._v("unit for the labels (either explicitly specified or implicitly provided by the reference system)")]),e._v(" "),t("li",[e._v("additional information specific to the dimension type (e.g. the geometry types for a dimension containing geometries)")])]),e._v(" "),t("p",[e._v("All these information are usually provided through the datacube metadata.")]),e._v(" "),t("p",[e._v("Here is an overview of the dimensions contained in our example raster datacube above:")]),e._v(" "),t("table",[t("thead",[t("tr",[t("th",[e._v("#")]),e._v(" "),t("th",[e._v("name")]),e._v(" "),t("th",[e._v("type")]),e._v(" "),t("th",[e._v("labels")]),e._v(" "),t("th",[e._v("resolution")]),e._v(" "),t("th",[e._v("reference system")])])]),e._v(" "),t("tbody",[t("tr",[t("td",[e._v("1")]),e._v(" "),t("td",[t("code",[e._v("x")])]),e._v(" "),t("td",[e._v("spatial")]),e._v(" "),t("td",[t("code",[e._v("466380")]),e._v(", "),t("code",[e._v("466580")]),e._v(", "),t("code",[e._v("466780")]),e._v(", "),t("code",[e._v("466980")]),e._v(", "),t("code",[e._v("467180")]),e._v(", "),t("code",[e._v("467380")])]),e._v(" "),t("td",[e._v("200m")]),e._v(" "),t("td",[t("a",{attrs:{href:"https://epsg.io/32627",target:"_blank",rel:"noopener noreferrer"}},[e._v("EPSG:32627"),t("OutboundLink")],1)])]),e._v(" "),t("tr",[t("td",[e._v("2")]),e._v(" "),t("td",[t("code",[e._v("y")])]),e._v(" "),t("td",[e._v("spatial")]),e._v(" "),t("td",[t("code",[e._v("7167130")]),e._v(", "),t("code",[e._v("7166930")]),e._v(", "),t("code",[e._v("7166730")]),e._v(", "),t("code",[e._v("7166530")]),e._v(", "),t("code",[e._v("7166330")]),e._v(", "),t("code",[e._v("7166130")]),e._v(", "),t("code",[e._v("7165930")])]),e._v(" "),t("td",[e._v("200m")]),e._v(" "),t("td",[t("a",{attrs:{href:"https://epsg.io/32627",target:"_blank",rel:"noopener noreferrer"}},[e._v("EPSG:32627"),t("OutboundLink")],1)])]),e._v(" "),t("tr",[t("td",[e._v("3")]),e._v(" "),t("td",[t("code",[e._v("bands")])]),e._v(" "),t("td",[e._v("bands")]),e._v(" "),t("td",[t("code",[e._v("blue")]),e._v(", "),t("code",[e._v("green")]),e._v(", "),t("code",[e._v("red")]),e._v(", "),t("code",[e._v("nir")])]),e._v(" "),t("td",[e._v("4 bands")]),e._v(" "),t("td",[e._v("-")])]),e._v(" "),t("tr",[t("td",[e._v("4")]),e._v(" "),t("td",[t("code",[e._v("t")])]),e._v(" "),t("td",[e._v("temporal")]),e._v(" "),t("td",[t("code",[e._v("2020-10-01")]),e._v(", "),t("code",[e._v("2020-10-13")]),e._v(", "),t("code",[e._v("2020-10-25")])]),e._v(" "),t("td",[e._v("12 days")]),e._v(" "),t("td",[e._v("Gregorian calendar / UTC")])])])]),e._v(" "),t("p",[e._v('Dimension labels are usually either numerical or text (also known as "strings"), which also includes textual representations of timestamps or geometries for example.\nFor example, temporal labels are usually encoded as '),t("a",{attrs:{href:"https://en.wikipedia.org/wiki/ISO_8601",target:"_blank",rel:"noopener noreferrer"}},[e._v("ISO 8601"),t("OutboundLink")],1),e._v(" compatible dates and/or times and similarly geometries can be encoded as "),t("a",{attrs:{href:"https://en.wikipedia.org/wiki/Well-known_text_representation_of_geometry",target:"_blank",rel:"noopener noreferrer"}},[e._v("Well-known Text (WKT)"),t("OutboundLink")],1),e._v(" or be represented by their IDs.")]),e._v(" "),t("p",[e._v("Dimensions with a natural/inherent order (usually all temporal and spatial raster dimensions) are always sorted. Dimensions without inherent order (usually "),t("code",[e._v("bands")]),e._v("), retain the order in which they have been defined in metadata or processes (e.g. through "),t("a",{attrs:{href:"https://processes.openeo.org/#filter_bands",target:"_blank",rel:"noopener noreferrer"}},[t("code",[e._v("filter_bands")]),t("OutboundLink")],1),e._v("), with new labels simply being appended to the existing labels.")]),e._v(" "),t("p",[e._v("A geometry dimension is not included in the example raster datacube above and it is not used in the following examples, but to show how a vector dimension with two polygons could look like:")]),e._v(" "),t("table",[t("thead",[t("tr",[t("th",[e._v("name")]),e._v(" "),t("th",[e._v("type")]),e._v(" "),t("th",[e._v("labels")]),e._v(" "),t("th",[e._v("reference system")])])]),e._v(" "),t("tbody",[t("tr",[t("td",[t("code",[e._v("geometry")])]),e._v(" "),t("td",[e._v("vector")]),e._v(" "),t("td",[t("code",[e._v("POLYGON((-122.4 37.6,-122.35 37.6,-122.35 37.64,-122.4 37.64,-122.4 37.6))")]),e._v(", "),t("code",[e._v("POLYGON((-122.51 37.5,-122.48 37.5,-122.48 37.52,-122.51 37.52,-122.51 37.5))")])]),e._v(" "),t("td",[t("a",{attrs:{href:"https://epsg.io/4326",target:"_blank",rel:"noopener noreferrer"}},[e._v("EPSG:4326"),t("OutboundLink")],1)])])])]),e._v(" "),t("p",[e._v("A dimension with geometries can consist of points, linestrings, polygons, multi points, multi linestrings, or multi polygons.\nIt is not possible to mix geometry types, but the single geometry type with their corresponding multi type can be combined in a dimension (e.g. points and multi points).\nEmpty geometries (such as GeoJSON features with a "),t("code",[e._v("null")]),e._v(" geometry or GeoJSON geometries with an empty coordinates array) are allowed and can sometimes also be the result of certain vector operations such as a negative buffer.")]),e._v(" "),t("h3",{attrs:{id:"applying-processes-on-dimensions"}},[t("a",{staticClass:"header-anchor",attrs:{href:"#applying-processes-on-dimensions"}},[e._v("#")]),e._v(" Applying Processes on Dimensions")]),e._v(" "),t("p",[e._v('Some processes are typically applied "along a dimension". You can imagine said dimension as an arrow and whatever is happening as a parallel process to that arrow. It simply means: "we focus on '),t("em",[e._v("this")]),e._v(' dimension right now".')]),e._v(" "),t("h3",{attrs:{id:"resolution"}},[t("a",{staticClass:"header-anchor",attrs:{href:"#resolution"}},[e._v("#")]),e._v(" Resolution")]),e._v(" "),t("p",[e._v("The resolution of a dimension gives information about what interval lies between observations. This is most obvious with the temporal resolution, where the intervals depict how often observations were made. Spatial resolution gives information about the pixel spacing, meaning how many 'real world meters' are contained in a pixel. The number of bands and their wavelength intervals give information about the spectral resolution.")]),e._v(" "),t("h3",{attrs:{id:"coordinate-reference-system-as-a-dimension"}},[t("a",{staticClass:"header-anchor",attrs:{href:"#coordinate-reference-system-as-a-dimension"}},[e._v("#")]),e._v(" Coordinate Reference System as a Dimension")]),e._v(" "),t("p",[e._v("In the example above, "),t("em",[e._v("x")]),e._v(" and "),t("em",[e._v("y")]),e._v(" dimension values have a "),t("em",[e._v("unique")]),e._v(" relationship to world coordinates through their coordinate reference system (CRS). This implies that a single coordinate reference system is associated with these "),t("em",[e._v("x")]),e._v(" and "),t("em",[e._v("y")]),e._v(" dimensions. If we want to create a data cube from multiple tiles spanning different coordinate reference systems (e.g. Sentinel-2: different UTM zones), we would "),t("em",[e._v("have")]),e._v(" to resample/warp those to a single coordinate reference system. In many cases, this is wanted because we want to be able to "),t("em",[e._v("look")]),e._v(" at the result, meaning it is available in a single coordinate reference system.")]),e._v(" "),t("p",[e._v("Resampling is however costly, involves (some) data loss, and is in general not reversible. Suppose that we want to work only on the spectral and temporal dimensions of a data cube, and do not want to do any resampling. In that case, one could create one data cube for each coordinate reference system. An alternative would be to create one "),t("em",[e._v("single")]),e._v(" data cube containing all tiles that has an "),t("em",[e._v("additional dimension")]),e._v(" with the coordinate reference system. In that data cube, "),t("em",[e._v("x")]),e._v(" and "),t("em",[e._v("y")]),e._v(" no longer point to a unique world coordinate, because identical "),t("em",[e._v("x")]),e._v(" and "),t("em",[e._v("y")]),e._v(" coordinate pairs occur in each UTM zone. Now, only the combination ("),t("em",[e._v("x")]),e._v(", "),t("em",[e._v("y")]),e._v(", "),t("em",[e._v("crs")]),e._v(") has a unique relationship to the world coordinates.")]),e._v(" "),t("p",[e._v("On such a "),t("em",[e._v("crs-dimensioned data cube")]),e._v(", several operations make perfect sense, such as "),t("code",[e._v("apply")]),e._v(" or "),t("code",[e._v("reduce_dimension")]),e._v(" on spectral and/or temporal dimensions. A simple reduction over the "),t("code",[e._v("crs")]),e._v(" dimension, using "),t("em",[e._v("sum")]),e._v(" or "),t("em",[e._v("mean")]),e._v(' would typically not make sense. The "reduction" (removal) of the '),t("code",[e._v("crs")]),e._v(" dimension that is meaningful involves the resampling/warping of all sub-cubes for the "),t("code",[e._v("crs")]),e._v(" dimension to a single, common target coordinate reference system.")]),e._v(" "),t("h2",{attrs:{id:"values-in-a-datacube"}},[t("a",{staticClass:"header-anchor",attrs:{href:"#values-in-a-datacube"}},[e._v("#")]),e._v(" Values in a datacube")]),e._v(" "),t("p",[e._v("openEO datacubes contain scalar values (e.g. strings, numbers or boolean values), with all other associated attributes stored in dimensions (e.g. coordinates or timestamps). Attributes such as the CRS or the sensor can also be turned into dimensions. Be advised that in such a case, the uniqueness of pixel coordinates may be affected. When usually, "),t("code",[e._v("(x, y)")]),e._v(" refers to a unique location, that changes to "),t("code",[e._v("(x, y, CRS)")]),e._v(" when "),t("code",[e._v("(x, y)")]),e._v(" values are reused in other coordinate reference systems (e.g. two neighboring UTM zones).")]),e._v(" "),t("div",{staticClass:"custom-block tip"},[t("p",{staticClass:"custom-block-title"},[e._v("Be Careful with Data Types")]),e._v(" "),t("p",[e._v("As stated above, datacubes only contain scalar values. However, implementations may differ in their ability to handle or convert them. Implementations may also not allow mixing data types in a datacube. For example, returning a boolean value for a reducer on a numerical datacube may result in an error on some back-ends. The recommendation is to not change the data type of values in a datacube unless the back-end supports it explicitly.")])]),e._v(" "),t("p",[e._v("Data cube values can be sampled in two different ways. The values are either area or point samples.")]),e._v(" "),t("ul",[t("li",[e._v("Area sampling aggregates measurements over defined regions, i.e. the grid cells for raster data or polygons/lines for vector data.")]),e._v(" "),t("li",[e._v("Point sampling collects data at specific locations, providing detailed information for specific points.")])]),e._v(" "),t("h2",{attrs:{id:"processes-on-datacubes"}},[t("a",{staticClass:"header-anchor",attrs:{href:"#processes-on-datacubes"}},[e._v("#")]),e._v(" Processes on Datacubes")]),e._v(" "),t("p",[e._v("In the following part, the basic processes for manipulating datacubes are introduced.")]),e._v(" "),t("h3",{attrs:{id:"filter"}},[t("a",{staticClass:"header-anchor",attrs:{href:"#filter"}},[e._v("#")]),e._v(" Filter")]),e._v(" "),t("p",[e._v("When filtering data (e.g. "),t("a",{attrs:{href:"https://processes.openeo.org/#filter_spatial",target:"_blank",rel:"noopener noreferrer"}},[t("code",[e._v("filter_spatial")]),t("OutboundLink")],1),e._v(", "),t("a",{attrs:{href:"https://processes.openeo.org/#filter_temporal",target:"_blank",rel:"noopener noreferrer"}},[t("code",[e._v("filter_temporal")]),t("OutboundLink")],1),e._v(", "),t("a",{attrs:{href:"https://processes.openeo.org/#filter_bands",target:"_blank",rel:"noopener noreferrer"}},[t("code",[e._v("filter_bands")]),t("OutboundLink")],1),e._v("), only the data that satisfies a condition is returned. For example, this condition could be a timestamp or interval, (a set of) coordinates, or specific bands. By applying filtering the datacube becomes smaller, according to the selected data.")]),e._v(" "),t("div",{staticClass:"custom-block tip"},[t("p",{staticClass:"custom-block-title"},[e._v("Simplified")]),e._v(" "),t("p",[t("span",{attrs:{title:"Filtering vegetarian options from [corn, potato, pig] returns [corn, potato].\n"}},[t("code",[e._v("filter([🌽, 🥔, 🐷], isVegetarian) => [🌽, 🥔]")])])])]),e._v(" "),t("p",[e._v("In the image, the example datacube can be seen at the top with labeled dimensions. The filtering techniques are displayed separately below. On the left, the datacube is filtered temporally with the interval "),t("code",[e._v('["2020-10-15", "2020-10-27"]')]),e._v(". The result is a cube with only the rasters for the timestep that lies within that interval ("),t("code",[e._v('"2020-10-25"')]),e._v(") and unchanged bands and spatial dimensions. Likewise, the original cube is filtered for a specific band "),t("code",[e._v('["nir"]')]),e._v(" in the middle and a specific spatial region "),t("code",[e._v("[Polygon(...)]")]),e._v(" on the right.")]),e._v(" "),t("figure",[t("img",{attrs:{src:a(313),alt:"Datacube filtering: From the datacube 4 by 3 grid, arrows depict what happens if the grid is filtered. Temporal filtering results in data for one timestep with all four bands, filtering bands results in data with one band with all three timesteps, and spatial filtering results in all timesteps and bands being preserved, but all with a smaller area."}}),e._v(" "),t("figcaption",[e._v("Filtering the sample datacube. It is displayed at the top with dimensions labels. Filtered results are shown at the bottom.")])]),e._v(" "),t("h3",{attrs:{id:"apply"}},[t("a",{staticClass:"header-anchor",attrs:{href:"#apply"}},[e._v("#")]),e._v(" Apply")]),e._v(" "),t("p",[e._v("The "),t("code",[e._v("apply*")]),e._v(" functions (e.g. "),t("a",{attrs:{href:"https://processes.openeo.org/#apply",target:"_blank",rel:"noopener noreferrer"}},[t("code",[e._v("apply")]),t("OutboundLink")],1),e._v(", "),t("a",{attrs:{href:"https://processes.openeo.org/#apply_neighborhood",target:"_blank",rel:"noopener noreferrer"}},[t("code",[e._v("apply_neighborhood")]),t("OutboundLink")],1),e._v(", "),t("a",{attrs:{href:"https://processes.openeo.org/#apply_dimension",target:"_blank",rel:"noopener noreferrer"}},[t("code",[e._v("apply_dimension")]),t("OutboundLink")],1),e._v(") employ a process on the datacube that calculates new pixel values for each pixel, based on "),t("code",[e._v("n")]),e._v(" other pixels. Please note that several programming languages use the name "),t("code",[e._v("map")]),e._v(" instead of "),t("code",[e._v("apply")]),e._v(", but they describe the same type of function.")]),e._v(" "),t("div",{staticClass:"custom-block tip"},[t("p",{staticClass:"custom-block-title"},[e._v("Simplified")]),e._v(" "),t("p",[t("span",{attrs:{title:"Applying the process 'cook' to [corn, potato, pig] returns [popcorn, fries, meat]."}},[t("code",[e._v("apply([🌽, 🥔, 🐷], cook) => [🍿, 🍟, 🍖]")])])])]),e._v(" "),t("p",[e._v("For the case "),t("code",[e._v("n = 1")]),e._v(" this is called a unary function and means that only the pixel itself is considered when calculating the new pixel value. A prominent example is the "),t("code",[e._v("absolute()")]),e._v(" function, calculating the absolute value of the input pixel value.")]),e._v(" "),t("figure",[t("img",{attrs:{src:a(314),alt:"Datacube apply unary: 3 example tiles hold values below and above 0. after applying the process 'absolute', all values in the three example tiles have changed to their absolute values above 0."}}),e._v(" "),t("figcaption",[e._v("Applying an unary process. Only the pixel itself is considered for calculating the new pixel value.")])]),e._v(" "),t("p",[e._v("If "),t("code",[e._v("n")]),e._v(" is larger than 1, the function is called n-ary. In practice, this means that the pixel neighbourhood is taken into account to calculate the new pixel value. Such neighbourhoods can be of spatial and/or temporal nature. A spatial function works on a kernel that weights the surrounding pixels (e.g. smoothing values with nearby observations), a temporal function works on a time series at a certain pixel location (e.g. smoothing values over time). Combinations of types to n-dimensional neighbourhoods are also possible.")]),e._v(" "),t("p",[e._v("In the example below, an example weighted kernel (shown in the middle) is applied to the cube (via "),t("a",{attrs:{href:"https://processes.openeo.org/#apply_kernel",target:"_blank",rel:"noopener noreferrer"}},[t("code",[e._v("apply_kernel")]),t("OutboundLink")],1),e._v("). To avoid edge effects (affecting pixels on the edge of the image with less neighbours), a padding has been added in the background.")]),e._v(" "),t("figure",[t("img",{attrs:{src:a(315),alt:"Datacube apply spatial kernel: Three example tiles hold some values with a lot of variance. A spatial kernel (a cell plus it's 4 direct neighbours) is applied to all pixels, and the result appears to be spatially smoothed, with less variance."}}),e._v(" "),t("figcaption",[e._v("Applying a spatial kernel. For calculating each new pixel value, the defined weighted neighbourhood is used.")])]),e._v(" "),t("p",[e._v("Of course this also works for temporal neighbourhoods (timeseries), considering neighbours before and after a pixel. To be able to show the effect, two timesteps were added in this example figure. A moving average of window size 3 is then applied, meaning that for each pixel the average is calculated out of the previous, the next, and the timestep in question (t"),t("sub",[e._v("n-1")]),e._v(", t"),t("sub",[e._v("n")]),e._v(" and t"),t("sub",[e._v("n+1")]),e._v("). No padding was added which is why we observe edge effects (NA values are returned for t"),t("sub",[e._v("1")]),e._v(" and t"),t("sub",[e._v("5")]),e._v(", because their temporal neighbourhood is missing input timesteps).")]),e._v(" "),t("figure",[t("img",{attrs:{src:a(316),alt:"Datacube apply temporal moving average: Smoothing is applied to 5 example tiles by calculating the mean of 3 timesteps of every single pixel. The resulting tiles for the timestamps look much more alike."}}),e._v(" "),t("figcaption",[e._v("Applying a moving average (temporal smoothing) by averaging the direct temporal neighbourhoods of pixels. No padding is used, which leads to edge effects.")])]),e._v(" "),t("p",[e._v("Alternatively, a process can also be applied along a dimension of the datacube, meaning the input is no longer a neighbourhood of some sort but all pixels along that dimension ("),t("code",[e._v("n")]),e._v(" equals the complete dimension). If a process is applied along the "),t("code",[e._v("time")]),e._v(" dimension (e.g. a breakpoint detection), the complete pixel timeseries are the input. If a process is applied along the "),t("code",[e._v("spatial")]),e._v(" dimensions (e.g. a "),t("code",[e._v("mean")]),e._v("), all pixels of an image are the input. The process is then applied to all pixels along that dimension and the dimension continues to exist. This is in contrast to "),t("a",{attrs:{href:"#reduce"}},[e._v("reduce")]),e._v(". In the image below, a "),t("code",[e._v("mean")]),e._v(" is applied to the "),t("code",[e._v("time")]),e._v(" dimension. An example pixel timeseries is highlighted by a green line and processed step-by-step.")]),e._v(" "),t("figure",[t("img",{attrs:{src:a(317),alt:"Datacube apply dimension time: The mean of all 5 timesteps is calculated for every single pixel. The resulting 5 tiles look exaclty the same, as they have been averaged."}}),e._v(" "),t("figcaption",[e._v("Applying a mean to the temporal dimension.")])]),e._v(" "),t("h3",{attrs:{id:"resample"}},[t("a",{staticClass:"header-anchor",attrs:{href:"#resample"}},[e._v("#")]),e._v(" Resample")]),e._v(" "),t("p",[e._v("In a resampling processes (e.g. "),t("a",{attrs:{href:"https://processes.openeo.org/#resample_cube_spatial",target:"_blank",rel:"noopener noreferrer"}},[t("code",[e._v("resample_cube_spatial")]),t("OutboundLink")],1),e._v(", "),t("a",{attrs:{href:"https://processes.openeo.org/#resample_cube_temporal",target:"_blank",rel:"noopener noreferrer"}},[t("code",[e._v("resample_cube_temporal")]),t("OutboundLink")],1),e._v("), the "),t("em",[e._v("layout")]),e._v(" of a certain dimension is changed into another "),t("em",[e._v("layout")]),e._v(", most likely also changing the resolution of that dimension. This is done by mapping values of the source (old) datacube to the new layout of the target (new) datacube. During that process, resolutions can be "),t("em",[e._v("upscaled")]),e._v(" or "),t("em",[e._v("downscaled")]),e._v(" (also called "),t("em",[e._v("upsampling")]),e._v(" and "),t("em",[e._v("downsampling")]),e._v("), depending on whether they have a finer or a coarser spacing afterwards. A function is then needed to translate the existing data into the new resolution. A prominent example is to reproject a datacube into the coordinate reference system of another datacube, for example in order to merge the two cubes.")]),e._v(" "),t("div",{staticClass:"custom-block tip"},[t("p",{staticClass:"custom-block-title"},[e._v("Simplified")]),e._v(" "),t("p",[t("span",{attrs:{title:"Downscaling a raster image (to infinity) returns one pixel."}},[t("code",[e._v("resample(🖼️, downscale) => 🟦")])])]),e._v(" "),t("p",[t("span",{attrs:{title:"Reprojecting a globe results into a map."}},[t("code",[e._v("resample(🌍, reproject) => 🗺️")])])])]),e._v(" "),t("p",[e._v("The first figure gives an overview of temporal resampling. How exactly the input timesteps are rescaled to the output timesteps depends on the resampling function.")]),e._v(" "),t("figure",[t("img",{attrs:{src:a(318),alt:"Datacube temporal resampling (up and down): Downsampling: To a timeline-representation of the example tiles, another timeline with only 2 steps at different dates is applied. The result has tiles only at those new timesteps. In Upsampling, the existing 3 timesteps are sampled into 5 result timesteps."}}),e._v(" "),t("figcaption",[e._v("Temporal downsampling is seen on the left, upsampling on the right. The temporal layout that the cubes are resampled to is displayed in the middle.")])]),e._v(" "),t("p",[e._v("The second figure displays spatial resampling. Observe how in the upsampling process, the output datacube has not gained in information value. The resulting grid still carries the same pixel information, but in higher spatial resolution. Other upsampling methods may yield smoother results, e.g. by using interpolation.")]),e._v(" "),t("figure",[t("img",{attrs:{src:a(319),alt:"Datacube spatial resampling (up and down): Downsampling: The resulting tiles have a lower spatial resolution than the input tiles. Upsampling: The resulting tiles have a higher spatial resolution than the input tiles, but contain the same image than before (no information added)."}}),e._v(" "),t("figcaption",[e._v("Spatial resampling. The geometry which the input cube is resampled to is displayed in the middle. The output cube then contains the same information, but in the resampled spatial layout.")])]),e._v(" "),t("h3",{attrs:{id:"reduce"}},[t("a",{staticClass:"header-anchor",attrs:{href:"#reduce"}},[e._v("#")]),e._v(" Reduce")]),e._v(" "),t("p",[e._v("The "),t("a",{attrs:{href:"https://processes.openeo.org/#reduce_dimension",target:"_blank",rel:"noopener noreferrer"}},[t("code",[e._v("reduce_dimension")]),t("OutboundLink")],1),e._v(" process "),t("em",[e._v("collapses")]),e._v(" a whole dimension of the datacube. It does so by using some sort of "),t("strong",[e._v("reducer")]),e._v(", which is a function that calculates a single result from an amount of values, as e.g. "),t("code",[e._v("mean()")]),e._v(", "),t("code",[e._v("min()")]),e._v(" and "),t("code",[e._v("max()")]),e._v(" are. For example we can reduce the time dimension ("),t("code",[e._v("t")]),e._v(") of a timeseries by calculating the mean value of all timesteps for each pixel. We are left with a cube that has no time dimension, because all values of that dimension are compressed into a single mean value. The same goes for e.g. the spatial dimensions: If we calculate the mean along the "),t("code",[e._v("x")]),e._v(" and "),t("code",[e._v("y")]),e._v(" dimensions, we are left without any spatial dimensions, but a mean value for each instance that previously was a raster is returned. In the image below, the dimensions that are reduced are crossed out in the result.")]),e._v(" "),t("div",{staticClass:"custom-block tip"},[t("p",{staticClass:"custom-block-title"},[e._v("Simplified")]),e._v(" "),t("p",[t("span",{attrs:{title:"Reducing [mixed greens, cucumber, tomato, onion] returns a salad."}},[t("code",[e._v("reduce([🥬, 🥒, 🍅, 🧅], prepare) => 🥗")])])])]),e._v(" "),t("p",[e._v("Think of it as a waste press that does math instead of using brute force. Given a representation of our example datacube, let's see how it is affected.")]),e._v(" "),t("figure",[t("img",{attrs:{src:a(320),alt:"Datacube reduce: Three arrows depict what happens to the 12 example tiles, if they are reduced: Reducing timesteps leads to four tiles (one for each band), and the time dimension is deleted. Reducing bands lead to one tile per timestep, and the bands dimension is deleted. Reducing spatially leads to the original 4 by 3 bands by time layout, but the result has no spatial dimension and thus, the tiles have been turned into single values, per tile."}}),e._v(" "),t("figcaption",[e._v("Overview of reducing the sample datacube. Dimensions that are reduced are crossed out in the result images. Their information value has been compressed by a reducer function.")])]),e._v(" "),t("h3",{attrs:{id:"aggregate"}},[t("a",{staticClass:"header-anchor",attrs:{href:"#aggregate"}},[e._v("#")]),e._v(" Aggregate")]),e._v(" "),t("p",[e._v("An aggregation of a datacube can be thought of as a grouped reduce. That means it consists of two steps:")]),e._v(" "),t("ol",[t("li",[e._v("Grouping via a grouping variable, i.e. spatial geometries or temporal intervals")]),e._v(" "),t("li",[e._v("Reducing these groups along the grouped dimension with a certain reducer function, e.g. calculating the mean pixel value per polygon or the maximum pixel values per month")])]),e._v(" "),t("p",[e._v("While the layout of the reduced dimension is changed, other dimensions keep their resolution and geometry. But in contrast to pure "),t("code",[e._v("reduce")]),e._v(", the dimensions along which the reducer function is applied still exist after the operation.")]),e._v(" "),t("div",{staticClass:"custom-block tip"},[t("p",{staticClass:"custom-block-title"},[e._v("Simplified")]),e._v(" "),t("p",[t("span",{attrs:{title:"Aggregating different family representations with 3, 2 and 4 members with the function 'countFamilyMembers' returns [3, 2, 4]."}},[t("code",[e._v("aggregate(👪 👩‍👦 👨‍👩‍👦‍👦, countFamilyMembers) => [3️⃣, 2️⃣, 4️⃣]")])])])]),e._v(" "),t("p",[e._v("A temporal aggregation (e.g. "),t("a",{attrs:{href:"https://processes.openeo.org/#aggregate_temporal",target:"_blank",rel:"noopener noreferrer"}},[t("code",[e._v("aggregate_temporal")]),t("OutboundLink")],1),e._v(") is similar to the downsampling process, as it can be seen in the according image above. Intervals for grouping can either be set manually, or periods can be chosen: monthly, yearly, etc. All timesteps in an interval are then collapsed via a reducer function ("),t("code",[e._v("mean")]),e._v(", "),t("code",[e._v("max")]),e._v(", etc.) and assigned to the given new labels.")]),e._v(" "),t("p",[e._v("A spatial aggregation (e.g. "),t("a",{attrs:{href:"https://processes.openeo.org/#aggregate_spatial",target:"_blank",rel:"noopener noreferrer"}},[t("code",[e._v("aggregate_spatial")]),t("OutboundLink")],1),e._v(") works in a similar manner. Polygons, lines and points can be selected for grouping. Their spatial dimension is then reduced by a given process and thus, a vector cube is returned. The vector cube then has dimensions containing features, attributes and time. In the graphic below, the grouping is only shown for the first timestep.")]),e._v(" "),t("figure",[t("img",{attrs:{src:a(321),alt:"Datacube spatial aggregation: A line and a polygon are selected from the original example tiles. The pixels covered by these geometries are aggregated and the result consists no longer of imagery tiles but of an array with values for 2 geometries by 4 bands by 3 timesteps."}}),e._v(" "),t("figcaption",[e._v("When aggregating spatially, pixels are grouped (cut out) based on geometries, and then collapsed with a reducer function. A vector datacube is returned (as shown with dimensions names and labels). Please note that this visualization shows aggregation on a data cube with four dimensions, but "),t("code",[e._v("aggregate_spatial")]),e._v(" specifically can only handle data cubes with three dimensions as of now.")])])])}),[],!1,null,null,null);t.default=i.exports}}]); \ No newline at end of file diff --git a/assets/js/15.f548d8e3.js b/assets/js/15.4231ee89.js similarity index 99% rename from assets/js/15.f548d8e3.js rename to assets/js/15.4231ee89.js index c39008d4f..46b20b2eb 100644 --- a/assets/js/15.f548d8e3.js +++ b/assets/js/15.4231ee89.js @@ -1 +1 @@ -(window.webpackJsonp=window.webpackJsonp||[]).push([[15],{325:function(e,t,o){e.exports=o.p+"assets/img/qgis_button.2b5f39a5.png"},326:function(e,t,o){e.exports=o.p+"assets/img/login_dialog.424c4b4e.png"},327:function(e,t,o){e.exports=o.p+"assets/img/backend_info.a00e7a1d.png"},328:function(e,t,o){e.exports=o.p+"assets/img/jobs.fef9e692.png"},329:function(e,t,o){e.exports=o.p+"assets/img/adapt_job.64ea4b55.png"},330:function(e,t,o){e.exports=o.p+"assets/img/edit_spatial.23df03fa.png"},331:function(e,t,o){e.exports=o.p+"assets/img/edit_temporal.609c87e2.png"},332:function(e,t,o){e.exports=o.p+"assets/img/edit_bands.d9ed77a5.png"},333:function(e,t,o){e.exports=o.p+"assets/img/edit_subpg.c7fbfd4d.png"},334:function(e,t,o){e.exports=o.p+"assets/img/services.a958fd61.png"},335:function(e,t,o){e.exports=o.p+"assets/img/services_create.0881f2cd.png"},533:function(e,t,o){"use strict";o.r(t);var n=o(4),a=Object(n.a)({},(function(){var e=this,t=e._self._c;return t("ContentSlotsDistributor",{attrs:{"slot-key":e.$parent.slotKey}},[t("h1",{attrs:{id:"qgis-plugin"}},[t("a",{staticClass:"header-anchor",attrs:{href:"#qgis-plugin"}},[e._v("#")]),e._v(" QGIS Plugin")]),e._v(" "),t("p",[e._v("The openEO QGIS plugin enables exploring openEO backends as well as execute and modify your jobs at an backend\nwithin QGIS. The plugin can load the results of a job execution to the QGIS map, so that the user can make further\nanalyses and visualisation steps.")]),e._v(" "),t("h2",{attrs:{id:"installation"}},[t("a",{staticClass:"header-anchor",attrs:{href:"#installation"}},[e._v("#")]),e._v(" Installation")]),e._v(" "),t("p",[e._v("There are two different versions of the QGIS Plugin available:")]),e._v(" "),t("ol",[t("li",[e._v("The "),t("strong",[e._v("latest stable version")]),e._v(' is accessible in the plugin\nmanager of QGIS (Plugins -> Manage and Install Plugins). Note that you have to activate the option to show experimental\nplugins (Settings -> Show also experimental plugins). After that, you can search for\n"OpenEO", install and activate the plugin.')]),e._v(" "),t("li",[e._v("The "),t("strong",[e._v("latest version")]),e._v(" is accessible at the\n"),t("a",{attrs:{href:"https://github.com/Open-EO/openeo-qgis-plugin",target:"_blank",rel:"noopener noreferrer"}},[e._v("GitHub repository"),t("OutboundLink")],1),e._v('. First, download the repository as zip archive.\nNow, open the plugin manager of QGIS (Plugins -> Manage and Install Plugins) and select "Install from ZIP".\nThere you can browse for the downloaded zip archive, install and activate it.')])]),e._v(" "),t("p",[e._v("This tutorial shows the capabilities of version 0.9.2. Make sure you have installed at least that version by checking in\nthe plugin manager.")]),e._v(" "),t("p",[e._v("After successfully installing and activating the plugin, the openEO logo should be part of the toolbar:")]),e._v(" "),t("p",[t("img",{attrs:{src:o(325),alt:"QGIS Plugin Icon"}})]),e._v(" "),t("p",[e._v("Simply click on the icon to start the plugin.")]),e._v(" "),t("h2",{attrs:{id:"connecting"}},[t("a",{staticClass:"header-anchor",attrs:{href:"#connecting"}},[e._v("#")]),e._v(" Connecting")]),e._v(" "),t("p",[e._v("The first window you see when starting the plugin is a login dialog, since you can only access your jobs at the backend\nif you are authenticated. The backend dropdown menu contains the available openEO backends from\nthe "),t("a",{attrs:{href:"https://hub.openeo.org/",target:"_blank",rel:"noopener noreferrer"}},[e._v("openEO Hub"),t("OutboundLink")],1),e._v('. By default, the plugin chooses the latest compatible version from the\nselected provider. If you want to connect to a specific version of a backend, you need to uncheck\nthe checkbox labeled "Only Latest versions". You can also manually type a backend url into the selection\nfield, in case it is not registered at our hub yet.')]),e._v(" "),t("p",[t("img",{attrs:{src:o(326),alt:"QGIS Login Dialog"}})]),e._v(" "),t("p",[e._v("Now that you have chosen a backend, you can log in with your username and password provided by the backend.\nNote that the QGIS plugin only supports Basic authentication and not "),t("a",{attrs:{href:"https://openid.net/connect/",target:"_blank",rel:"noopener noreferrer"}},[e._v("OpenID Connect"),t("OutboundLink")],1),e._v(" yet.\nBackends that do not support this authentication can not be accessed via this plugin at the moment.")]),e._v(" "),t("p",[e._v("If logged in successfully, the main window of the plugin appears with three tabs ("),t("strong",[e._v("Backend Info")]),e._v(", "),t("strong",[e._v("Jobs")]),e._v(", "),t("strong",[e._v("Services")]),e._v(").\nThe following sections will go through the capabilities of these tabs.")]),e._v(" "),t("h2",{attrs:{id:"exploring-a-backend"}},[t("a",{staticClass:"header-anchor",attrs:{href:"#exploring-a-backend"}},[e._v("#")]),e._v(" Exploring a backend")]),e._v(" "),t("p",[e._v("The first tab shows information about the backend and the available collections and processes.\nOn the top, there is a basic description about the backend you are connected to.\nNext, you can choose a collection in the drop down menu to see a description of that dataset.")]),e._v(" "),t("p",[t("img",{attrs:{src:o(327),alt:"QGIS Backend Info"}})]),e._v(" "),t("p",[e._v("On the bottom, you can use the drop down menu to choose one of the available processes from the backend.\nAfter selection, the parameters of the process are listed in the table below. The first column contains the\nparameter name, which is required if bold and otherwise optional.\nThe second column shows the type of the parameter (e.g. number) and the third column a short description.\nTo learn more about the process, you can click on the info button next to the drop down menu\n(marked red in the figure above). The return type of the process is written next to the info box. If you want to get an\noverview of all processes of openEO you might visit the "),t("RouterLink",{attrs:{to:"/documentation/1.0/processes.html"}},[e._v("official processes page")]),e._v(", but note that not all backends\nwill implement all processes listed there, whereas only available processes of the backend are in the QGIS plugin.")],1),e._v(" "),t("h2",{attrs:{id:"job-management"}},[t("a",{staticClass:"header-anchor",attrs:{href:"#job-management"}},[e._v("#")]),e._v(" Job Management")]),e._v(" "),t("p",[e._v('The "Jobs" tab lists all of your '),t("RouterLink",{attrs:{to:"/documentation/1.0/glossary.html#data-processing-modes"}},[e._v("jobs")]),e._v("\nat the backend. In openEO a job describes what the backend needs to process\n(e.g. by defining a "),t("RouterLink",{attrs:{to:"/documentation/1.0/glossary.html#processes"}},[e._v("process graph")]),e._v(") as well as\nadditional meta-information (e.g. title, creation date). The first two columns show the title and the creation date of\nthe job. The other elements of the table are numbered in the screenshot and described in the following.")],1),e._v(" "),t("p",[t("img",{attrs:{src:o(328),alt:"QGIS Jobs"}})]),e._v(" "),t("ol",[t("li",[t("strong",[e._v("Status")]),e._v(' - Shows the current lifecycle state of the job. The first status of a job is "created",\nif it got created at the backend, but not executed yet. After the job gets executed it will be\n"queued" if the backend plans to executes it, but has not started yet. If the execution started but hasn\'t finished yet,\nit has the status of "running". Last but not least it will have either "canceled", if it was stopped during execution,\n"finished" if the execution was successfully or "error", if an error occurred during execution.')]),e._v(" "),t("li",[t("strong",[e._v("Execute")]),e._v(' - By clicking on the "Play" button, the plugin will start the execution of the job at the backend.\nAlready finished jobs are executed again. The icon of the button will change if the job is in the "running" state,\nso that it looks like a "Stop" button, which will cancel the job execution.')]),e._v(" "),t("li",[t("strong",[e._v("Display")]),e._v(' - By clicking on the "Eye" button, the plugin downloads the resulting image(s) of the job from the backend\nand creates a new layer in QGIS named after the title and the creation date of the image. Note that if the result\nis not geo referenced, you might get a dialog from QGIS to choose a coordinate reference system, therefore it is\nrecommended to choose GeoTiff as job output format if available at the backend.')]),e._v(" "),t("li",[t("strong",[e._v("Save")]),e._v(' - By clicking on the "Download" button, you can navigate to the folder where you want to store the\nresulting image(s) of the job and the plugin will download it there.')]),e._v(" "),t("li",[t("strong",[e._v("Adapt")]),e._v(' - By clicking on the "Pencil" button a new dialog appears, where you can adapt the job title and\ndescription as well as the processes and extent of the job. How this works in detail is described in the following sections.')]),e._v(" "),t("li",[t("strong",[e._v("Information")]),e._v(' - By clicking on the "Info" button a window with additional information about the job appears.\nIt contains information like a description, a cost plan etc., of course only if this information is provided by the\nbackend. If the backend provides a logging output, it is also part of this info window.')]),e._v(" "),t("li",[t("strong",[e._v("Delete")]),e._v(' - By clicking on the "Trash" button the job gets deleted from the backend, after being asked if you are\nreally sure about it.')]),e._v(" "),t("li",[t("strong",[e._v("Load Job from openEO Hub")]),e._v(" - At the moment it is recommended to not use this feature, since the exchange of\nprocess graphs in the OpenEO Hub is under development.")]),e._v(" "),t("li",[t("strong",[e._v("Create new Job in Web Editor")]),e._v(" - This button opens the "),t("a",{attrs:{href:"https://editor.openeo.org/",target:"_blank",rel:"noopener noreferrer"}},[e._v("openEO web editor"),t("OutboundLink")],1),e._v(" in your\nsystem browser, so that you can create a new job using it. This is the recommended way for creating a new job, since it has\na graphical and therefore more convenient way of doing so.")]),e._v(" "),t("li",[t("strong",[e._v("Create new Job")]),e._v(" - You can create a job from scratch using this button.\nMore information in the next sections.")]),e._v(" "),t("li",[t("strong",[e._v("Refresh Table")]),e._v(" - This button refreshes the list of jobs manually, in general the list will refresh every few\nseconds. If you do not want to automatically refresh the list (it might cause some lags if the connection to the\nbackend is low) you can do so by deactivating the checkbox next to the refresh button.")]),e._v(" "),t("li",[t("strong",[e._v("User Manual")]),e._v(" - This button opens your browser with this introduction page.")])]),e._v(" "),t("h3",{attrs:{id:"creating-new-jobs"}},[t("a",{staticClass:"header-anchor",attrs:{href:"#creating-new-jobs"}},[e._v("#")]),e._v(" Creating new Jobs")]),e._v(" "),t("p",[e._v("There are three approaches to create a new job using this plugin, depending on whether you want to start from scratch or just\nchange existing jobs:")]),e._v(" "),t("ul",[t("li",[t("strong",[e._v("From scratch with web editor")]),e._v(" - As described in the job table overview above, there is a button (no. 9) that opens\nyour web browser with the "),t("a",{attrs:{href:"https://editor.openeo.org/",target:"_blank",rel:"noopener noreferrer"}},[e._v("openEO web editor"),t("OutboundLink")],1),e._v(". It is the recommended way to create a new job\nfrom scratch, since it has a very convenient graphical user interface. It also shows the process graph in a neat graph\nbased manner for a better understanding of how processes are connected.")]),e._v(" "),t("li",[t("strong",[e._v("From scratch with QGIS")]),e._v(' - If you want to use the QGIS plugin, you can create a new job using the\nbutton (no. 10) of the job overview dialog. It opens the job adaption window (more details in the section below).\nIn the beginning the job has already a "load_collection" process as a starting point.')]),e._v(" "),t("li",[t("strong",[e._v("From existing Job")]),e._v(" - You can create a new job by adapting\none of your existing jobs at the backend. You can e.g. create a new job with a different spatial extent, or\nadding a few processes to the original one. To do so, you need to click on the edit button in the job overview window (no. 5)")])]),e._v(" "),t("h3",{attrs:{id:"adapting-existing-jobs"}},[t("a",{staticClass:"header-anchor",attrs:{href:"#adapting-existing-jobs"}},[e._v("#")]),e._v(" Adapting existing Jobs")]),e._v(" "),t("p",[e._v("In this section you'll get an overview of the job adaption workflow using the job adaption window.\nHow you get there was described in the previous section.")]),e._v(" "),t("p",[t("img",{attrs:{src:o(329),alt:"QGIS Adapting Job"}})]),e._v(" "),t("ol",[t("li",[t("strong",[e._v("Job Title")]),e._v(" - Here you can write the title of the job. It is recommended to choose it in a way that\nmakes you identify the job in a list more easily.")]),e._v(" "),t("li",[t("strong",[e._v("Job Description")]),e._v(" - You can describe the job in more detail in this field (e.g. what is calculated and how).")]),e._v(" "),t("li",[t("strong",[e._v("Process Graph Table")]),e._v(" - In the process graph table you can see a list of all processes used by the job.\nThe first column contains the identifier of the process node, so a unique identifier of the process throughout the\nwhole process graph (e.g. loadcollection1). Most openEO clients generate these identifiers automatically. We define a\nprocess node (or just node) as one element of the process graph, so a single executed process."),t("br"),e._v('\nIn the second column you can see the name/identifier of the process (e.g. load_collection), which needs to be one of the\nprocesses that the backend provides. The third column shows the node identifier of the predecessor node.\nFor example, "loadcollection1" in the second row means that the output of the node with id "loadcollection1" is the input\nof the node with id "reducedimension1". In other words the process of the second row uses the output of the process of\nthe first row and is therefore executed after the first process.')]),e._v(" "),t("li",[t("strong",[e._v("Process Edit")]),e._v(' - When pressing on the "pencil" button, the process of the same row is loaded into the process\ntable on the right (see no. 6). On this table you can adapt the arguments of the chosen process and therefore configure\nits behaviour.')]),e._v(" "),t("li",[t("strong",[e._v("Delete Process")]),e._v(' - Clicking on the "trash" button deletes the selected process from the process graph.\nNote that other processes, which have this process as predecessor might fail after the deletion.')]),e._v(" "),t("li",[t("strong",[e._v("Undo Changes")]),e._v(" - Press this button if you want to undo all your changes on the job.")]),e._v(" "),t("li",[t("strong",[e._v("Raw Graph")]),e._v(' - Press this button to see the raw process graph (JSON format) in a pop up window. Changes to the\nprocess graph are also applied if you click "Apply". Therefore, you can also copy and paste here a complete process graph'),t("br"),e._v("\ninto the QGIS plugin.")]),e._v(" "),t("li",[t("strong",[e._v("Add Process")]),e._v(' - If you want to add a new process to the process graph you can select one at the drop down menu\n(see "Select a process") and press the button labeled "Add Process". The text field on the right will be the new node id\nand it is autogenerated after selecting a process, but can also be manually defined by typing it into the text field. Note\nthat it has to be unique within the job, otherwise the plugin shows an error message.\nOnce added, the id can not be modified.')]),e._v(" "),t("li",[t("strong",[e._v("Process Table")]),e._v(" - In this table you see all arguments of the currently selected process, the expected type and\nthe current value. If the name of the argument is bold, it is a required argument, hence it must be set.\nYou can edit the values of the arguments directly in the text field of the value column. For some arguments the plugin\nprovides helper function in the fourth column of the process table (e.g. drop down menu of all available collections in\nthe first row)")]),e._v(" "),t("li",[t("strong",[e._v("Process Argument Helper")]),e._v(" - For some arguments of a process, the QGIS Plugin provides helper functions to make the\nadaption of the arguments easier. This is the case, if the field of the fourth column in the process table is\nnot empty.")]),e._v(" "),t("li",[t("strong",[e._v("Result Process")]),e._v(' - This checkbox needs to be checked on the last process of the process graph. It tells the\nbackend that the result of the checked process is the output of the job (usually a "save_result" process). Note that\nonly one process of the process graph can be a result node. If you create a sub process graph in the process graph\n(e.g. when using apply or reduce), it also needs to have exactly one resulting process.')]),e._v(" "),t("li",[t("strong",[e._v("Clone Process")]),e._v(' - When clicking on this button, a clone of the currently selected node gets created and loaded\ninto the process table on the right. Note that clicking on this button does not add it to the job already, so you need to\npress on the "Add Process" button to do so.')]),e._v(" "),t("li",[t("strong",[e._v("Save Process")]),e._v(" - Changes on the process arguments are not stored in the process graph until this button is pressed.\nYou can see if there are unsaved changes if this button is enabled, otherwise it is disabled (see screenshot).")]),e._v(" "),t("li",[t("strong",[e._v("Manage Job")]),e._v(' - In this section of the adaption dialog, there are three options to handle changes on the job.\nFirst, by pressing on "Adapt Job" the selected job will be adapted to the changes you did and no new job will be created.\nSecond, by pressing on "Create New Job" a new job will be created at the backend, so if you have selected a job before\nfor the adaption, it will stay unchanged and your changes will just be applied to the newly created job.\nThird, the "Cancel" button closes the job adaption dialog with your changes having no effect. The same behaviour applies\nby closing the dialog.')])]),e._v(" "),t("h4",{attrs:{id:"process-argument-helper"}},[t("a",{staticClass:"header-anchor",attrs:{href:"#process-argument-helper"}},[e._v("#")]),e._v(" Process Argument Helper")]),e._v(" "),t("p",[e._v("For some process arguments the QGIS plugin provides helper functions for a more convenient editing.\nThis section provides a list of the available helper functions and how to use them:")]),e._v(" "),t("ul",[t("li",[t("strong",[e._v("Collection Id")]),e._v(' - Whenever an argument expects a collection id (e.g. "load_collection" process), the plugin shows a\ndrop down menu with all available collections of the backend. There you can select one and it will be put into the\narguments value.')]),e._v(" "),t("li",[t("strong",[e._v("Spatial Extent")]),e._v(" - Edit buttons of arguments which expect a spatial extent (e.g. geojson, bounding-box) open a\nspatial extent dialog:")])]),e._v(" "),t("p",[t("img",{attrs:{src:o(330),alt:"QGIS Edit spatial extent"}})]),e._v(" "),t("p",[e._v('On the bottom you can edit the spatial extent manually in the text box. In the drop down menu on the top you can choose\nhow to select the spatial extent. You can get the extent of the current layer, the extent of a shape file, the extent of\nthe current QGIS map canvas, by drawing a rectangle on the QGIS map canvas or by drawing a polygon on the QGIS map\ncanvas. The drawings start after clicking on the "Draw Extent" button, so that your curser becomes a cross to draw on\nthe map. After pressing the "OK" button, the extent string in the text field is set to the process argument and the\nwindow closes.')]),e._v(" "),t("ul",[t("li",[t("strong",[e._v("Temporal Extent")]),e._v(" - If an argument expects a start and end date, the edit button opens a calendar dialog:")])]),e._v(" "),t("p",[t("img",{attrs:{src:o(331),alt:"QGIS Edit temporal extent"}})]),e._v(" "),t("p",[e._v("The left calendar sets the start date and the right calendar the end date.")]),e._v(" "),t("ul",[t("li",[t("strong",[e._v("Band selection")]),e._v(" - If an argument expects a selection of bands, the edit button opens the following dialog to choose\nfrom the bands available at the selected collection. Note that it always lists all bands of the collection even if some\nbands are filtered by previous processes and therefore not available in the datacube anymore.")])]),e._v(" "),t("p",[t("img",{attrs:{src:o(332),alt:"QGIS Edit band selection"}})]),e._v(" "),t("ul",[t("li",[t("strong",[e._v("Process Graph Node")]),e._v(' - If an argument expects a raster data cube, a drop down menu will appear on the edit column.\nThere you can choose from existing process graph nodes (e.g. "loadcollection1") It uses the output of the given node\nidentifier as input of the process argument.')]),e._v(" "),t("li",[t("strong",[e._v("Sub Process Graph")]),e._v(" - Some processes need a whole (sub-)process graph as input value (e.g. apply or reduce\nprocesses). When clicking on the edit button, the plugin opens a new adaption window, which looks similar to the job\nadaption window, but shows the sub process graph:")])]),e._v(" "),t("p",[t("img",{attrs:{src:o(333),alt:"QGIS Edit sub process graph"}})]),e._v(" "),t("p",[e._v('In this window you can adapt the sub process graph in the same way as the original process graph. After pressing on\n"Adapt", the changes are written to the original job. Process arguments, which do not have special editing fields,\nhave a "Proc-Param" button. If pressed it will forward the input data of the parent node\n(so the one with the subgraph as attribute) to the selected argument (see screenshot "data" argument). Note that the\nsub process graph also needs to have at least one result node.')]),e._v(" "),t("h2",{attrs:{id:"service-management"}},[t("a",{staticClass:"header-anchor",attrs:{href:"#service-management"}},[e._v("#")]),e._v(" Service Management")]),e._v(" "),t("p",[e._v('The "Services" tab lists all of your '),t("RouterLink",{attrs:{to:"/documentation/1.0/glossary.html#data-processing-modes"}},[e._v("secondary web services")]),e._v("\nat the backend. In openEO a secondary service has a process graph like a job, but depending on the service type it is\npossible for the user to change the viewing extent dynamically. The first two columns shows the title, the description\nand the date and time it got created at the backend.\nThe other elements of this window are numbered at the screenshot below and described in the following.")],1),e._v(" "),t("p",[t("img",{attrs:{src:o(334),alt:"QGIS Services"}})]),e._v(" "),t("ol",[t("li",[t("strong",[e._v("Display")]),e._v(' - When clicking on the "Eye", the secondary service gets loaded into a new QGIS layer, named after the\nservice. QGIS now fetches the result of the processing into the current extent of the QGIS map canvas. Note that it will\nload the whole screen at once, so it might take a while.')]),e._v(" "),t("li",[t("strong",[e._v("Information")]),e._v(" - Clicking on the Infobox, shows detailed information about the service.")]),e._v(" "),t("li",[t("strong",[e._v("Delete")]),e._v(" - Clicking on the delete button removes the service from the backend.")]),e._v(" "),t("li",[t("strong",[e._v("Create from job")]),e._v(' - By clicking on this button you can create a new service from one of your jobs. It will create a\nservice with the same process graph as the selected job, but the extent will be dynamically loaded via the service. By\nclicking on the button a new dialog pops up. On the creation dialog you can set a title and a description text, but note\nthat they are optional. Nevertheless, you have to select a job and choose a type of secondary service. The drop down\nmenu of the service types contains only the ones supported by your backend. By clicking on "Create Service" the\nplugin creates the service on the backend, so you should be able to see it on the table. Note that the list of jobs\ncontains only successfully executed jobs (e.g. with "finished" status). By clicking on "Raw Graph"\n'),t("img",{attrs:{src:o(335),alt:"QGIS Create Services from job"}})]),e._v(" "),t("li",[t("strong",[e._v("Create from web editor")]),e._v(" - Similarly to the job table overview, this button opens your web browser with\nthe "),t("a",{attrs:{href:"https://editor.openeo.org/",target:"_blank",rel:"noopener noreferrer"}},[e._v("openEO web editor"),t("OutboundLink")],1),e._v(". There you can create new services via the editor or from your jobs.")]),e._v(" "),t("li",[t("strong",[e._v("Refresh Table")]),e._v(" - Similar to the jobs table, this button refreshes the list of services manually, in general the list will refresh every few\nseconds. If you do not want to automatically refresh the list (it might cause some lags if the connection to the\nbackend is low) you can do so by deactivating the checkbox next to the refresh button.")]),e._v(" "),t("li",[t("strong",[e._v("Create from web editor")]),e._v(" - This button opens your browser with this introduction page.")])]),e._v(" "),t("h2",{attrs:{id:"additional-information"}},[t("a",{staticClass:"header-anchor",attrs:{href:"#additional-information"}},[e._v("#")]),e._v(" Additional Information")]),e._v(" "),t("ul",[t("li",[t("a",{attrs:{href:"https://github.com/Open-EO/openeo-qgis-plugin",target:"_blank",rel:"noopener noreferrer"}},[e._v("Github Repository"),t("OutboundLink")],1)]),e._v(" "),t("li",[t("a",{attrs:{href:"https://plugins.qgis.org/plugins/openeo-qgis-plugin-master/",target:"_blank",rel:"noopener noreferrer"}},[e._v("QGIS Plugin Page"),t("OutboundLink")],1)])])])}),[],!1,null,null,null);t.default=a.exports}}]); \ No newline at end of file +(window.webpackJsonp=window.webpackJsonp||[]).push([[15],{325:function(e,t,o){e.exports=o.p+"assets/img/qgis_button.2b5f39a5.png"},326:function(e,t,o){e.exports=o.p+"assets/img/login_dialog.424c4b4e.png"},327:function(e,t,o){e.exports=o.p+"assets/img/backend_info.a00e7a1d.png"},328:function(e,t,o){e.exports=o.p+"assets/img/jobs.fef9e692.png"},329:function(e,t,o){e.exports=o.p+"assets/img/adapt_job.64ea4b55.png"},330:function(e,t,o){e.exports=o.p+"assets/img/edit_spatial.23df03fa.png"},331:function(e,t,o){e.exports=o.p+"assets/img/edit_temporal.609c87e2.png"},332:function(e,t,o){e.exports=o.p+"assets/img/edit_bands.d9ed77a5.png"},333:function(e,t,o){e.exports=o.p+"assets/img/edit_subpg.c7fbfd4d.png"},334:function(e,t,o){e.exports=o.p+"assets/img/services.a958fd61.png"},335:function(e,t,o){e.exports=o.p+"assets/img/services_create.0881f2cd.png"},532:function(e,t,o){"use strict";o.r(t);var n=o(4),a=Object(n.a)({},(function(){var e=this,t=e._self._c;return t("ContentSlotsDistributor",{attrs:{"slot-key":e.$parent.slotKey}},[t("h1",{attrs:{id:"qgis-plugin"}},[t("a",{staticClass:"header-anchor",attrs:{href:"#qgis-plugin"}},[e._v("#")]),e._v(" QGIS Plugin")]),e._v(" "),t("p",[e._v("The openEO QGIS plugin enables exploring openEO backends as well as execute and modify your jobs at an backend\nwithin QGIS. The plugin can load the results of a job execution to the QGIS map, so that the user can make further\nanalyses and visualisation steps.")]),e._v(" "),t("h2",{attrs:{id:"installation"}},[t("a",{staticClass:"header-anchor",attrs:{href:"#installation"}},[e._v("#")]),e._v(" Installation")]),e._v(" "),t("p",[e._v("There are two different versions of the QGIS Plugin available:")]),e._v(" "),t("ol",[t("li",[e._v("The "),t("strong",[e._v("latest stable version")]),e._v(' is accessible in the plugin\nmanager of QGIS (Plugins -> Manage and Install Plugins). Note that you have to activate the option to show experimental\nplugins (Settings -> Show also experimental plugins). After that, you can search for\n"OpenEO", install and activate the plugin.')]),e._v(" "),t("li",[e._v("The "),t("strong",[e._v("latest version")]),e._v(" is accessible at the\n"),t("a",{attrs:{href:"https://github.com/Open-EO/openeo-qgis-plugin",target:"_blank",rel:"noopener noreferrer"}},[e._v("GitHub repository"),t("OutboundLink")],1),e._v('. First, download the repository as zip archive.\nNow, open the plugin manager of QGIS (Plugins -> Manage and Install Plugins) and select "Install from ZIP".\nThere you can browse for the downloaded zip archive, install and activate it.')])]),e._v(" "),t("p",[e._v("This tutorial shows the capabilities of version 0.9.2. Make sure you have installed at least that version by checking in\nthe plugin manager.")]),e._v(" "),t("p",[e._v("After successfully installing and activating the plugin, the openEO logo should be part of the toolbar:")]),e._v(" "),t("p",[t("img",{attrs:{src:o(325),alt:"QGIS Plugin Icon"}})]),e._v(" "),t("p",[e._v("Simply click on the icon to start the plugin.")]),e._v(" "),t("h2",{attrs:{id:"connecting"}},[t("a",{staticClass:"header-anchor",attrs:{href:"#connecting"}},[e._v("#")]),e._v(" Connecting")]),e._v(" "),t("p",[e._v("The first window you see when starting the plugin is a login dialog, since you can only access your jobs at the backend\nif you are authenticated. The backend dropdown menu contains the available openEO backends from\nthe "),t("a",{attrs:{href:"https://hub.openeo.org/",target:"_blank",rel:"noopener noreferrer"}},[e._v("openEO Hub"),t("OutboundLink")],1),e._v('. By default, the plugin chooses the latest compatible version from the\nselected provider. If you want to connect to a specific version of a backend, you need to uncheck\nthe checkbox labeled "Only Latest versions". You can also manually type a backend url into the selection\nfield, in case it is not registered at our hub yet.')]),e._v(" "),t("p",[t("img",{attrs:{src:o(326),alt:"QGIS Login Dialog"}})]),e._v(" "),t("p",[e._v("Now that you have chosen a backend, you can log in with your username and password provided by the backend.\nNote that the QGIS plugin only supports Basic authentication and not "),t("a",{attrs:{href:"https://openid.net/connect/",target:"_blank",rel:"noopener noreferrer"}},[e._v("OpenID Connect"),t("OutboundLink")],1),e._v(" yet.\nBackends that do not support this authentication can not be accessed via this plugin at the moment.")]),e._v(" "),t("p",[e._v("If logged in successfully, the main window of the plugin appears with three tabs ("),t("strong",[e._v("Backend Info")]),e._v(", "),t("strong",[e._v("Jobs")]),e._v(", "),t("strong",[e._v("Services")]),e._v(").\nThe following sections will go through the capabilities of these tabs.")]),e._v(" "),t("h2",{attrs:{id:"exploring-a-backend"}},[t("a",{staticClass:"header-anchor",attrs:{href:"#exploring-a-backend"}},[e._v("#")]),e._v(" Exploring a backend")]),e._v(" "),t("p",[e._v("The first tab shows information about the backend and the available collections and processes.\nOn the top, there is a basic description about the backend you are connected to.\nNext, you can choose a collection in the drop down menu to see a description of that dataset.")]),e._v(" "),t("p",[t("img",{attrs:{src:o(327),alt:"QGIS Backend Info"}})]),e._v(" "),t("p",[e._v("On the bottom, you can use the drop down menu to choose one of the available processes from the backend.\nAfter selection, the parameters of the process are listed in the table below. The first column contains the\nparameter name, which is required if bold and otherwise optional.\nThe second column shows the type of the parameter (e.g. number) and the third column a short description.\nTo learn more about the process, you can click on the info button next to the drop down menu\n(marked red in the figure above). The return type of the process is written next to the info box. If you want to get an\noverview of all processes of openEO you might visit the "),t("RouterLink",{attrs:{to:"/documentation/1.0/processes.html"}},[e._v("official processes page")]),e._v(", but note that not all backends\nwill implement all processes listed there, whereas only available processes of the backend are in the QGIS plugin.")],1),e._v(" "),t("h2",{attrs:{id:"job-management"}},[t("a",{staticClass:"header-anchor",attrs:{href:"#job-management"}},[e._v("#")]),e._v(" Job Management")]),e._v(" "),t("p",[e._v('The "Jobs" tab lists all of your '),t("RouterLink",{attrs:{to:"/documentation/1.0/glossary.html#data-processing-modes"}},[e._v("jobs")]),e._v("\nat the backend. In openEO a job describes what the backend needs to process\n(e.g. by defining a "),t("RouterLink",{attrs:{to:"/documentation/1.0/glossary.html#processes"}},[e._v("process graph")]),e._v(") as well as\nadditional meta-information (e.g. title, creation date). The first two columns show the title and the creation date of\nthe job. The other elements of the table are numbered in the screenshot and described in the following.")],1),e._v(" "),t("p",[t("img",{attrs:{src:o(328),alt:"QGIS Jobs"}})]),e._v(" "),t("ol",[t("li",[t("strong",[e._v("Status")]),e._v(' - Shows the current lifecycle state of the job. The first status of a job is "created",\nif it got created at the backend, but not executed yet. After the job gets executed it will be\n"queued" if the backend plans to executes it, but has not started yet. If the execution started but hasn\'t finished yet,\nit has the status of "running". Last but not least it will have either "canceled", if it was stopped during execution,\n"finished" if the execution was successfully or "error", if an error occurred during execution.')]),e._v(" "),t("li",[t("strong",[e._v("Execute")]),e._v(' - By clicking on the "Play" button, the plugin will start the execution of the job at the backend.\nAlready finished jobs are executed again. The icon of the button will change if the job is in the "running" state,\nso that it looks like a "Stop" button, which will cancel the job execution.')]),e._v(" "),t("li",[t("strong",[e._v("Display")]),e._v(' - By clicking on the "Eye" button, the plugin downloads the resulting image(s) of the job from the backend\nand creates a new layer in QGIS named after the title and the creation date of the image. Note that if the result\nis not geo referenced, you might get a dialog from QGIS to choose a coordinate reference system, therefore it is\nrecommended to choose GeoTiff as job output format if available at the backend.')]),e._v(" "),t("li",[t("strong",[e._v("Save")]),e._v(' - By clicking on the "Download" button, you can navigate to the folder where you want to store the\nresulting image(s) of the job and the plugin will download it there.')]),e._v(" "),t("li",[t("strong",[e._v("Adapt")]),e._v(' - By clicking on the "Pencil" button a new dialog appears, where you can adapt the job title and\ndescription as well as the processes and extent of the job. How this works in detail is described in the following sections.')]),e._v(" "),t("li",[t("strong",[e._v("Information")]),e._v(' - By clicking on the "Info" button a window with additional information about the job appears.\nIt contains information like a description, a cost plan etc., of course only if this information is provided by the\nbackend. If the backend provides a logging output, it is also part of this info window.')]),e._v(" "),t("li",[t("strong",[e._v("Delete")]),e._v(' - By clicking on the "Trash" button the job gets deleted from the backend, after being asked if you are\nreally sure about it.')]),e._v(" "),t("li",[t("strong",[e._v("Load Job from openEO Hub")]),e._v(" - At the moment it is recommended to not use this feature, since the exchange of\nprocess graphs in the OpenEO Hub is under development.")]),e._v(" "),t("li",[t("strong",[e._v("Create new Job in Web Editor")]),e._v(" - This button opens the "),t("a",{attrs:{href:"https://editor.openeo.org/",target:"_blank",rel:"noopener noreferrer"}},[e._v("openEO web editor"),t("OutboundLink")],1),e._v(" in your\nsystem browser, so that you can create a new job using it. This is the recommended way for creating a new job, since it has\na graphical and therefore more convenient way of doing so.")]),e._v(" "),t("li",[t("strong",[e._v("Create new Job")]),e._v(" - You can create a job from scratch using this button.\nMore information in the next sections.")]),e._v(" "),t("li",[t("strong",[e._v("Refresh Table")]),e._v(" - This button refreshes the list of jobs manually, in general the list will refresh every few\nseconds. If you do not want to automatically refresh the list (it might cause some lags if the connection to the\nbackend is low) you can do so by deactivating the checkbox next to the refresh button.")]),e._v(" "),t("li",[t("strong",[e._v("User Manual")]),e._v(" - This button opens your browser with this introduction page.")])]),e._v(" "),t("h3",{attrs:{id:"creating-new-jobs"}},[t("a",{staticClass:"header-anchor",attrs:{href:"#creating-new-jobs"}},[e._v("#")]),e._v(" Creating new Jobs")]),e._v(" "),t("p",[e._v("There are three approaches to create a new job using this plugin, depending on whether you want to start from scratch or just\nchange existing jobs:")]),e._v(" "),t("ul",[t("li",[t("strong",[e._v("From scratch with web editor")]),e._v(" - As described in the job table overview above, there is a button (no. 9) that opens\nyour web browser with the "),t("a",{attrs:{href:"https://editor.openeo.org/",target:"_blank",rel:"noopener noreferrer"}},[e._v("openEO web editor"),t("OutboundLink")],1),e._v(". It is the recommended way to create a new job\nfrom scratch, since it has a very convenient graphical user interface. It also shows the process graph in a neat graph\nbased manner for a better understanding of how processes are connected.")]),e._v(" "),t("li",[t("strong",[e._v("From scratch with QGIS")]),e._v(' - If you want to use the QGIS plugin, you can create a new job using the\nbutton (no. 10) of the job overview dialog. It opens the job adaption window (more details in the section below).\nIn the beginning the job has already a "load_collection" process as a starting point.')]),e._v(" "),t("li",[t("strong",[e._v("From existing Job")]),e._v(" - You can create a new job by adapting\none of your existing jobs at the backend. You can e.g. create a new job with a different spatial extent, or\nadding a few processes to the original one. To do so, you need to click on the edit button in the job overview window (no. 5)")])]),e._v(" "),t("h3",{attrs:{id:"adapting-existing-jobs"}},[t("a",{staticClass:"header-anchor",attrs:{href:"#adapting-existing-jobs"}},[e._v("#")]),e._v(" Adapting existing Jobs")]),e._v(" "),t("p",[e._v("In this section you'll get an overview of the job adaption workflow using the job adaption window.\nHow you get there was described in the previous section.")]),e._v(" "),t("p",[t("img",{attrs:{src:o(329),alt:"QGIS Adapting Job"}})]),e._v(" "),t("ol",[t("li",[t("strong",[e._v("Job Title")]),e._v(" - Here you can write the title of the job. It is recommended to choose it in a way that\nmakes you identify the job in a list more easily.")]),e._v(" "),t("li",[t("strong",[e._v("Job Description")]),e._v(" - You can describe the job in more detail in this field (e.g. what is calculated and how).")]),e._v(" "),t("li",[t("strong",[e._v("Process Graph Table")]),e._v(" - In the process graph table you can see a list of all processes used by the job.\nThe first column contains the identifier of the process node, so a unique identifier of the process throughout the\nwhole process graph (e.g. loadcollection1). Most openEO clients generate these identifiers automatically. We define a\nprocess node (or just node) as one element of the process graph, so a single executed process."),t("br"),e._v('\nIn the second column you can see the name/identifier of the process (e.g. load_collection), which needs to be one of the\nprocesses that the backend provides. The third column shows the node identifier of the predecessor node.\nFor example, "loadcollection1" in the second row means that the output of the node with id "loadcollection1" is the input\nof the node with id "reducedimension1". In other words the process of the second row uses the output of the process of\nthe first row and is therefore executed after the first process.')]),e._v(" "),t("li",[t("strong",[e._v("Process Edit")]),e._v(' - When pressing on the "pencil" button, the process of the same row is loaded into the process\ntable on the right (see no. 6). On this table you can adapt the arguments of the chosen process and therefore configure\nits behaviour.')]),e._v(" "),t("li",[t("strong",[e._v("Delete Process")]),e._v(' - Clicking on the "trash" button deletes the selected process from the process graph.\nNote that other processes, which have this process as predecessor might fail after the deletion.')]),e._v(" "),t("li",[t("strong",[e._v("Undo Changes")]),e._v(" - Press this button if you want to undo all your changes on the job.")]),e._v(" "),t("li",[t("strong",[e._v("Raw Graph")]),e._v(' - Press this button to see the raw process graph (JSON format) in a pop up window. Changes to the\nprocess graph are also applied if you click "Apply". Therefore, you can also copy and paste here a complete process graph'),t("br"),e._v("\ninto the QGIS plugin.")]),e._v(" "),t("li",[t("strong",[e._v("Add Process")]),e._v(' - If you want to add a new process to the process graph you can select one at the drop down menu\n(see "Select a process") and press the button labeled "Add Process". The text field on the right will be the new node id\nand it is autogenerated after selecting a process, but can also be manually defined by typing it into the text field. Note\nthat it has to be unique within the job, otherwise the plugin shows an error message.\nOnce added, the id can not be modified.')]),e._v(" "),t("li",[t("strong",[e._v("Process Table")]),e._v(" - In this table you see all arguments of the currently selected process, the expected type and\nthe current value. If the name of the argument is bold, it is a required argument, hence it must be set.\nYou can edit the values of the arguments directly in the text field of the value column. For some arguments the plugin\nprovides helper function in the fourth column of the process table (e.g. drop down menu of all available collections in\nthe first row)")]),e._v(" "),t("li",[t("strong",[e._v("Process Argument Helper")]),e._v(" - For some arguments of a process, the QGIS Plugin provides helper functions to make the\nadaption of the arguments easier. This is the case, if the field of the fourth column in the process table is\nnot empty.")]),e._v(" "),t("li",[t("strong",[e._v("Result Process")]),e._v(' - This checkbox needs to be checked on the last process of the process graph. It tells the\nbackend that the result of the checked process is the output of the job (usually a "save_result" process). Note that\nonly one process of the process graph can be a result node. If you create a sub process graph in the process graph\n(e.g. when using apply or reduce), it also needs to have exactly one resulting process.')]),e._v(" "),t("li",[t("strong",[e._v("Clone Process")]),e._v(' - When clicking on this button, a clone of the currently selected node gets created and loaded\ninto the process table on the right. Note that clicking on this button does not add it to the job already, so you need to\npress on the "Add Process" button to do so.')]),e._v(" "),t("li",[t("strong",[e._v("Save Process")]),e._v(" - Changes on the process arguments are not stored in the process graph until this button is pressed.\nYou can see if there are unsaved changes if this button is enabled, otherwise it is disabled (see screenshot).")]),e._v(" "),t("li",[t("strong",[e._v("Manage Job")]),e._v(' - In this section of the adaption dialog, there are three options to handle changes on the job.\nFirst, by pressing on "Adapt Job" the selected job will be adapted to the changes you did and no new job will be created.\nSecond, by pressing on "Create New Job" a new job will be created at the backend, so if you have selected a job before\nfor the adaption, it will stay unchanged and your changes will just be applied to the newly created job.\nThird, the "Cancel" button closes the job adaption dialog with your changes having no effect. The same behaviour applies\nby closing the dialog.')])]),e._v(" "),t("h4",{attrs:{id:"process-argument-helper"}},[t("a",{staticClass:"header-anchor",attrs:{href:"#process-argument-helper"}},[e._v("#")]),e._v(" Process Argument Helper")]),e._v(" "),t("p",[e._v("For some process arguments the QGIS plugin provides helper functions for a more convenient editing.\nThis section provides a list of the available helper functions and how to use them:")]),e._v(" "),t("ul",[t("li",[t("strong",[e._v("Collection Id")]),e._v(' - Whenever an argument expects a collection id (e.g. "load_collection" process), the plugin shows a\ndrop down menu with all available collections of the backend. There you can select one and it will be put into the\narguments value.')]),e._v(" "),t("li",[t("strong",[e._v("Spatial Extent")]),e._v(" - Edit buttons of arguments which expect a spatial extent (e.g. geojson, bounding-box) open a\nspatial extent dialog:")])]),e._v(" "),t("p",[t("img",{attrs:{src:o(330),alt:"QGIS Edit spatial extent"}})]),e._v(" "),t("p",[e._v('On the bottom you can edit the spatial extent manually in the text box. In the drop down menu on the top you can choose\nhow to select the spatial extent. You can get the extent of the current layer, the extent of a shape file, the extent of\nthe current QGIS map canvas, by drawing a rectangle on the QGIS map canvas or by drawing a polygon on the QGIS map\ncanvas. The drawings start after clicking on the "Draw Extent" button, so that your curser becomes a cross to draw on\nthe map. After pressing the "OK" button, the extent string in the text field is set to the process argument and the\nwindow closes.')]),e._v(" "),t("ul",[t("li",[t("strong",[e._v("Temporal Extent")]),e._v(" - If an argument expects a start and end date, the edit button opens a calendar dialog:")])]),e._v(" "),t("p",[t("img",{attrs:{src:o(331),alt:"QGIS Edit temporal extent"}})]),e._v(" "),t("p",[e._v("The left calendar sets the start date and the right calendar the end date.")]),e._v(" "),t("ul",[t("li",[t("strong",[e._v("Band selection")]),e._v(" - If an argument expects a selection of bands, the edit button opens the following dialog to choose\nfrom the bands available at the selected collection. Note that it always lists all bands of the collection even if some\nbands are filtered by previous processes and therefore not available in the datacube anymore.")])]),e._v(" "),t("p",[t("img",{attrs:{src:o(332),alt:"QGIS Edit band selection"}})]),e._v(" "),t("ul",[t("li",[t("strong",[e._v("Process Graph Node")]),e._v(' - If an argument expects a raster data cube, a drop down menu will appear on the edit column.\nThere you can choose from existing process graph nodes (e.g. "loadcollection1") It uses the output of the given node\nidentifier as input of the process argument.')]),e._v(" "),t("li",[t("strong",[e._v("Sub Process Graph")]),e._v(" - Some processes need a whole (sub-)process graph as input value (e.g. apply or reduce\nprocesses). When clicking on the edit button, the plugin opens a new adaption window, which looks similar to the job\nadaption window, but shows the sub process graph:")])]),e._v(" "),t("p",[t("img",{attrs:{src:o(333),alt:"QGIS Edit sub process graph"}})]),e._v(" "),t("p",[e._v('In this window you can adapt the sub process graph in the same way as the original process graph. After pressing on\n"Adapt", the changes are written to the original job. Process arguments, which do not have special editing fields,\nhave a "Proc-Param" button. If pressed it will forward the input data of the parent node\n(so the one with the subgraph as attribute) to the selected argument (see screenshot "data" argument). Note that the\nsub process graph also needs to have at least one result node.')]),e._v(" "),t("h2",{attrs:{id:"service-management"}},[t("a",{staticClass:"header-anchor",attrs:{href:"#service-management"}},[e._v("#")]),e._v(" Service Management")]),e._v(" "),t("p",[e._v('The "Services" tab lists all of your '),t("RouterLink",{attrs:{to:"/documentation/1.0/glossary.html#data-processing-modes"}},[e._v("secondary web services")]),e._v("\nat the backend. In openEO a secondary service has a process graph like a job, but depending on the service type it is\npossible for the user to change the viewing extent dynamically. The first two columns shows the title, the description\nand the date and time it got created at the backend.\nThe other elements of this window are numbered at the screenshot below and described in the following.")],1),e._v(" "),t("p",[t("img",{attrs:{src:o(334),alt:"QGIS Services"}})]),e._v(" "),t("ol",[t("li",[t("strong",[e._v("Display")]),e._v(' - When clicking on the "Eye", the secondary service gets loaded into a new QGIS layer, named after the\nservice. QGIS now fetches the result of the processing into the current extent of the QGIS map canvas. Note that it will\nload the whole screen at once, so it might take a while.')]),e._v(" "),t("li",[t("strong",[e._v("Information")]),e._v(" - Clicking on the Infobox, shows detailed information about the service.")]),e._v(" "),t("li",[t("strong",[e._v("Delete")]),e._v(" - Clicking on the delete button removes the service from the backend.")]),e._v(" "),t("li",[t("strong",[e._v("Create from job")]),e._v(' - By clicking on this button you can create a new service from one of your jobs. It will create a\nservice with the same process graph as the selected job, but the extent will be dynamically loaded via the service. By\nclicking on the button a new dialog pops up. On the creation dialog you can set a title and a description text, but note\nthat they are optional. Nevertheless, you have to select a job and choose a type of secondary service. The drop down\nmenu of the service types contains only the ones supported by your backend. By clicking on "Create Service" the\nplugin creates the service on the backend, so you should be able to see it on the table. Note that the list of jobs\ncontains only successfully executed jobs (e.g. with "finished" status). By clicking on "Raw Graph"\n'),t("img",{attrs:{src:o(335),alt:"QGIS Create Services from job"}})]),e._v(" "),t("li",[t("strong",[e._v("Create from web editor")]),e._v(" - Similarly to the job table overview, this button opens your web browser with\nthe "),t("a",{attrs:{href:"https://editor.openeo.org/",target:"_blank",rel:"noopener noreferrer"}},[e._v("openEO web editor"),t("OutboundLink")],1),e._v(". There you can create new services via the editor or from your jobs.")]),e._v(" "),t("li",[t("strong",[e._v("Refresh Table")]),e._v(" - Similar to the jobs table, this button refreshes the list of services manually, in general the list will refresh every few\nseconds. If you do not want to automatically refresh the list (it might cause some lags if the connection to the\nbackend is low) you can do so by deactivating the checkbox next to the refresh button.")]),e._v(" "),t("li",[t("strong",[e._v("Create from web editor")]),e._v(" - This button opens your browser with this introduction page.")])]),e._v(" "),t("h2",{attrs:{id:"additional-information"}},[t("a",{staticClass:"header-anchor",attrs:{href:"#additional-information"}},[e._v("#")]),e._v(" Additional Information")]),e._v(" "),t("ul",[t("li",[t("a",{attrs:{href:"https://github.com/Open-EO/openeo-qgis-plugin",target:"_blank",rel:"noopener noreferrer"}},[e._v("Github Repository"),t("OutboundLink")],1)]),e._v(" "),t("li",[t("a",{attrs:{href:"https://plugins.qgis.org/plugins/openeo-qgis-plugin-master/",target:"_blank",rel:"noopener noreferrer"}},[e._v("QGIS Plugin Page"),t("OutboundLink")],1)])])])}),[],!1,null,null,null);t.default=a.exports}}]); \ No newline at end of file diff --git a/assets/js/18.131835dc.js b/assets/js/18.2f2caa18.js similarity index 99% rename from assets/js/18.131835dc.js rename to assets/js/18.2f2caa18.js index d02a97994..193b22f22 100644 --- a/assets/js/18.131835dc.js +++ b/assets/js/18.2f2caa18.js @@ -1 +1 @@ -(window.webpackJsonp=window.webpackJsonp||[]).push([[18],{315:function(t,s,a){t.exports=a.p+"assets/img/urk_scaling.1f27c164.jpg"},316:function(t,s,a){t.exports=a.p+"assets/img/urk.e6564348.jpg"},317:function(t,s,a){t.exports=a.p+"assets/img/pellworm_248.29ad280d.jpg"},318:function(t,s,a){t.exports=a.p+"assets/img/pellworm_ndvi.36c775d8.jpg"},319:function(t,s,a){t.exports=a.p+"assets/img/pellworm_threshold.be97c121.jpg"},320:function(t,s,a){t.exports=a.p+"assets/img/pellworm_s1.acf74ce7.jpg"},321:function(t,s,a){t.exports=a.p+"assets/img/pellworm_kernels.d12dda41.jpg"},515:function(t,s,a){"use strict";a.r(s);var n=a(4),e=Object(n.a)({},(function(){var t=this,s=t._self._c;return s("ContentSlotsDistributor",{attrs:{"slot-key":t.$parent.slotKey}},[s("h1",{attrs:{id:"openeo-cookbook"}},[s("a",{staticClass:"header-anchor",attrs:{href:"#openeo-cookbook"}},[t._v("#")]),t._v(" openEO Cookbook")]),t._v(" "),s("p",[t._v("This is the openEO cookbook that you can refer to to get a first idea on how to solve problems with openEO in the three client languages Python, R and JavaScript. It describes how to implement simple use cases in a pragmatic way.")]),t._v(" "),s("p",[t._v("Please refer to the getting started guides for "),s("RouterLink",{attrs:{to:"/documentation/1.0/javascript/"}},[t._v("JavaScript")]),t._v(", "),s("RouterLink",{attrs:{to:"/documentation/1.0/python/"}},[t._v("Python")]),t._v(" and "),s("RouterLink",{attrs:{to:"/documentation/1.0/r/"}},[t._v("R")]),t._v(" if you have never worked with one of the openEO client libraries before. This guide requires you to have a basic idea of how to establish a connection to a back-end and how to explore that back-end.")],1),t._v(" "),s("div",{staticClass:"custom-block tip"},[s("p",{staticClass:"custom-block-title"},[t._v("References")]),t._v(" "),s("ul",[s("li",[s("RouterLink",{attrs:{to:"/documentation/1.0/processes.html"}},[t._v("openEO processes documentation")])],1),t._v(" "),s("li",[s("a",{attrs:{href:"https://hub.openeo.org",target:"_blank",rel:"noopener noreferrer"}},[t._v("openEO Hub"),s("OutboundLink")],1),t._v(" to discover back-ends with available data and processes")]),t._v(" "),s("li",[s("a",{attrs:{href:"https://editor.openeo.org",target:"_blank",rel:"noopener noreferrer"}},[t._v("openEO Web Editor"),s("OutboundLink")],1),t._v(" to visually build and execute processing workflows")])]),t._v(" "),s("hr"),t._v(" "),s("ul",[s("li",[s("a",{attrs:{href:"https://open-eo.github.io/openeo-python-client/index.html",target:"_blank",rel:"noopener noreferrer"}},[t._v("Python client documentation"),s("OutboundLink")],1)]),t._v(" "),s("li",[s("a",{attrs:{href:"https://open-eo.github.io/openeo-js-client/latest/index.html",target:"_blank",rel:"noopener noreferrer"}},[t._v("JavaScript client documentation"),s("OutboundLink")],1)]),t._v(" "),s("li",[s("a",{attrs:{href:"https://open-eo.github.io/openeo-r-client/index.html",target:"_blank",rel:"noopener noreferrer"}},[t._v("R client documentation"),s("OutboundLink")],1)])])]),t._v(" "),s("h2",{attrs:{id:"chapter-1"}},[s("a",{staticClass:"header-anchor",attrs:{href:"#chapter-1"}},[t._v("#")]),t._v(" Chapter 1")]),t._v(" "),s("p",[t._v("In this chapter, we want to explore the different output formats that are possible with openEO. For that, we load and filter a collection (a datacube) of satellite data and calculate the temporal mean of that data. Different steps (e.g. a linear scaling) are done to prepare for the data to be output in one of the formats: Raster or text data.")]),t._v(" "),s("p",[t._v("Throughout this guide, code examples for all three client languages are given. Select your preferred language with the code switcher on the right-hand side to set all examples to that language.")]),t._v(" "),s("h3",{attrs:{id:"connecting-to-a-back-end"}},[s("a",{staticClass:"header-anchor",attrs:{href:"#connecting-to-a-back-end"}},[t._v("#")]),t._v(" Connecting to a back-end")]),t._v(" "),s("p",[t._v("Click the link below to see how to connect to a back-end (via OpenID Connect). You can call the connection object "),s("code",[t._v("con")]),t._v(" as it is done in all following code, to avoid confusion throughout the rest of the tutorials.")]),t._v(" "),s("CodeSwitcher",{scopedSlots:t._u([{key:"py",fn:function(){return[s("p",[s("RouterLink",{attrs:{to:"/documentation/1.0/python/#openid-connect-authentication"}},[t._v("Getting started: Authentication")])],1)]},proxy:!0},{key:"r",fn:function(){return[s("p",[s("RouterLink",{attrs:{to:"/documentation/1.0/r/#openid-connect-authentication"}},[t._v("Getting started: Authentication")])],1)]},proxy:!0},{key:"js",fn:function(){return[s("p",[s("RouterLink",{attrs:{to:"/documentation/1.0/javascript/#openid-connect-authentication"}},[t._v("Getting started: Authentication")])],1)]},proxy:!0}])}),t._v(" "),s("p",[t._v("In R and JavaScript it is very useful to assign a graph-building helper object to a variable, to easily access all openEO processes and add them to the process graph that you will be building. These objects will be used throughout this guide. In Python, it also helps to import a helper object, even though we'll need it less often.")]),t._v(" "),s("CodeSwitcher",{scopedSlots:t._u([{key:"py",fn:function(){return[s("div",{staticClass:"language-python extra-class"},[s("pre",{pre:!0,attrs:{class:"language-python"}},[s("code",[s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# import ProcessBuilder functions")]),t._v("\n"),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("from")]),t._v(" openeo"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),t._v("processes "),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("import")]),t._v(" ProcessBuilder\n")])])]),s("p",[s("strong",[t._v("Note:")]),t._v(" Many functions in "),s("em",[t._v("child processes")]),t._v(" (see below), are instances of this "),s("code",[t._v("ProcessBuilder")]),t._v(" import.")])]},proxy:!0},{key:"r",fn:function(){return[s("div",{staticClass:"language-r extra-class"},[s("pre",{pre:!0,attrs:{class:"language-r"}},[s("code",[s("span",{pre:!0,attrs:{class:"token comment"}},[t._v('# assign the graph-building helper object to "p" for easy access to all openEO processes, see > ?processes()')]),t._v("\np "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("<-")]),t._v(" processes"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n")])])]),s("p",[s("strong",[t._v("Note:")]),t._v(" In all R code, "),s("code",[t._v("p")]),t._v(" is used to select openEO processes.")])]},proxy:!0},{key:"js",fn:function(){return[s("div",{staticClass:"language-js extra-class"},[s("pre",{pre:!0,attrs:{class:"language-js"}},[s("code",[s("span",{pre:!0,attrs:{class:"token comment"}},[t._v('// assign the graph-building helper object to "builder" for easy access to all openEO processes')]),t._v("\n"),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("var")]),t._v(" builder "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("await")]),t._v(" con"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("buildProcess")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(";")]),t._v("\n")])])]),s("p",[s("strong",[t._v("Note:")]),t._v(" In all JavaScript code, "),s("code",[t._v("builder")]),t._v(" is used to select openEO processes.")])]},proxy:!0}])}),t._v(" "),s("h3",{attrs:{id:"input-load-collection"}},[s("a",{staticClass:"header-anchor",attrs:{href:"#input-load-collection"}},[t._v("#")]),t._v(" Input: "),s("code",[t._v("load_collection")])]),t._v(" "),s("p",[t._v("Before loading a collection, we need to find out the exact name of a collection we want to use (back-end-specific, see references "),s("a",{attrs:{href:"#openeo-cookbook"}},[t._v("at the top")]),t._v("). We assign the spatial and temporal extent to variables, so that we can re-use them on other collections we might want to load. Let's look for a Sentinel 2 (preprocessed level 2A preferably) collection and load the green, red and a near-infrared band (bands 3, 4 and 8).")]),t._v(" "),s("div",{staticClass:"custom-block tip"},[s("p",{staticClass:"custom-block-title"},[t._v("Collection and Band Names")]),t._v(" "),s("p",[t._v("The names of collections and bands differ between back-ends. So always check the collection description for the correct names. The differences might be subtle, e.g. "),s("code",[t._v("B8")]),t._v(" vs. "),s("code",[t._v("B08")]),t._v(".")])]),t._v(" "),s("p",[t._v("We'll name our collection very explicitly "),s("code",[t._v("cube_s2_b348")]),t._v(" as to not get confused later on.")]),t._v(" "),s("CodeSwitcher",{scopedSlots:t._u([{key:"py",fn:function(){return[s("div",{staticClass:"language-python extra-class"},[s("pre",{pre:!0,attrs:{class:"language-python"}},[s("code",[s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# make dictionary, containing bounding box")]),t._v("\nurk "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("{")]),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"west"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(":")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("5.5661")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"south"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(":")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("52.6457")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"east"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(":")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("5.7298")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"north"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(":")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("52.7335")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("}")]),t._v("\n"),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# make list, containing the temporal interval")]),t._v("\nt "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"2021-04-26"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"2021-04-30"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),t._v("\n\n"),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# load first datacube")]),t._v("\ncube_s2_b348 "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" con"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),t._v("load_collection"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"COPERNICUS/S2_SR"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n spatial_extent "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" urk"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n temporal_extent "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" t"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n bands "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"B3"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"B4"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"B8"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),t._v("\n"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n")])])])]},proxy:!0},{key:"r",fn:function(){return[s("div",{staticClass:"language-r extra-class"},[s("pre",{pre:!0,attrs:{class:"language-r"}},[s("code",[s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# create variables for loading collection")]),t._v("\nurk "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("<-")]),t._v(" list"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("west "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("5.5661")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" south "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("52.6457")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" east "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("5.7298")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" north "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("52.7335")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n\nt "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("<-")]),t._v(" c"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"2021-04-26"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"2021-04-30"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n\n"),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# load first datacube")]),t._v("\ncube_s2_b348 "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("<-")]),t._v(" p"),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("$")]),t._v("load_collection"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("\n id "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"COPERNICUS/S2_SR"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n spatial_extent "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" urk"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n temporal_extent "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" t"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n bands"),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v("c"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"B3"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"B4"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"B8"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n")])])])]},proxy:!0},{key:"js",fn:function(){return[s("div",{staticClass:"language-js extra-class"},[s("pre",{pre:!0,attrs:{class:"language-js"}},[s("code",[s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("// make spatial and temporal extent")]),t._v("\n"),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("let")]),t._v(" urk "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("{")]),s("span",{pre:!0,attrs:{class:"token string-property property"}},[t._v('"west"')]),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v(":")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("5.5661")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string-property property"}},[t._v('"south"')]),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v(":")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("52.6457")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string-property property"}},[t._v('"east"')]),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v(":")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("5.7298")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string-property property"}},[t._v('"north"')]),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v(":")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("52.7335")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("}")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(";")]),t._v("\n\n"),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("let")]),t._v(" t "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"2021-04-26"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"2021-04-30"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(";")]),t._v(" \n\n"),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("// load first cube")]),t._v("\n"),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("var")]),t._v(" cube_s2_b348 "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" builder"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("load_collection")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"COPERNICUS/S2_SR"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n urk"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n t"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"B3"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"B4"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"B8"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),t._v("\n"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(";")]),t._v("\n")])])]),s("p",[s("strong",[t._v("Note:")]),t._v(" JavaScript doesn't use parameter names (like Python and R), so the parameters need to be in the order that they are defined in the "),s("RouterLink",{attrs:{to:"/documentation/1.0/processes.html"}},[t._v("openEO processes documentation")]),t._v(".")],1)]},proxy:!0}])}),t._v(" "),s("h3",{attrs:{id:"filter-bands-filter-bands"}},[s("a",{staticClass:"header-anchor",attrs:{href:"#filter-bands-filter-bands"}},[t._v("#")]),t._v(" Filter Bands: "),s("code",[t._v("filter_bands")])]),t._v(" "),s("p",[t._v("To go through the desired output formats, we'll need one collection with three bands, and one collection with only one band. Here we use "),s("code",[t._v("filter_bands")]),t._v(", when of course we could also just define a separate collection via "),s("code",[t._v("load_collection")]),t._v(". As our input datacube already has the required three bands, we filter it for a single band to create an additional datacube with the same spatial and temporal extent, but with only one band (band 8).")]),t._v(" "),s("p",[t._v("We'll name this one "),s("code",[t._v("cube_s2_b8")]),t._v(" to distinguish it from the original "),s("code",[t._v("cube_s2_b348")]),t._v(".")]),t._v(" "),s("CodeSwitcher",{scopedSlots:t._u([{key:"py",fn:function(){return[s("div",{staticClass:"language-python extra-class"},[s("pre",{pre:!0,attrs:{class:"language-python"}},[s("code",[s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# filter for band 8")]),t._v("\ncube_s2_b8 "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" cube_s2_b348"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),t._v("filter_bands"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("bands "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"B8"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n")])])])]},proxy:!0},{key:"r",fn:function(){return[s("div",{staticClass:"language-r extra-class"},[s("pre",{pre:!0,attrs:{class:"language-r"}},[s("code",[s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# filter for band 8")]),t._v("\ncube_s2_b8 "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("<-")]),t._v(" p"),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("$")]),t._v("filter_bands"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("data "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" cube_s2_b348"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" bands "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" c"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"B8"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n")])])])]},proxy:!0},{key:"js",fn:function(){return[s("div",{staticClass:"language-js extra-class"},[s("pre",{pre:!0,attrs:{class:"language-js"}},[s("code",[s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("// filter for band 8")]),t._v("\n"),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("var")]),t._v(" cube_s2_b8 "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" builder"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("filter_bands")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("cube_s2_b348"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"B08"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n")])])])]},proxy:!0}])}),t._v(" "),s("h3",{attrs:{id:"temporal-mean-reduce-dimension"}},[s("a",{staticClass:"header-anchor",attrs:{href:"#temporal-mean-reduce-dimension"}},[t._v("#")]),t._v(" Temporal Mean: "),s("code",[t._v("reduce_dimension")])]),t._v(" "),s("p",[t._v("As we don't want to download the raw collection of satellite data, we need to reduce that data somehow. That means, we want to get rid of one dimension. Let's say we calculate a "),s("code",[t._v("mean")]),t._v(" over all timesteps, and then drop the temporal dimension (as it's empty then anyway, see explanation in the "),s("RouterLink",{attrs:{to:"/documentation/1.0/datacubes.html#reduce"}},[t._v("datacube guide")]),t._v("). This can be done via "),s("code",[t._v("reduce_dimension()")]),t._v(". The function requires a reducer, in our case a "),s("code",[t._v("mean")]),t._v(" process, and the dimension over which to reduce, given as a string ("),s("code",[t._v('"t"')]),t._v(").")],1),t._v(" "),s("div",{staticClass:"custom-block tip"},[s("p",{staticClass:"custom-block-title"},[t._v("Child Processes")]),t._v(" "),s("p",[t._v("Here, we need to define a child process: A function that is called by (or passed to) another function, and then works on a subset of the datacube (somewhat similar to the concept of callbacks in JavaScript). In this case: We want "),s("code",[t._v("reduce_dimension")]),t._v(" to use the "),s("code",[t._v("mean")]),t._v(" function to average all timesteps of each pixel. Not any function can be used like this, it must be defined by openEO, of course.")]),t._v(" "),s("p",[t._v("All clients have more or less different specifics when defining a child process. As you can observe directly below, one way to define one is to define the function directly inside the parent process.")]),t._v(" "),s("p",[t._v("For a more clean way to define a child process, see the chapter below.")])]),t._v(" "),s("CodeSwitcher",{scopedSlots:t._u([{key:"py",fn:function(){return[s("div",{staticClass:"language-python extra-class"},[s("pre",{pre:!0,attrs:{class:"language-python"}},[s("code",[s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# reduce all timesteps")]),t._v("\n"),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# mean_time() is a shortcut function")]),t._v("\ncube_s2_b8_red "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" cube_s2_b8"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),t._v("mean_time"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n\n"),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# alternatively, 'reduce_dimension' can be used")]),t._v("\ncube_s2_b8_red "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" cube_s2_b8"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),t._v("reduce_dimension"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("dimension"),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"t"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" reducer"),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"mean"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n\n"),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# additionally, reduce second collection")]),t._v("\ncube_s2_b348_red "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" cube_s2_b348"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),t._v("mean_time"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n")])])]),s("p",[s("strong",[t._v("Note:")]),t._v(" In python, the child process can be a string.")])]},proxy:!0},{key:"r",fn:function(){return[s("div",{staticClass:"language-r extra-class"},[s("pre",{pre:!0,attrs:{class:"language-r"}},[s("code",[s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# reduce dimension, first collection")]),t._v("\ncube_s2_b8_red "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("<-")]),t._v(" p"),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("$")]),t._v("reduce_dimension"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("data "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" cube_s2_b8"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" reducer "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("function")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("data"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" context"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("{")]),t._v(" p"),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("$")]),t._v("mean"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("data"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("}")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" dimension "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"t"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n\n"),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# reduce, second collection")]),t._v("\ncube_s2_b348_red "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("<-")]),t._v(" p"),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("$")]),t._v("reduce_dimension"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("data "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" cube_s2_b348"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" reducer "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("function")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("data"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" context"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("{")]),t._v(" p"),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("$")]),t._v("mean"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("data"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("}")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" dimension "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"t"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n")])])]),s("p",[s("strong",[t._v("Note:")]),t._v(" In R, we can select a child process from the "),s("code",[t._v("p")]),t._v(" helper object.")])]},proxy:!0},{key:"js",fn:function(){return[s("div",{staticClass:"language-js extra-class"},[s("pre",{pre:!0,attrs:{class:"language-js"}},[s("code",[s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("// reduce dimension")]),t._v("\n"),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("var")]),t._v(" cube_s2_b8_red "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" builder"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("reduce_dimension")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("cube_s2_b8"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token parameter"}},[t._v("data"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" _"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" child")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=>")]),t._v(" child"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("mean")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("data"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"t"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(";")]),t._v("\n\n"),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("// second collection")]),t._v("\n"),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("var")]),t._v(" cube_s2_b348_red "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" builder"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("reduce_dimension")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("cube_s2_b348"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token parameter"}},[t._v("data"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" _"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" child")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=>")]),t._v(" child"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("mean")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("data"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"t"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(";")]),t._v("\n")])])]),s("p",[s("strong",[t._v("Note:")]),t._v(" In JavaScript, arrow functions can be used as child processes.")])]},proxy:!0}])}),t._v(" "),s("h3",{attrs:{id:"scale-all-pixels-linearly-apply-linear-scale-range"}},[s("a",{staticClass:"header-anchor",attrs:{href:"#scale-all-pixels-linearly-apply-linear-scale-range"}},[t._v("#")]),t._v(" Scale All Pixels Linearly: "),s("code",[t._v("apply")]),t._v(", "),s("code",[t._v("linear_scale_range")])]),t._v(" "),s("p",[t._v("To create a PNG output, we need to scale the satellite data we have down to the 8bit range of a PNG image. For this, the scale range of our imagery has to be known. For Sentinel 2 over urban and agricultural areas, we can use "),s("code",[t._v("6000")]),t._v(" as a maximum.")]),t._v(" "),s("p",[t._v("We'll use the process "),s("code",[t._v("linear_scale_range")]),t._v(". It takes a number and the four borders of the intervals as input. Because it works on a number and not a datacube as all processes discussed so far, we need to nest the process into an "),s("code",[t._v("apply")]),t._v(", once again defining a child process. "),s("code",[t._v("apply")]),t._v(" applies a unary process to all pixels of a datacube.")]),t._v(" "),s("p",[t._v("This time we'll also define our child processes externally, as to not get confused in too much code nesting.")]),t._v(" "),s("CodeSwitcher",{scopedSlots:t._u([{key:"py",fn:function(){return[s("div",{staticClass:"language-python extra-class"},[s("pre",{pre:!0,attrs:{class:"language-python"}},[s("code",[s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# define child process, use ProcessBuilder")]),t._v("\n"),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("def")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("scale_function")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("x"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(":")]),t._v(" ProcessBuilder"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(":")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("return")]),t._v(" x"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),t._v("linear_scale_range"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("0")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("6000")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("0")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("255")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n\n"),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# apply scale_function to all pixels")]),t._v("\ncube_s2_b348_red_lin "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" cube_s2_b348_red"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token builtin"}},[t._v("apply")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("scale_function"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n")])])]),s("p",[s("strong",[t._v("Resource:")]),t._v(" Refer to the "),s("a",{attrs:{href:"https://open-eo.github.io/openeo-python-client/processes.html#processes-with-child-callbacks",target:"_blank",rel:"noopener noreferrer"}},[t._v("Python client documentation"),s("OutboundLink")],1),t._v(" to learn more about child processes in Python.")])]},proxy:!0},{key:"r",fn:function(){return[s("div",{staticClass:"language-r extra-class"},[s("pre",{pre:!0,attrs:{class:"language-r"}},[s("code",[s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# define child process")]),t._v("\nscale_function "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("<-")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("function")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("x"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" context"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("{")]),t._v("\n p"),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("$")]),t._v("linear_scale_range"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("x"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" inputMin "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("0")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" inputMax "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("6000")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" outputMin "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("0")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" outputMax "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("255")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("}")]),t._v("\n\n"),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# apply scale range to all pixels")]),t._v("\ncube_s2_b348_red_lin "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("<-")]),t._v(" p"),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("$")]),t._v("apply"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("data "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" cube_s2_b348_red"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" process "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" scale_function"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n")])])])]},proxy:!0},{key:"js",fn:function(){return[s("div",{staticClass:"language-js extra-class"},[s("pre",{pre:!0,attrs:{class:"language-js"}},[s("code",[s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("// define child process (long way)")]),t._v("\n"),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("var")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token function-variable function"}},[t._v("scale_function")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("function")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token parameter"}},[t._v("x"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" context")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("{")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("return")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("this")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("linear_scale_range")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("x"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("0")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("6000")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("0")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("255")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("}")]),t._v("\n\n"),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("// we could also use an arrow function here to abbreviate")]),t._v("\n"),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("// var scale_function = (x, context, child) => child.linear_scale_range(x, 0, 6000, 0, 255)")]),t._v("\n\n"),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("// apply child process to all pixels")]),t._v("\n"),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("var")]),t._v(" cube_s2_b348_red_lin "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("builder")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("apply")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("cube_s2_b348_red"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" scale_function"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(";")]),t._v("\n")])])]),s("p",[s("strong",[t._v("Note:")]),t._v(" Given the two ways of defining a child process above, we can see that in the long way, the builder is available as "),s("code",[t._v("this")]),t._v(", while in arrow functions, it has to be passed as the last argument (here called "),s("code",[t._v("child")]),t._v(").")])]},proxy:!0}])}),t._v(" "),s("figure",[s("img",{attrs:{src:a(315),alt:"A comparison between an unscaled and a scaled raster is shown. Unscaled values are much larger, sclaed values much closer together and all below 255."}}),t._v(" "),s("figcaption",[t._v("A part of our original image is displayed here, to observe the effect of applying a linear scale: Original (thus unscaled) imagery is seen on the left, and scaled values on the right.")])]),t._v(" "),s("h3",{attrs:{id:"spatial-aggregation-aggregate-spatial"}},[s("a",{staticClass:"header-anchor",attrs:{href:"#spatial-aggregation-aggregate-spatial"}},[t._v("#")]),t._v(" Spatial Aggregation: "),s("code",[t._v("aggregate_spatial")])]),t._v(" "),s("p",[t._v('To look at text output formats we first need to "de-spatialize" our data. Or put another way: If we\'re interested in e.g. timeseries of various geometries, text output might be very interesting for us.')]),t._v(" "),s("p",[t._v("To aggregate over certain geometries, we use the process "),s("code",[t._v("aggregate_spatial")]),t._v(". It takes valid GeoJSON as input. We can pass a GeoJSON "),s("code",[t._v("FeatureCollection")]),t._v(" in Python and JavaScript, but we need to introduce two packages in R, "),s("code",[t._v("sf")]),t._v(" and "),s("code",[t._v("geojsonsf")]),t._v(", to convert the "),s("code",[t._v("FeatureCollection")]),t._v(" "),s("code",[t._v("string")]),t._v(" to a "),s("code",[t._v("simple feature collection")]),t._v(".")]),t._v(" "),s("CodeSwitcher",{scopedSlots:t._u([{key:"py",fn:function(){return[s("div",{staticClass:"language-python extra-class"},[s("pre",{pre:!0,attrs:{class:"language-python"}},[s("code",[s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# polygons as (geojson) dict")]),t._v("\npolygons "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("{")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"type"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(":")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"FeatureCollection"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"features"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(":")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("{")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"type"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(":")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"Feature"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"properties"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(":")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("{")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("}")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"geometry"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(":")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("{")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"type"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(":")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"Polygon"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"coordinates"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(":")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("5.636715888977051")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("52.6807532675943")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("5.629441738128662")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("52.68157281641395")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("5.633561611175536")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("52.67787822078012")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("5.636715888977051")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("52.6807532675943")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("}")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("}")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("{")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"type"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(":")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"Feature"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"properties"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(":")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("{")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("}")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"geometry"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(":")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("{")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"type"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(":")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"Polygon"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"coordinates"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(":")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("5.622982978820801")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("52.68595649102906")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("5.6201934814453125")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("52.68429152697491")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("5.628776550292969")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("52.683719180920846")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("5.622982978820801")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("52.68595649102906")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("}")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("}")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("}")]),t._v("\n\n"),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# aggregate spatial")]),t._v("\ncube_s2_b8_agg "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" cube_s2_b8"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),t._v("aggregate_spatial"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("geometries "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" polygons"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" reducer "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"mean"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n\n"),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# alternatively, the python client has a shortcut function for this special case")]),t._v("\n"),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# cube_s2_b8_agg = cube_s2_b8.polygonal_mean_timeseries(polygon = polygons)")]),t._v("\n")])])])]},proxy:!0},{key:"r",fn:function(){return[s("div",{staticClass:"language-r extra-class"},[s("pre",{pre:!0,attrs:{class:"language-r"}},[s("code",[s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# load sf and geojsonsf")]),t._v("\nlibrary"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("sf"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\nlibrary"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("geojsonsf"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n\n"),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# create string containing the geojson FeatureCollection")]),t._v("\npolygons_string "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("<-")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('\'{ "type": "FeatureCollection", "features": [ { "type": "Feature", "properties": {}, "geometry": { "type": "Polygon", "coordinates": [ [ [ 5.636715888977051, 52.6807532675943 ], [ 5.629441738128662, 52.68157281641395 ], [ 5.633561611175536, 52.67787822078012 ], [ 5.636715888977051, 52.6807532675943 ] ] ] } }, { "type": "Feature", "properties": {}, "geometry": { "type": "Polygon", "coordinates": [ [ [ 5.622982978820801, 52.68595649102906 ], [ 5.6201934814453125, 52.68429152697491 ], [ 5.628776550292969, 52.683719180920846 ], [ 5.622982978820801, 52.68595649102906 ] ] ] } } ]}\'')]),t._v("\n"),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# convert to sf object")]),t._v("\npolygons "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("<-")]),t._v(" geojson_sf"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("polygons_string"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n\n"),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# add any attribute as a workaround, empty simple features are not accepted")]),t._v("\npolygons"),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("$")]),t._v("anAttribute "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("<-")]),t._v(" c"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("4")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("5")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n\n"),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# aggregate spatially")]),t._v("\ncube_s2_b8_agg "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("<-")]),t._v(" p"),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("$")]),t._v("aggregate_spatial"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("data "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" cube_s2_b8"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" reducer "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("function")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("data"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" context"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("{")]),t._v(" p"),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("$")]),t._v("mean"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("data"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("}")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" geometries "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" polygons"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n")])])]),s("p",[s("strong",[t._v("Note:")]),t._v(" At the time of writing this, empty simple features are not accepted and produce an error. To work around this issue, simply add a random attribute to the "),s("code",[t._v("sf")]),t._v(" object. Above we are assigning the (randomly chosen) values "),s("code",[t._v("4")]),t._v(" and "),s("code",[t._v("5")]),t._v(" to the two polygons in the collection.")])]},proxy:!0},{key:"js",fn:function(){return[s("div",{staticClass:"language-js extra-class"},[s("pre",{pre:!0,attrs:{class:"language-js"}},[s("code",[s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("// define polygons as geojson")]),t._v("\n"),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("var")]),t._v(" polygons "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("{")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token string-property property"}},[t._v('"type"')]),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v(":")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"FeatureCollection"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token string-property property"}},[t._v('"features"')]),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v(":")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("{")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token string-property property"}},[t._v('"type"')]),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v(":")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"Feature"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token string-property property"}},[t._v('"properties"')]),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v(":")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("{")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("}")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token string-property property"}},[t._v('"geometry"')]),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v(":")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("{")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token string-property property"}},[t._v('"type"')]),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v(":")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"Polygon"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token string-property property"}},[t._v('"coordinates"')]),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v(":")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("5.636715888977051")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("52.6807532675943")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("5.629441738128662")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("52.68157281641395")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("5.633561611175536")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("52.67787822078012")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("5.636715888977051")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("52.6807532675943")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("}")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("}")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("{")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token string-property property"}},[t._v('"type"')]),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v(":")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"Feature"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token string-property property"}},[t._v('"properties"')]),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v(":")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("{")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("}")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token string-property property"}},[t._v('"geometry"')]),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v(":")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("{")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token string-property property"}},[t._v('"type"')]),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v(":")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"Polygon"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token string-property property"}},[t._v('"coordinates"')]),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v(":")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("5.622982978820801")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("52.68595649102906")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("5.6201934814453125")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("52.68429152697491")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("5.628776550292969")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("52.683719180920846")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("5.622982978820801")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("52.68595649102906")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("}")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("}")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),t._v("\n"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("}")]),t._v("\n \n"),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("// aggregate spatial")]),t._v("\n"),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("var")]),t._v(" cube_s2_b8_agg "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" builder"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("aggregate_spatial")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("cube_s2_b8"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" polygons"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token parameter"}},[t._v("data"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" _"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" child")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=>")]),t._v(" child"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("mean")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("data"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n")])])])]},proxy:!0}])}),t._v(" "),s("h3",{attrs:{id:"output-save-result"}},[s("a",{staticClass:"header-anchor",attrs:{href:"#output-save-result"}},[t._v("#")]),t._v(" Output: "),s("code",[t._v("save_result")])]),t._v(" "),s("p",[t._v("To get a result, we first need to create a "),s("code",[t._v("save_result")]),t._v(" node, in which we state the desired output format and potential parameters, both dependent on the back-end you are connected to. The output formats and their parameters can e.g. be explored via the Web Editor along with available processes and collections.")]),t._v(" "),s("p",[t._v("We then proceed to send that job to the back-end, "),s("em",[t._v("without executing it")]),t._v(". Refer to the getting started guides on how to process results as batch or synchronous jobs. The way it is stated here allows us to log in to the Web Editor and look at, change, and execute the job from there.")]),t._v(" "),s("h4",{attrs:{id:"raster-formats-gtiff-netcdf"}},[s("a",{staticClass:"header-anchor",attrs:{href:"#raster-formats-gtiff-netcdf"}},[t._v("#")]),t._v(" Raster Formats: GTiff, NetCDF")]),t._v(" "),s("p",[t._v("In the example, GeoTiff files are produced. Refer to the back-end for the available formats, options, and their correct naming. Check the "),s("a",{attrs:{href:"#raster-formats-png"}},[t._v("PNG section")]),t._v(" for passing options.")]),t._v(" "),s("p",[t._v("Different from the creation of a PNG image, the raster format doesn't need scaling and the original datacube can be downloaded as is. However, we need to be careful with the dimensionality of the datacube: How a 4+ - dimensional datacube is handled when converted to a raster format is back-end dependent. That is why we "),s("a",{attrs:{href:"#temporal-mean-reduce-dimension"}},[t._v("made sure")]),t._v(" that our cube would only contain one additional dimension, apart from the spatial "),s("code",[t._v("x")]),t._v(" and "),s("code",[t._v("y")]),t._v(".")]),t._v(" "),s("CodeSwitcher",{scopedSlots:t._u([{key:"py",fn:function(){return[s("div",{staticClass:"language-python extra-class"},[s("pre",{pre:!0,attrs:{class:"language-python"}},[s("code",[s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# save using save_result, give format as string")]),t._v("\nres "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" cube_s2_b8_red"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),t._v("save_result"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token builtin"}},[t._v("format")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"GTiff"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n\n"),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# send job to back-end, do not execute")]),t._v("\njob "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" res"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),t._v("create_job"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("title "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"temporal_mean_as_GTiff_py"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n")])])])]},proxy:!0},{key:"r",fn:function(){return[s("div",{staticClass:"language-r extra-class"},[s("pre",{pre:!0,attrs:{class:"language-r"}},[s("code",[s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# use list_file_formats() to be able to choose from a list")]),t._v("\nformats "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("<-")]),t._v(" list_file_formats"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n\n"),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# save using save_result, give format via list")]),t._v("\nres "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("<-")]),t._v(" p"),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("$")]),t._v("save_result"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("data "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" cube_s2_b8_red"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" format "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" formats"),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("$")]),t._v("output"),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("$")]),t._v("GTiff"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n\n"),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# send job to back-end")]),t._v("\njob "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("<-")]),t._v(" create_job"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("graph "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" res"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" title "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"temporal_mean_as_GTiff_r"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n")])])])]},proxy:!0},{key:"js",fn:function(){return[s("div",{staticClass:"language-js extra-class"},[s("pre",{pre:!0,attrs:{class:"language-js"}},[s("code",[s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("// save using save_result, give fomat as string")]),t._v("\nresult "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" builder"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("save_result")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("cube_s2_b8_red"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"GTiff"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(";")]),t._v("\n\n"),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("// send job to back-end, but don't execute yet; set title")]),t._v("\n"),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("var")]),t._v(" job "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("await")]),t._v(" con"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("createJob")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("result"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"temporal_mean_as_GTiff_js"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(";")]),t._v("\n")])])])]},proxy:!0}])}),t._v(" "),s("h4",{attrs:{id:"raster-formats-png"}},[s("a",{staticClass:"header-anchor",attrs:{href:"#raster-formats-png"}},[t._v("#")]),t._v(" Raster Formats: PNG")]),t._v(" "),s("p",[t._v("For a PNG output, we'll use the datacube with the bands 3, 4 and 8 (green, red and near-infrared) that we've been working on simultaneously with the datacube used above. As we have scaled the data down to 8bit using a "),s("a",{attrs:{href:"#scale-all-pixels-linearly-apply-linear-scale-range"}},[t._v("linear scale")]),t._v(", nothing stands in the way of downloading the data as PNG.")]),t._v(" "),s("p",[t._v("We want to produce a false-color composite highlighting the vegetation in red (as seen below the code). For that, we want to assign the infrared band ("),s("code",[t._v("B8")]),t._v(") to the red channel, the red band ("),s("code",[t._v("B4")]),t._v(") to the green channel and the green band ("),s("code",[t._v("B3")]),t._v(") to the blue channel. Some back-ends may offer to pass along this desired band order as it is shown below. Check with the back-end for available options.")]),t._v(" "),s("div",{staticClass:"custom-block tip"},[s("p",{staticClass:"custom-block-title"},[t._v("Note")]),t._v(" "),s("p",[t._v("If no options can be passed, handling of the bands for PNG output is internal and should be documented by the back-end. You might also be able to tell how this is done by how your PNG looks: As explained in the "),s("RouterLink",{attrs:{to:"/documentation/1.0/datacubes.html#dimensions"}},[t._v("datacube guide")]),t._v(", the order of the "),s("code",[t._v("bands")]),t._v(" dimension is defined when the values are loaded or altered (in our example: "),s("code",[t._v("filter_bands")]),t._v("). As we filter bands in the order "),s("code",[t._v('"B3", "B4", "B8"')]),t._v(" vegetation might be highlighted in blue, given that the back-end uses the input order for the RGB channels.")],1),t._v(" "),s("p",[s("strong",[t._v("The example below uses the "),s("code",[t._v("PNG")]),t._v(" file format as defined by the Google Earth Engine back-end so the parameters "),s("code",[t._v("red")]),t._v(", "),s("code",[t._v("green")]),t._v(" and "),s("code",[t._v("blue")]),t._v(" may not be available on another back-end.")]),t._v(" Make sure to check the file format documentation for your back-end.")])]),t._v(" "),s("CodeSwitcher",{scopedSlots:t._u([{key:"py",fn:function(){return[s("div",{staticClass:"language-python extra-class"},[s("pre",{pre:!0,attrs:{class:"language-python"}},[s("code",[s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# save result cube as PNG")]),t._v("\nres "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" cube_s2_b348_red_lin"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),t._v("save_result"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token builtin"}},[t._v("format")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"PNG"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" options "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("{")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"red"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(":")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"B8"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"green"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(":")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"B4"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"blue"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(":")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"B3"')]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("}")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n\n"),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# send job to back-end")]),t._v("\njob "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" res"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),t._v("create_job"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("title "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"temporal_mean_as_PNG_py"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n")])])]),s("p",[t._v("In python, options are passed as a dictionary")])]},proxy:!0},{key:"r",fn:function(){return[s("div",{staticClass:"language-r extra-class"},[s("pre",{pre:!0,attrs:{class:"language-r"}},[s("code",[s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# use list_file_formats() to be able to choose from a list")]),t._v("\nformats "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("<-")]),t._v(" list_file_formats"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n\n"),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# save result as PNG")]),t._v("\nres "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("<-")]),t._v(" p"),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("$")]),t._v("save_result"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("data "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" cube_s2_b348_red_lin"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" format "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" formats"),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("$")]),t._v("output"),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("$")]),t._v("PNG"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" \n options "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" list"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("red"),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"B8"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" green"),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"B4"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" blue"),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"B3"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n\n"),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# send job to back-end")]),t._v("\njob "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("<-")]),t._v(" create_job"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("graph "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" res"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" title "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"temporal_mean_as_PNG_r"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n")])])]),s("p",[t._v("In R, options are passed as a list.")])]},proxy:!0},{key:"js",fn:function(){return[s("div",{staticClass:"language-js extra-class"},[s("pre",{pre:!0,attrs:{class:"language-js"}},[s("code",[s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("// save result as PNG")]),t._v("\nresult "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" builder"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("save_result")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("cube_s2_b348_red_lin"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"PNG"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("{")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token literal-property property"}},[t._v("red")]),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v(":")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"B8"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token literal-property property"}},[t._v("green")]),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v(":")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"B4"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token literal-property property"}},[t._v("blue")]),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v(":")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"B3"')]),t._v("\n"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("}")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(";")]),t._v("\n \n"),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("// send job to back-end")]),t._v("\n"),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("var")]),t._v(" job "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("await")]),t._v(" con"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("createJob")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("result"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"temporal_mean_as_PNG_js"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(";")]),t._v("\n")])])]),s("p",[t._v("In JavaScript, options are passed as objects.")])]},proxy:!0}])}),t._v(" "),s("figure",[s("img",{attrs:{src:a(316),alt:"Example PNG: false color composite highlighting vegetation in red."}}),t._v(" "),s("figcaption",[t._v("Image above: Example PNG output with the vegetation highlighted in red.")])]),t._v(" "),s("h4",{attrs:{id:"text-formats-json-csv"}},[s("a",{staticClass:"header-anchor",attrs:{href:"#text-formats-json-csv"}},[t._v("#")]),t._v(" Text Formats: JSON, CSV")]),t._v(" "),s("p",[t._v("We can now save the timeseries in the "),s("a",{attrs:{href:"#spatial-aggregation-aggregate-spatial"}},[t._v("aggregated")]),t._v(" datacube as e.g. JSON.")]),t._v(" "),s("CodeSwitcher",{scopedSlots:t._u([{key:"py",fn:function(){return[s("div",{staticClass:"language-python extra-class"},[s("pre",{pre:!0,attrs:{class:"language-python"}},[s("code",[s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# save result cube as JSON")]),t._v("\nres "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" cube_s2_b8_agg"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),t._v("save_result"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token builtin"}},[t._v("format")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"JSON"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n\n"),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# send job to back-end")]),t._v("\njob "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" res"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),t._v("create_job"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("title "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"timeseries_as_JSON_py"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n")])])])]},proxy:!0},{key:"r",fn:function(){return[s("div",{staticClass:"language-r extra-class"},[s("pre",{pre:!0,attrs:{class:"language-r"}},[s("code",[s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# use list_file_formats() to be able to choose from a list")]),t._v("\nformats "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("<-")]),t._v(" list_file_formats"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n\n"),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# save result as JSON")]),t._v("\nres "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("<-")]),t._v(" p"),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("$")]),t._v("save_result"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("data "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" cube_s2_b8_agg"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" format "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" formats"),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("$")]),t._v("output"),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("$")]),t._v("JSON"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n\n"),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# send job to back-end")]),t._v("\njob "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("<-")]),t._v(" create_job"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("graph "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" res"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" title "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"timeseries_as_JSON_r"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n")])])]),s("p",[s("strong",[t._v("Note:")]),t._v(" Because the R client rounds coordinates to four digits, slightly different results are received in comparison to the other clients.")])]},proxy:!0},{key:"js",fn:function(){return[s("div",{staticClass:"language-js extra-class"},[s("pre",{pre:!0,attrs:{class:"language-js"}},[s("code",[s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("// save as CSV")]),t._v("\nresult "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" builder"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("save_result")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("cube_s2_b8_agg"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"JSON"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(";")]),t._v("\n\n"),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("// send job to back-end")]),t._v("\n"),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("var")]),t._v(" job "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("await")]),t._v(" con"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("createJob")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("result"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"timeseries_as_JSON_js"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(";")]),t._v("\n")])])])]},proxy:!0}])}),t._v(" "),s("h3",{attrs:{id:"output-process-as-json"}},[s("a",{staticClass:"header-anchor",attrs:{href:"#output-process-as-json"}},[t._v("#")]),t._v(" Output: Process as JSON")]),t._v(" "),s("p",[t._v("In some cases we want to export the JSON representation of a process we created. If you followed one of the examples above, then your end node is called "),s("code",[t._v("res")]),t._v(". If not, replace that with whatever you called your process end node.")]),t._v(" "),s("CodeSwitcher",{scopedSlots:t._u([{key:"py",fn:function(){return[s("div",{staticClass:"language-python extra-class"},[s("pre",{pre:!0,attrs:{class:"language-python"}},[s("code",[t._v("process "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" res"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),t._v("to_json"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n\n"),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# if needed, write JSON to file, e.g.:")]),t._v("\n"),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("with")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token builtin"}},[t._v("open")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"./process.json"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"w"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("as")]),t._v(" tfile"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(":")]),t._v("\n tfile"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),t._v("write"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("process"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n")])])])]},proxy:!0},{key:"r",fn:function(){return[s("div",{staticClass:"language-r extra-class"},[s("pre",{pre:!0,attrs:{class:"language-r"}},[s("code",[s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# convert process to JSON")]),t._v("\nprocess_json "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("<-")]),t._v(" toJSON"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("as"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("res"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"Process"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n\n"),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# if needed, write JSON to file, e.g.:")]),t._v("\ncat"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("process_json"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" file "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"./process.json"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n")])])])]},proxy:!0},{key:"js",fn:function(){return[s("div",{staticClass:"language-js extra-class"},[s("pre",{pre:!0,attrs:{class:"language-js"}},[s("code",[s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("// set last node as result = true so it is recognized as the result node")]),t._v("\nres"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),t._v("result "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token boolean"}},[t._v("true")]),t._v("\n\nprocess "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token constant"}},[t._v("JSON")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("stringify")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("builder"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("toJSON")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n\n"),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("// if needed, write JSON to file, e.g.:")]),t._v("\n"),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("var")]),t._v(" fs "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("require")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token string"}},[t._v("'fs'")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(";")]),t._v("\nfs"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("writeFileSync")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"./process.json"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" process"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(";")]),t._v("\n")])])]),s("p",[s("strong",[t._v("Note:")]),t._v(" The code to store a file only works with NodeJS. Browsers can't write files to disk.")])]},proxy:!0}])}),t._v(" "),s("h2",{attrs:{id:"chapter-2"}},[s("a",{staticClass:"header-anchor",attrs:{href:"#chapter-2"}},[t._v("#")]),t._v(" Chapter 2")]),t._v(" "),s("p",[t._v("In this second part of the cookbook, things are a bit less linear. We'll explore bandmath, masking and "),s("code",[t._v("apply_*")]),t._v(" functionality, only that these steps are less interconnected than in the first chapter.")]),t._v(" "),s("p",[t._v("As usual we'll load a collection to work with (Sentinel 2, bands "),s("code",[t._v("2")]),t._v(", "),s("code",[t._v("4")]),t._v(", "),s("code",[t._v("8")]),t._v(" and "),s("code",[t._v("SCL")]),t._v("). Let's call it "),s("code",[t._v("cube_s2")]),t._v(". We pre-select a time frame of which we know it only contains one Sentinel 2 scene, so that we're not bothered with multiple timesteps (the collection still contains a time dimension, but with only one timestep in it, so that it can be ignored). The extent has been chosen to provide results that are suitable to show the effect of the processes used, while being considerably small and thus fast to compute. If you want to minimize processing time you are of course free to use much smaller AOIs.")]),t._v(" "),s("p",[t._v("To be able to download and look at the results, refer to the "),s("a",{attrs:{href:"#raster-formats-gtiff-netcdf"}},[t._v("output section of chapter 1")]),t._v(". Most of the images in this tutorial were all downloaded as GTiff and plotted with R.")]),t._v(" "),s("CodeSwitcher",{scopedSlots:t._u([{key:"py",fn:function(){return[s("div",{staticClass:"language-python extra-class"},[s("pre",{pre:!0,attrs:{class:"language-python"}},[s("code",[t._v("pellworm "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("{")]),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"west"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(":")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("8.5464")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"south"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(":")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("54.4473")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"east"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(":")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("9.0724")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"north"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(":")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("54.5685")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("}")]),t._v("\nt "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"2021-03-05"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"2021-03-05"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),t._v("\n\ncube_s2 "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" con"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),t._v("load_collection"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"SENTINEL2_L2A_SENTINELHUB"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n spatial_extent "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" pellworm"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n temporal_extent "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" t"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n bands "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"B02"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"B04"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"B08"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"SCL"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),t._v("\n"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n")])])])]},proxy:!0},{key:"r",fn:function(){return[s("div",{staticClass:"language-r extra-class"},[s("pre",{pre:!0,attrs:{class:"language-r"}},[s("code",[t._v("pellworm "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("<-")]),t._v(" list"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("west "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("8.5464")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" south "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("54.4473")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" east "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("9.0724")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" north "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("54.5685")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\nt "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("<-")]),t._v(" c"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"2021-03-05"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"2021-03-05"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n\ncube_s2 "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("<-")]),t._v(" p"),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("$")]),t._v("load_collection"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("\n id "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"SENTINEL2_L2A_SENTINELHUB"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n spatial_extent "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" pellworm"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n temporal_extent "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" t"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n bands"),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v("c"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"B02"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"B04"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"B08"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"SCL"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n")])])])]},proxy:!0},{key:"js",fn:function(){return[s("div",{staticClass:"language-js extra-class"},[s("pre",{pre:!0,attrs:{class:"language-js"}},[s("code",[s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("let")]),t._v(" pellworm "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("{")]),s("span",{pre:!0,attrs:{class:"token string-property property"}},[t._v('"west"')]),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v(":")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("8.5464")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string-property property"}},[t._v('"south"')]),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v(":")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("54.4473")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string-property property"}},[t._v('"east"')]),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v(":")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("9.0724")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string-property property"}},[t._v('"north"')]),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v(":")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("54.5685")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("}")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(";")]),t._v("\n"),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("let")]),t._v(" t "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"2021-03-05"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"2021-03-05"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(";")]),t._v("\n\n"),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("var")]),t._v(" cube_s2 "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" builder"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("load_collection")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"SENTINEL2_L2A_SENTINELHUB"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n pellworm"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n t"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"B02"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"B04"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"B08"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"SCL"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),t._v("\n"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(";")]),t._v("\n")])])])]},proxy:!0}])}),t._v(" "),s("figure",[s("img",{attrs:{src:a(317),alt:"The AOI around Pellworm is shown as a false color RGB. RGB = red, nir and blue"}}),t._v(" "),s("figcaption",[t._v("This is a false color image of our area of interest for this chapter. The bands 4, 8 and 2 have been assigned to the RGB channels without any further processing. The surrounding area of the island Pellworm is shown at low tide.\n")])]),t._v(" "),s("h3",{attrs:{id:"bandmath"}},[s("a",{staticClass:"header-anchor",attrs:{href:"#bandmath"}},[t._v("#")]),t._v(" Bandmath")]),t._v(" "),s("p",[t._v("Bandmath refers to computations that involve multiple bands, like indices (Normalized Difference Vegetation Index, Normalized Burn Ratio etc.).")]),t._v(" "),s("p",[t._v("In openEO, this goes along with using for example "),s("code",[t._v("reduce_dimension")]),t._v(" over the "),s("code",[t._v("bands")]),t._v(" dimension. In this process, a new pixel value is calculated from the values of different bands using a given formula (the actual bandmath), to then eliminate the "),s("code",[t._v("bands")]),t._v(" dimension alltogether. If e.g. a cube contains a "),s("code",[t._v("red")]),t._v(" and a "),s("code",[t._v("nir")]),t._v(" band in its "),s("code",[t._v("bands")]),t._v(" dimension and we reduce said dimension with a formula for the NDVI, that cube afterwards contains NDVI values, but no "),s("code",[t._v("bands")]),t._v(" dimension anymore.")]),t._v(" "),s("p",[t._v("In the following we'll observe a thorough explanation of how to calculate an NDVI. That section covers different ways (depending on the client) to set up such a process in openEO. Afterwards, we'll see how an EVI is computed in a quicker, less thorough example.")]),t._v(" "),s("h4",{attrs:{id:"example-1-ndvi"}},[s("a",{staticClass:"header-anchor",attrs:{href:"#example-1-ndvi"}},[t._v("#")]),t._v(" Example 1: NDVI")]),t._v(" "),s("p",[t._v("As mentioned above, bandmath is about reducing the "),s("code",[t._v("bands")]),t._v(" dimension with a child process (a formula) that gives us the desired output. In "),s("a",{attrs:{href:"#chapter-1"}},[t._v("chapter one")]),t._v(", we already saw different ways of defining a child process: a) We learned how to use a simple "),s("code",[t._v("mean")]),t._v(" to "),s("RouterLink",{attrs:{to:"/documentation/1.0/cookbook/#temporal-mean-reduce-dimension"}},[t._v("reduce the time dimension")]),t._v(", and b) we saw how to access and use the openEO defined "),s("code",[t._v("linear_scale_range")]),t._v(" function "),s("RouterLink",{attrs:{to:"/documentation/1.0/cookbook/#scale-all-pixels-linearly-apply-linear-scale-range"}},[t._v("to scale all pixels linearly")]),t._v(".")],1),t._v(" "),s("p",[t._v("In this chapter, we'll reiterate these techniques and discuss some subtleties and alternatives. It is up to you to choose one that works best. Special to the NDVI is, given that it is "),s("em",[t._v("the")]),t._v(" most common use case, that openEO has predefined processes that cover the math for us and only need to be given the correct input. There even is a function "),s("code",[t._v("ndvi")]),t._v(" that masks all details and only takes a datacube and the bandnames as input. Further down we'll dig into what this "),s("code",[t._v("ndvi")]),t._v(" process actually masks, how we can reproduce that manually, and thus how we could formulate other bandmath functions, apart from an NDVI.")]),t._v(" "),s("p",[t._v("By using the openEO defined "),s("strong",[s("code",[t._v("ndvi")]),t._v(" function")]),t._v(", calculating an NDVI becomes pretty straightforward. The process can detect the red and near-infrared band based on metadata and doesn't need bandname input (but band names can be passed to calculate other normalized differences). Also, by supplying the optional parameter "),s("code",[t._v("target_band")]),t._v(" we can decide if we want to get a reduced cube with NDVI values and no "),s("code",[t._v("bands")]),t._v(" dimension as result, or if we want to append the new NDVI band to the existing bands of our input cube. If we choose the latter, we only need to supply a name for that new NDVI band.")]),t._v(" "),s("CodeSwitcher",{scopedSlots:t._u([{key:"py",fn:function(){return[s("div",{staticClass:"language-python extra-class"},[s("pre",{pre:!0,attrs:{class:"language-python"}},[s("code",[t._v("cube_s2_ndvi "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" cube_s2"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),t._v("ndvi"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n\n"),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# or name bands explicitly + append the result band to the existing cube")]),t._v("\n"),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v('# cube_s2_ndvi_bands = cube_s2.ndvi(nir = "B08", red = "B04", target_band = "NDVI")')]),t._v("\n")])])])]},proxy:!0},{key:"r",fn:function(){return[s("div",{staticClass:"language-r extra-class"},[s("pre",{pre:!0,attrs:{class:"language-r"}},[s("code",[t._v("cube_s2_ndvi "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("<-")]),t._v(" p"),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("$")]),t._v("ndvi"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("cube_s2"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n\n"),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# or name bands explicitly + append the result band to the existing cube")]),t._v("\n"),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v('# cube_s2_nvdi_bands <- p$ndvi(data = cube_s2, nir = "B08", red = "B04", target_band = "NDVI")')]),t._v("\n")])])])]},proxy:!0},{key:"js",fn:function(){return[s("div",{staticClass:"language-js extra-class"},[s("pre",{pre:!0,attrs:{class:"language-js"}},[s("code",[t._v("cube_s2_ndvi "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" builder"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("ndvi")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("cube_s2"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n\n"),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("// or name bands explicitly + append the result band to the existing cube")]),t._v("\n"),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v('// cube_s2_ndvi_bands = builder.ndvi(cube_s2, "B08", "B04", "NDVI")')]),t._v("\n")])])])]},proxy:!0}])}),t._v(" "),s("p",[t._v("For the purpose of understanding, we'll stick with our NDVI example to explore different ways of defining bandmath in openEO. That gives you the knowledge to define other processes, not just NDVIs. The first method is available in all clients: "),s("strong",[t._v("Defining a function")]),t._v(" and passing it to a process, e.g. "),s("code",[t._v("reduce_dimension")]),t._v(". If available, other possibilities are discussed afterwards.")]),t._v(" "),s("div",{staticClass:"custom-block tip"},[s("p",{staticClass:"custom-block-title"},[t._v("Important: Check Band Indices and Bandnames!")]),t._v(" "),s("p",[t._v("Be careful when handling the names or array indices of bands. While names differ across back-ends, indices can be mixed up easily when some other band is deleted from the input collection. Python and JavaScript have 0-based indices, R indices are 1-based. So double check which bands you're actually using.")])]),t._v(" "),s("CodeSwitcher",{scopedSlots:t._u([{key:"py",fn:function(){return[s("div",{staticClass:"language-python extra-class"},[s("pre",{pre:!0,attrs:{class:"language-python"}},[s("code",[s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# necessary imports")]),t._v("\n"),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("from")]),t._v(" openeo"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),t._v("processes "),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("import")]),t._v(" array_element"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" normalized_difference\n\n"),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# define an NDVI function")]),t._v("\n"),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("def")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("ndvi_function")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("data"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(":")]),t._v("\n B04 "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" array_element"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("data"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" index "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("1")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# array_element takes either an index ..")]),t._v("\n B08 "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" array_element"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("data"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" label "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"B08"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# or a label")]),t._v("\n\n "),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# ndvi = (B08 - B04) / (B08 + B04) # implement NDVI as formula ..")]),t._v("\n ndvi "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" normalized_difference"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("B08"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" B04"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v('# or use the openEO "normalized_difference" process')]),t._v("\n \n "),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("return")]),t._v(" ndvi\n\n"),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v('# supply the defined function to a reduce_dimension process, set dimension = "bands"')]),t._v("\ncube_s2_ndvi "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" cube_s2"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),t._v("reduce_dimension"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("reducer "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" ndvi_function"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" dimension "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"bands"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n")])])]),s("p",[t._v("What we see above:")]),t._v(" "),s("ul",[s("li",[t._v("access specific bands inside the child process: "),s("code",[t._v("array_element")]),t._v(" (supply data and index/label)")]),t._v(" "),s("li",[t._v("call openEO defined functions inside the child process by importing it: "),s("code",[t._v("from openeo.processes import normalized_difference")])]),t._v(" "),s("li",[t._v("write math as formula inside the child process: "),s("code",[t._v("ndvi = (B08 - B04) / (B08 + B04)")])])]),t._v(" "),s("p",[t._v("The python client also holds a second possibility to do the above. It has a "),s("strong",[t._v("function "),s("code",[t._v("band")])]),t._v(" that does "),s("code",[t._v("array_element")]),t._v(" and "),s("code",[t._v('reduce_dimension(dimension = "bands")')]),t._v(" for us. When using it, we can type out the NDVI formula right in the script (since "),s("code",[t._v(".band")]),t._v(" reduced the cube for us).")]),t._v(" "),s("div",{staticClass:"language-python extra-class"},[s("pre",{pre:!0,attrs:{class:"language-python"}},[s("code",[t._v("B04 "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" cube_s2"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),t._v("band"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"B04"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\nB08 "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" cube_s2"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),t._v("band"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"B08"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n\ncube_s2_ndvi "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("B08 "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("-")]),t._v(" B04"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("/")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("B08 "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("+")]),t._v(" B04"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# type math formula")]),t._v("\n")])])])]},proxy:!0},{key:"r",fn:function(){return[s("div",{staticClass:"language-r extra-class"},[s("pre",{pre:!0,attrs:{class:"language-r"}},[s("code",[s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# define an NDVI function")]),t._v("\nndvi_function "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("<-")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("function")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("data"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" context"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("{")]),t._v("\n B04 "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("<-")]),t._v(" data"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("2")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# we can supply an index (1-based in R) ..")]),t._v("\n B08 "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("<-")]),t._v(" data"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"B08"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# or a label")]),t._v("\n \n "),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# ndvi <- (B08 - B04) / (B08 + B04) # implement NDVI as formula ..")]),t._v("\n ndvi "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("<-")]),t._v(" p"),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("$")]),t._v("normalized_difference"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("B08"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" B04"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v('# or use the openEO "normalized_difference" process')]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# ndvi <- p$normalized_difference(data[2], data[3]) # or shorten all in one line")]),t._v("\n\n return"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("ndvi"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("}")]),t._v("\n\n"),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v('# supply the defined function to a reduce_dimension process, set dimension = "bands"')]),t._v("\ncube_s2_ndvi "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("<-")]),t._v(" p"),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("$")]),t._v("reduce_dimension"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("data "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" cube_s2"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" reducer "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" ndvi_function"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" dimension "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"bands"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n")])])]),s("p",[t._v("What we see above:")]),t._v(" "),s("ul",[s("li",[t._v("access specific bands inside the child process by using array subset: "),s("code",[t._v("data[index]")]),t._v(" or "),s("code",[t._v('data["bandname"]')])]),t._v(" "),s("li",[t._v("call openEO defined functions inside the child process by calling it via the "),s("code",[t._v("p")]),t._v(" processes environment: "),s("code",[t._v("p$normalized_difference")])]),t._v(" "),s("li",[t._v("write math as formulas inside the child process: "),s("code",[t._v("ndvi <- (B08 - B04) / (B08 + B04)")])])]),t._v(" "),s("p",[t._v("In R, there are no other ways to define a child process than through defining a function as seen above.")])]},proxy:!0},{key:"js",fn:function(){return[s("div",{staticClass:"language-js extra-class"},[s("pre",{pre:!0,attrs:{class:"language-js"}},[s("code",[s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("// define NDVI function")]),t._v("\n"),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("var")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token function-variable function"}},[t._v("ndvi_function")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("function")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token parameter"}},[t._v("data"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" context")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("{")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token constant"}},[t._v("B04")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" data"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("1")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("// use array operator to extract bands")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token constant"}},[t._v("B08")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" data"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"B08"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("// or supply label")]),t._v("\n\n ndvi "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("this")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("normalized_difference")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token constant"}},[t._v("B08")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token constant"}},[t._v("B04")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v('// use "this" to access openEO processes inside this function')]),t._v("\n\n "),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v('// ndvi = this.normalized_difference(data["B08"], data["B04"]) // or shorten it all into one line')]),t._v("\n \n "),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("return")]),t._v(" ndvi\n"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("}")]),t._v("\n\n"),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v('// supply the defined function to a reduce_dimension process, set dimension = "bands"')]),t._v("\ncube_s2_ndvi "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" builder"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("reduce_dimension")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("cube_s2"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" ndvi_function"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"bands"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n")])])]),s("p",[t._v("What we see above:")]),t._v(" "),s("ul",[s("li",[t._v("access specific bands inside the child process by using array subset: "),s("code",[t._v("data[index]")]),t._v(" or "),s("code",[t._v('data["bandname"]')])]),t._v(" "),s("li",[t._v("call openEO defined functions inside the child process by calling it via "),s("code",[t._v("this")])])]),t._v(" "),s("p",[t._v("We note that JavaScript doesn't support just typing out math functions as R and Python do. But the JS client has another, even simpler way of defining quick bandmath: "),s("strong",[t._v("using "),s("code",[t._v("new Formula")])]),t._v(".")]),t._v(" "),s("div",{staticClass:"language-js extra-class"},[s("pre",{pre:!0,attrs:{class:"language-js"}},[s("code",[s("span",{pre:!0,attrs:{class:"token comment"}},[t._v('// using "New Formula()", both $index and $label are valid as seen here, $1 refers to B04')]),t._v("\ncube_s2_ndvi "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" builder"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("reduce_dimension")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("cube_s2"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("new")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token class-name"}},[t._v("Formula")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"($B08 - $1) / ($B08 + $1)"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"bands"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n")])])]),s("p",[t._v("We see that using "),s("code",[t._v('new Formula("")')]),t._v(" is much faster than defining a whole child process. We use "),s("code",[t._v("$")]),t._v(" to access bands (works with "),s("code",[t._v("$indices")]),t._v(" or "),s("code",[t._v("$bandnames")]),t._v("). If we want to use openEO defined processes, there's also the "),s("strong",[t._v("arrow function")]),t._v(" to still be able to do that in-line.")]),t._v(" "),s("div",{staticClass:"language-js extra-class"},[s("pre",{pre:!0,attrs:{class:"language-js"}},[s("code",[s("span",{pre:!0,attrs:{class:"token comment"}},[t._v('// using an arrow function to call openeo process "normalized_difference"')]),t._v("\ncube_s2_ndvi "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" builder"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("reduce_dimension")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("cube_s2"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token parameter"}},[t._v("data"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" _"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" child")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=>")]),t._v(" child"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("normalized_difference")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("data"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("2")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" data"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("1")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"bands"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n")])])]),s("p",[t._v("In an arrow function, we can use array subsets again.")]),t._v(" "),s("p",[t._v("To sum up: Although "),s("code",[t._v("new Formula")]),t._v(" is probably the most straightforward way of calculating an NDVI, it is up to you to decide on a method that suits your use-case.")])]},proxy:!0}])}),t._v(" "),s("figure",[s("img",{attrs:{src:a(318),alt:"NDVI image of the AOI"}}),t._v(" "),s("figcaption",[t._v("A correctly calculated NDVI would look as displayed here (scaled linearly).")])]),t._v(" "),s("h4",{attrs:{id:"example-2-evi"}},[s("a",{staticClass:"header-anchor",attrs:{href:"#example-2-evi"}},[t._v("#")]),t._v(" Example 2: EVI")]),t._v(" "),s("p",[t._v("The formula for the Enhanced Vegetation Index is a bit more complicated than the NDVI one and contains constants. But we also don't necessarily need an openEO defined function and can concentrate on implementing a more complex formula. Here's the most efficient way to do this, per client.")]),t._v(" "),s("CodeSwitcher",{scopedSlots:t._u([{key:"py",fn:function(){return[s("div",{staticClass:"language-python extra-class"},[s("pre",{pre:!0,attrs:{class:"language-python"}},[s("code",[s("span",{pre:!0,attrs:{class:"token comment"}},[t._v('# extract and reduce all bands via "band"')]),t._v("\nB02 "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" cube_s2"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),t._v("band"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"B02"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\nB04 "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" cube_s2"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),t._v("band"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"B04"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\nB08 "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" cube_s2"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),t._v("band"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"B08"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n\n"),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# write formula")]),t._v("\ncube_s2_evi "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("2.5")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("*")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("B08 "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("-")]),t._v(" B04"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("/")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("B08 "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("+")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("6.0")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("*")]),t._v(" B04 "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("-")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("7.5")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("*")]),t._v(" B02"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("+")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("1.0")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n")])])])]},proxy:!0},{key:"r",fn:function(){return[s("div",{staticClass:"language-r extra-class"},[s("pre",{pre:!0,attrs:{class:"language-r"}},[s("code",[s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# in R, there's no shorter way to define bandmath")]),t._v("\nevi_ "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("<-")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("function")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("x"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" context"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("{")]),t._v("\n b2 "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("<-")]),t._v(" x"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("1")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),t._v("\n b4 "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("<-")]),t._v(" x"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("2")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),t._v("\n b8 "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("<-")]),t._v(" x"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("3")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),t._v("\n return"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("2.5")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("*")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("b8 "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("-")]),t._v(" b4"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("/")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("b8 "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("+")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("6")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("*")]),t._v(" b4 "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("-")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("7.5")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("*")]),t._v(" b2"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("+")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("1")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("}")]),t._v("\n\n"),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# reduce_dimension bands with the defined formula")]),t._v("\ncube_s2_evi "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("<-")]),t._v(" p"),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("$")]),t._v("reduce_dimension"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("data "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" cube_s2"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" reducer "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" evi_"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" dimension "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"bands"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n")])])])]},proxy:!0},{key:"js",fn:function(){return[s("div",{staticClass:"language-js extra-class"},[s("pre",{pre:!0,attrs:{class:"language-js"}},[s("code",[s("span",{pre:!0,attrs:{class:"token comment"}},[t._v('// "new Formula" is the quickest way to provide a bandmath formula')]),t._v("\ncube_s2_evi "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" builder"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("reduce_dimension")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("cube_s2"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("new")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token class-name"}},[t._v("Formula")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"(2.5 * ($B08 - $B04)) / (($B08 + 6 * $B04 - 7.5 * $B02) + 1)"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"bands"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n")])])])]},proxy:!0}])}),t._v(" "),s("h3",{attrs:{id:"masks-mask"}},[s("a",{staticClass:"header-anchor",attrs:{href:"#masks-mask"}},[t._v("#")]),t._v(" Masks: "),s("code",[t._v("mask")])]),t._v(" "),s("p",[t._v("Masking generally refers to excluding (or replacing) specific areas from an image. This is usually done by providing a boolean mask that detemines which pixels to replace with a no-data value, and which to leave as they are. In the following we will consider two cases: a) Creating a mask from classification classes and b) creating a mask by thresholding an image.")]),t._v(" "),s("h4",{attrs:{id:"mask-out-specific-values"}},[s("a",{staticClass:"header-anchor",attrs:{href:"#mask-out-specific-values"}},[t._v("#")]),t._v(" Mask Out Specific Values")]),t._v(" "),s("p",[t._v("In some cases we want to mask our data with other data. A common example is to mask out clouds, which optical satellites can not see through. Some Sentinel 2 collections provide the "),s("code",[t._v("SCL")]),t._v(" classification band (see the table of classes "),s("a",{attrs:{href:"https://sentinels.copernicus.eu/web/sentinel/technical-guides/sentinel-2-msi/level-2a/algorithm",target:"_blank",rel:"noopener noreferrer"}},[t._v("at the bottom here"),s("OutboundLink")],1),t._v("), providing a representation coded into land cover classes. In this classification, vegetation is coded as "),s("code",[t._v("4")]),t._v(" and non-vegetation as "),s("code",[t._v("5")]),t._v(", while e.g. clouds are coded as "),s("code",[t._v("8")]),t._v(" to "),s("code",[t._v("10")]),t._v(".")]),t._v(" "),s("p",[t._v("In the following, we're building a mask using some logical operations as a child process while reducing the dimension "),s("code",[t._v("bands")]),t._v(". As explained at "),s("a",{attrs:{href:"#example-1-ndvi"}},[t._v("Example 1: NDVI")]),t._v(" this is done to be left with a cube that has no dimension "),s("code",[t._v("bands")]),t._v(". In R and JavaScript, we write a function "),s("code",[t._v("filter_")]),t._v(" that turns the values of the "),s("code",[t._v("SCL")]),t._v(" band into "),s("code",[t._v("0")]),t._v("s (for (non-) vegetation) and "),s("code",[t._v("1")]),t._v("s (for all others), and ignores all other bands. During "),s("code",[t._v("mask")]),t._v(", all "),s("code",[t._v("1")]),t._v("s (i.e. "),s("code",[t._v("TRUE")]),t._v(") pixels will be replaced, and as we don't define a replacement they will simply be set to "),s("code",[t._v("null")]),t._v(". In Python, in-line logical operations can be used.")]),t._v(" "),s("CodeSwitcher",{scopedSlots:t._u([{key:"py",fn:function(){return[s("div",{staticClass:"language-python extra-class"},[s("pre",{pre:!0,attrs:{class:"language-python"}},[s("code",[s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# get classification band")]),t._v("\nSCL "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" cube_s2"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),t._v("band"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"SCL"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n\n"),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# we want to mask all other values, so NOT (4 OR 5)")]),t._v("\ncube_s2_mask "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("~")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("SCL "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("==")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("4")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("|")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("SCL "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("==")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("5")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n\n"),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# masking")]),t._v("\ncube_s2_masked "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" cube_s2"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),t._v("mask"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("cube_s2_mask"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n")])])])]},proxy:!0},{key:"r",fn:function(){return[s("div",{staticClass:"language-r extra-class"},[s("pre",{pre:!0,attrs:{class:"language-r"}},[s("code",[s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# define filter function to create mask")]),t._v("\nfilter_function "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("<-")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("function")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("data"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" context"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("{")]),t._v("\n vegetation "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("<-")]),t._v(" p"),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("$")]),t._v("eq"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("data"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"SCL"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("4")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# vegetation is 4")]),t._v("\n non_vegetation "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("<-")]),t._v(" p"),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("$")]),t._v("eq"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("data"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"SCL"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("5")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# non-vegetation is 5")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# we want to mask all other values, so NOT (4 OR 5)")]),t._v("\n return"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("p"),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("$")]),t._v("not"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("p"),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("$")]),t._v("or"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("vegetation"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" non_vegetation"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("}")]),t._v("\n\n"),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# create mask by reducing bands with our defined formula")]),t._v("\ncube_s2_mask "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("<-")]),t._v(" p"),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("$")]),t._v("reduce_dimension"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("data "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" cube_s2"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" reducer "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" filter_function"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" dimension "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"bands"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n\n"),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# mask the NDVI data")]),t._v("\ncube_s2_masked "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("<-")]),t._v(" p"),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("$")]),t._v("mask"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("cube_s2"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" cube_s2_mask"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n")])])])]},proxy:!0},{key:"js",fn:function(){return[s("div",{staticClass:"language-js extra-class"},[s("pre",{pre:!0,attrs:{class:"language-js"}},[s("code",[s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("// filter classification layer")]),t._v("\n"),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("var")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token function-variable function"}},[t._v("filter_function")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("function")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token parameter"}},[t._v("data"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" context")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("{")]),t._v("\n vegetation "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("this")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("eq")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("data"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"SCL"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("4")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("// vegetation is 4")]),t._v("\n non_vegetation "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("this")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("eq")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("data"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"SCL"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("5")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("// non-vegetation is 5")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("// we want to mask all other values, so NOT (4 OR 5)")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("return")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("this")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("not")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("this")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("or")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("vegetation"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" non_vegetation"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("}")]),t._v("\n\n"),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("// create mask by reducing bands")]),t._v("\ncube_s2_mask "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" builder"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("reduce_dimension")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("cube_s2"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" filter_function"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"bands"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n\n"),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("// mask")]),t._v("\ncube_s2_masked "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" builder"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("mask")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("cube_s2"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" cube_s2_mask"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n")])])])]},proxy:!0}])}),t._v(" "),s("p",[t._v('As with all functionality there are differences between back-ends. If this first example "Mask Out Specific Values" doesn\'t work for you, that could be because we are trying to apply a mask (a cube with dimensions '),s("code",[t._v("x")]),t._v(", "),s("code",[t._v("y")]),t._v(", "),s("code",[t._v("t")]),t._v(") to the input data (a cube with dimensions "),s("code",[t._v("x")]),t._v(", "),s("code",[t._v("y")]),t._v(", "),s("code",[t._v("t")]),t._v(", "),s("code",[t._v("bands")]),t._v(") and thus, cubes with different dimensionality. If you encounter such a problem, try applying the first mask to the NDVI cube (with dimensions "),s("code",[t._v("x")]),t._v(", "),s("code",[t._v("y")]),t._v(", "),s("code",[t._v("t")]),t._v(') as it is shown in the second example "Thresholds".')]),t._v(" "),s("h4",{attrs:{id:"thresholds"}},[s("a",{staticClass:"header-anchor",attrs:{href:"#thresholds"}},[t._v("#")]),t._v(" Thresholds")]),t._v(" "),s("p",[t._v("In this scenario we want an image that contains all NDVI values above 0.3, and holds no-data values otherwise. This could be useful to have a look at the vegetation in the area, without being distracted by all other NDVI values. For this example we reuse the NDVI cube "),s("code",[t._v("cube_s2_ndvi")]),t._v(" that was calculated in the "),s("a",{attrs:{href:"#example-1-ndvi"}},[t._v("NDVI bandmath-example")]),t._v(", thus for this to work you must include said code into your script.")]),t._v(" "),s("p",[t._v("If you look closely, you'll notice that this time we're not using "),s("code",[t._v("reduce_dimension")]),t._v(" to construct our masking cube (in contrast to "),s("a",{attrs:{href:"#mask-out-specific-values"}},[t._v("Mask out Specific Values")]),t._v("). In R and JavaScript we use "),s("code",[t._v("apply")]),t._v(" instead, and in the python client no "),s("code",[t._v(".band()")]),t._v(" is necessary anymore. This is because when we were masking using specific values of the band "),s("code",[t._v("SCL")]),t._v(", we were using the "),s("code",[t._v("cube_s2")]),t._v(" (with the bands "),s("code",[t._v("B02")]),t._v(", "),s("code",[t._v("B04")]),t._v(", "),s("code",[t._v("B08")]),t._v(" and "),s("code",[t._v("SCL")]),t._v(") as input. We then reduced the "),s("code",[t._v("bands")]),t._v(" dimension by writing and passing the function "),s("code",[t._v("filter_")]),t._v(", which returned a cube that had no "),s("code",[t._v("bands")]),t._v(" dimension anymore but "),s("code",[t._v("1")]),t._v("s and "),s("code",[t._v("0")]),t._v("s according to what we wanted to mask.")]),t._v(" "),s("p",[t._v("Here, we are making a mask out of the "),s("code",[t._v("cube_s2_ndvi")]),t._v(", a cube that had its "),s("code",[t._v("band")]),t._v(" dimension already reduced when the NDVI was calculated. To turn its values into "),s("code",[t._v("1")]),t._v("s and "),s("code",[t._v("0")]),t._v("s, we only need to "),s("code",[t._v("apply")]),t._v(" a threshold function. For this we utilize the openEO defined function "),s("code",[t._v("lt")]),t._v(' ("less than"). As usual the clients expose different ways of getting to that function, one of which is shown below.')]),t._v(" "),s("CodeSwitcher",{scopedSlots:t._u([{key:"py",fn:function(){return[s("div",{staticClass:"language-python extra-class"},[s("pre",{pre:!0,attrs:{class:"language-python"}},[s("code",[s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# create mask that is TRUE for NDVI < 0.3")]),t._v("\nndvi_threshold "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" cube_s2_ndvi "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("<")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("0.3")]),t._v("\n\n"),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# apply mask to NDVI")]),t._v("\ncube_s2_ndvi_masked "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" cube_s2_ndvi"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),t._v("mask"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("ndvi_threshold"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n")])])])]},proxy:!0},{key:"r",fn:function(){return[s("div",{staticClass:"language-r extra-class"},[s("pre",{pre:!0,attrs:{class:"language-r"}},[s("code",[t._v("threshold_ "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("<-")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("function")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("data"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" context"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("{")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# create mask that is TRUE for NDVI < 0.3")]),t._v("\n threshold "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("<-")]),t._v(" p"),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("$")]),t._v("lt"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("data"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("1")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("0.3")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n return"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("threshold"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("}")]),t._v("\n\n"),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# apply the threshold to the NDVI cube")]),t._v("\nndvi_threshold "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("<-")]),t._v(" p"),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("$")]),t._v("apply"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("data "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" cube_s2_ndvi"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" process "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" threshold_"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n\n"),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# mask the NDVI cube with the calculated mask")]),t._v("\ncube_s2_ndvi_masked "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("<-")]),t._v(" p"),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("$")]),t._v("mask"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("cube_s2_ndvi"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" ndvi_threshold"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n")])])])]},proxy:!0},{key:"js",fn:function(){return[s("div",{staticClass:"language-js extra-class"},[s("pre",{pre:!0,attrs:{class:"language-js"}},[s("code",[s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("// create mask that is TRUE for NDVI < 0.3 via an arrow function")]),t._v("\nndvi_threshold "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("builder")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("apply")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("cube_s2_ndvi"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token parameter"}},[t._v("data"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" _"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" child")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=>")]),t._v(" child"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("lt")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("data"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("0")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("0.3")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n\n"),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("// apply mask to NDVI cube")]),t._v("\ncube_s2_ndvi_masked "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" builder"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("mask")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("cube_s2_ndvi"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" ndvi_threshold"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n")])])])]},proxy:!0}])}),t._v(" "),s("figure",[s("img",{attrs:{src:a(319),alt:"The NDVI with a threshold of 0.3 applied"}}),t._v(" "),s("figcaption",[t._v("Applying the above described threshold to the NDVI yields this result. Water and artificial surfaces are mostly masked from the image.")])]),t._v(" "),s("h3",{attrs:{id:"pixel-operations-apply"}},[s("a",{staticClass:"header-anchor",attrs:{href:"#pixel-operations-apply"}},[t._v("#")]),t._v(" Pixel Operations: "),s("code",[t._v("apply")])]),t._v(" "),s("p",[t._v("As we remember from the "),s("RouterLink",{attrs:{to:"/documentation/1.0/datacubes.html#apply"}},[t._v("datacube guide")]),t._v(", unary processes take only the pixel itself into account when calculating new pixel values. We can implement that with the "),s("code",[t._v("apply")]),t._v(" function and a child process that is in charge of modifying the pixel values. In our first example, that will be the square root. The openEO function is called "),s("code",[t._v("sqrt")]),t._v(". In the following we'll see how to pass it to the "),s("code",[t._v("apply")]),t._v(" process.")],1),t._v(" "),s("CodeSwitcher",{scopedSlots:t._u([{key:"py",fn:function(){return[s("div",{staticClass:"language-python extra-class"},[s("pre",{pre:!0,attrs:{class:"language-python"}},[s("code",[s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# pass unary child process as string")]),t._v("\ncube_s2_sqrt "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" cube_s2"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token builtin"}},[t._v("apply")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"sqrt"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n")])])])]},proxy:!0},{key:"r",fn:function(){return[s("div",{staticClass:"language-r extra-class"},[s("pre",{pre:!0,attrs:{class:"language-r"}},[s("code",[s("span",{pre:!0,attrs:{class:"token comment"}},[t._v('# pass unary child process as a function, call "sqrt" from openEO processes "p"')]),t._v("\ncube_s2_sqrt "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("<-")]),t._v(" p"),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("$")]),t._v("apply"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("cube_s2"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("function")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("x"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" context"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("{")]),t._v(" return"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("sqrt"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("x"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("}")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n")])])])]},proxy:!0},{key:"js",fn:function(){return[s("div",{staticClass:"language-js extra-class"},[s("pre",{pre:!0,attrs:{class:"language-js"}},[s("code",[s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("// pass unary child process via arrow function")]),t._v("\n"),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("var")]),t._v(" cube_s2_sqrt "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("builder")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("apply")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("cube_s2"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token parameter"}},[t._v("data"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" _"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" child")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=>")]),t._v(" child"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("sqrt")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("data"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n")])])])]},proxy:!0}])}),t._v(" "),s("p",[t._v("Let's say we're not looking at optical but SAR imagery. Depending on the collection held by the back-end, this data could already be log-scaled. In case it isn't, we may want to transform our data from intensity values to db. This formula is a bit more complicated: 10 * log"),s("sub",[t._v("10")]),t._v("(x). So we'll need a multiplication (by 10) and a "),s("code",[t._v("log")]),t._v(" process (to the "),s("code",[t._v("base")]),t._v(" 10).")]),t._v(" "),s("p",[t._v("Prior to applying the following code, we must load a collection containing SAR intensity data (e.g. Sentinel 1 GRD product).")]),t._v(" "),s("CodeSwitcher",{scopedSlots:t._u([{key:"py",fn:function(){return[s("div",{staticClass:"language-python extra-class"},[s("pre",{pre:!0,attrs:{class:"language-python"}},[s("code",[s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# import the defined openEO process")]),t._v("\n"),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("from")]),t._v(" openeo"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),t._v("processes "),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("import")]),t._v(" log\n\n"),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# define a child process")]),t._v("\n"),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("def")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("log_")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("x"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(":")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("return")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("10")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("*")]),t._v(" log"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("x"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("10")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n\n"),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v('# supply that function to the "apply" call')]),t._v("\ncube_s1_log10 "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" cube_s1"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token builtin"}},[t._v("apply")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("log_"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n")])])])]},proxy:!0},{key:"r",fn:function(){return[s("div",{staticClass:"language-r extra-class"},[s("pre",{pre:!0,attrs:{class:"language-r"}},[s("code",[s("span",{pre:!0,attrs:{class:"token comment"}},[t._v('# call multiply, log functions from "p"')]),t._v("\ncube_s1_log10 "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("<-")]),t._v(" p"),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("$")]),t._v("apply"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("cube_s1"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("function")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("x"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" context"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("{")]),t._v("p"),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("$")]),t._v("multiply"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("10")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" p"),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("$")]),t._v("log"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("x"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("10")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("}")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n")])])])]},proxy:!0},{key:"js",fn:function(){return[s("div",{staticClass:"language-js extra-class"},[s("pre",{pre:!0,attrs:{class:"language-js"}},[s("code",[s("span",{pre:!0,attrs:{class:"token comment"}},[t._v('// use openEO "log", "multiply" via arrow function')]),t._v("\ncube_s1_log10 "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("builder")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("apply")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("cube_s1"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token parameter"}},[t._v("data"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" _"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" child")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=>")]),t._v(" child"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("multiply")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("10")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" child"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("log")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("data"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("10")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n")])])])]},proxy:!0}])}),t._v(" "),s("figure",[s("img",{attrs:{src:a(320),alt:"The AOI image is split into two parts: The upper part depicts SAR data with some very bright and many very dark pixels, the lower part is more balanced."}}),t._v(" "),s("figcaption",[t._v("Here we see the effect of transforming intensity data to db: Both parts of the image are linearly scaled, but only the lower part has been log-transformed. It makes the interpretation much easier because image pixels take on less 'extreme' values.")])]),t._v(" "),s("h3",{attrs:{id:"image-kernels-apply-kernel"}},[s("a",{staticClass:"header-anchor",attrs:{href:"#image-kernels-apply-kernel"}},[t._v("#")]),t._v(" Image Kernels: "),s("code",[t._v("apply_kernel")])]),t._v(" "),s("p",[t._v("The process "),s("code",[t._v("apply_kernel")]),t._v(" takes an array of weights that is used as a moving window to calculate new pixel values. This is often used to smooth or sharped the image (e.g. Gaussian blur or highpass filter, respectively). Here, we show two Sobel edge detection kernels (both vertical and horizontal) and a highpass filter.")]),t._v(" "),s("p",[t._v("We'll only consider band 8 to shorten computation time.")]),t._v(" "),s("CodeSwitcher",{scopedSlots:t._u([{key:"py",fn:function(){return[s("div",{staticClass:"language-python extra-class"},[s("pre",{pre:!0,attrs:{class:"language-python"}},[s("code",[t._v("cube_s2_b8 "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" cube_s2"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),t._v("filter_bands"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"B08"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n")])])])]},proxy:!0},{key:"r",fn:function(){return[s("div",{staticClass:"language-r extra-class"},[s("pre",{pre:!0,attrs:{class:"language-r"}},[s("code",[t._v("cube_s2_b8 "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("<-")]),t._v(" p"),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("$")]),t._v("filter_bands"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("cube_s2"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" c"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"B08"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n")])])])]},proxy:!0},{key:"js",fn:function(){return[s("div",{staticClass:"language-js extra-class"},[s("pre",{pre:!0,attrs:{class:"language-js"}},[s("code",[t._v("cube_s2_b8 "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" builder"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("filter_bands")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("cube_s2"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"B08"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n")])])])]},proxy:!0}])}),t._v(" "),s("p",[t._v("Throughout all clients we can define the kernel as an array of arrays, of which the inner arrays represent lines ("),s("code",[t._v("x")]),t._v(") and the outer arrays columns ("),s("code",[t._v("y")]),t._v("). This means that by adding a line break after each inner array, a true representation of the kernel can be created (see "),s("code",[t._v("highpass")]),t._v(" in Python or JavaScript tab).")]),t._v(" "),s("p",[t._v("The parameters "),s("code",[t._v("factor")]),t._v(" and "),s("code",[t._v("border")]),t._v(" are not needed here and are left out to fall back to default. "),s("code",[t._v("factor")]),t._v(" (default "),s("code",[t._v("1")]),t._v(") is multiplied with each pixel after the focal operation, while "),s("code",[t._v("border")]),t._v(" (default "),s("code",[t._v("0")]),t._v(") defines how overlaps between the kernel and the image borders are handled (should pixel values be mirrored, replicated or simply set to 0?, see "),s("RouterLink",{attrs:{to:"/documentation/1.0/processes.html#apply_kernel"}},[s("code",[t._v("apply_kernel")])]),t._v(").")],1),t._v(" "),s("CodeSwitcher",{scopedSlots:t._u([{key:"py",fn:function(){return[s("div",{staticClass:"language-python extra-class"},[s("pre",{pre:!0,attrs:{class:"language-python"}},[s("code",[s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# we can pass a kernel as an array of arrays")]),t._v("\nsobel_vertical "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("1")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("2")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("1")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("0")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("0")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("0")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("-")]),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("1")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("-")]),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("2")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("-")]),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("1")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# e.g. 3x3 edge detection")]),t._v("\nsobel_horizontal "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("1")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("0")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("-")]),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("1")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("2")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("0")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("-")]),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("2")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("1")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("0")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("-")]),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("1")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),t._v("\n\nhighpass "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# or 5x5 highpass filter")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("-")]),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("1")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("-")]),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("1")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("-")]),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("1")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("-")]),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("1")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("-")]),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("1")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("-")]),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("1")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("-")]),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("1")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("-")]),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("1")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("-")]),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("1")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("-")]),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("1")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("-")]),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("1")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("-")]),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("1")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("24")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("-")]),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("1")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("-")]),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("1")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("-")]),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("1")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("-")]),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("1")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("-")]),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("1")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("-")]),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("1")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("-")]),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("1")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("-")]),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("1")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("-")]),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("1")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("-")]),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("1")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("-")]),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("1")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("-")]),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("1")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),t._v("\n"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),t._v("\n\n"),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# apply to cube")]),t._v("\ncube_s2_highpass "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" cube_s2_b8"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),t._v("apply_kernel"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("highpass"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n")])])])]},proxy:!0},{key:"r",fn:function(){return[s("div",{staticClass:"language-r extra-class"},[s("pre",{pre:!0,attrs:{class:"language-r"}},[s("code",[s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# we can pass a kernel as an array of arrays")]),t._v("\nsobel_vertical "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("<-")]),t._v(" matrix"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("c"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("1")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("2")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("1")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("0")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("0")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("0")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("-")]),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("1")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("-")]),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("2")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("-")]),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("1")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" nrow "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("3")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" byrow "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token boolean"}},[t._v("TRUE")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v(" \nsobel_horizontal "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("<-")]),t._v(" matrix"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("c"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("1")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("2")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("1")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("0")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("0")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("0")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("-")]),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("1")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("-")]),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("2")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("-")]),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("1")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" nrow "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("3")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# e.g. 3x3 edge detection")]),t._v("\n\nhighpass_vector "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("<-")]),t._v(" c"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("rep"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("-")]),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("1")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("12")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("24")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" rep"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("-")]),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("1")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("12")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\nhighpass "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("<-")]),t._v(" matrix"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("highpass_vector"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" nrow "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("5")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# or 5x5 highpass filter")]),t._v("\n\n"),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# apply to cube")]),t._v("\ncube_s2_b8_highpass "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("<-")]),t._v(" p"),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("$")]),t._v("apply_kernel"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("data "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" cube_s2_b8"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" kernel "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" highpass"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n")])])])]},proxy:!0},{key:"js",fn:function(){return[s("div",{staticClass:"language-js extra-class"},[s("pre",{pre:!0,attrs:{class:"language-js"}},[s("code",[s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("// we can pass a kernel as an array of arrays")]),t._v("\n"),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("let")]),t._v(" sobel_vertical "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("1")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("2")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("1")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("0")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("0")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("0")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("-")]),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("1")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("-")]),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("2")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("-")]),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("1")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("// e.g. 3x3 edge detection")]),t._v("\n"),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("let")]),t._v(" sobel_horizontal "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("1")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("0")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("-")]),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("1")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("2")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("0")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("-")]),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("2")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("1")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("0")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("-")]),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("1")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),t._v("\n\n"),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("let")]),t._v(" highpass "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("// or 5x5 highpass filter")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("-")]),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("1")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("-")]),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("1")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("-")]),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("1")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("-")]),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("1")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("-")]),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("1")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("-")]),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("1")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("-")]),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("1")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("-")]),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("1")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("-")]),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("1")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("-")]),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("1")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("-")]),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("1")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("-")]),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("1")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("24")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("-")]),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("1")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("-")]),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("1")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("-")]),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("1")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("-")]),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("1")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("-")]),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("1")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("-")]),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("1")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("-")]),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("1")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("-")]),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("1")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("-")]),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("1")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("-")]),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("1")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("-")]),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("1")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("-")]),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("1")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),t._v("\n"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),t._v("\n\n"),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("// apply to cube")]),t._v("\n"),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("var")]),t._v(" cube_s2_highpass "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" builder"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("apply_kernel")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("cube_s2_b8"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" highpass"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n")])])])]},proxy:!0}])}),t._v(" "),s("figure",[s("img",{attrs:{src:a(321),alt:"A combined edge detection RGB. Sobel vertical and horizontal are displayed as red and green, a 5x5 highpass filter is displayed as blue."}}),t._v(" "),s("figcaption",[t._v("Above a combined edge detection RGB can be seen. Sobel 3x3 vertical and horizontal edge detections are displayed as red and green, and a 5x5 highpass filter is displayed as blue. For this, all kernels in the code block above were applied and the sucessive cubes were merged afterwards.")])]),t._v(" "),s("h2",{attrs:{id:"endnote"}},[s("a",{staticClass:"header-anchor",attrs:{href:"#endnote"}},[t._v("#")]),t._v(" Endnote")]),t._v(" "),s("p",[t._v("You have "),s("strong",[t._v("feedback or")]),t._v(" noticed an "),s("strong",[t._v("error")]),t._v("? Feel free to open an issue in the "),s("a",{attrs:{href:"https://github.com/Open-EO/openeo.org",target:"_blank",rel:"noopener noreferrer"}},[t._v("github repository"),s("OutboundLink")],1),t._v(" or use the "),s("a",{attrs:{href:"https://openeo.org/contact.html",target:"_blank",rel:"noopener noreferrer"}},[t._v("other communication channels"),s("OutboundLink")],1)])],1)}),[],!1,null,null,null);s.default=e.exports}}]); \ No newline at end of file +(window.webpackJsonp=window.webpackJsonp||[]).push([[18],{303:function(t,s,a){t.exports=a.p+"assets/img/urk_scaling.1f27c164.jpg"},304:function(t,s,a){t.exports=a.p+"assets/img/urk.e6564348.jpg"},305:function(t,s,a){t.exports=a.p+"assets/img/pellworm_248.29ad280d.jpg"},306:function(t,s,a){t.exports=a.p+"assets/img/pellworm_ndvi.36c775d8.jpg"},307:function(t,s,a){t.exports=a.p+"assets/img/pellworm_threshold.be97c121.jpg"},308:function(t,s,a){t.exports=a.p+"assets/img/pellworm_s1.acf74ce7.jpg"},309:function(t,s,a){t.exports=a.p+"assets/img/pellworm_kernels.d12dda41.jpg"},512:function(t,s,a){"use strict";a.r(s);var n=a(4),e=Object(n.a)({},(function(){var t=this,s=t._self._c;return s("ContentSlotsDistributor",{attrs:{"slot-key":t.$parent.slotKey}},[s("h1",{attrs:{id:"openeo-cookbook"}},[s("a",{staticClass:"header-anchor",attrs:{href:"#openeo-cookbook"}},[t._v("#")]),t._v(" openEO Cookbook")]),t._v(" "),s("p",[t._v("This is the openEO cookbook that you can refer to to get a first idea on how to solve problems with openEO in the three client languages Python, R and JavaScript. It describes how to implement simple use cases in a pragmatic way.")]),t._v(" "),s("p",[t._v("Please refer to the getting started guides for "),s("RouterLink",{attrs:{to:"/documentation/1.0/javascript/"}},[t._v("JavaScript")]),t._v(", "),s("RouterLink",{attrs:{to:"/documentation/1.0/python/"}},[t._v("Python")]),t._v(" and "),s("RouterLink",{attrs:{to:"/documentation/1.0/r/"}},[t._v("R")]),t._v(" if you have never worked with one of the openEO client libraries before. This guide requires you to have a basic idea of how to establish a connection to a back-end and how to explore that back-end.")],1),t._v(" "),s("div",{staticClass:"custom-block tip"},[s("p",{staticClass:"custom-block-title"},[t._v("References")]),t._v(" "),s("ul",[s("li",[s("RouterLink",{attrs:{to:"/documentation/1.0/processes.html"}},[t._v("openEO processes documentation")])],1),t._v(" "),s("li",[s("a",{attrs:{href:"https://hub.openeo.org",target:"_blank",rel:"noopener noreferrer"}},[t._v("openEO Hub"),s("OutboundLink")],1),t._v(" to discover back-ends with available data and processes")]),t._v(" "),s("li",[s("a",{attrs:{href:"https://editor.openeo.org",target:"_blank",rel:"noopener noreferrer"}},[t._v("openEO Web Editor"),s("OutboundLink")],1),t._v(" to visually build and execute processing workflows")])]),t._v(" "),s("hr"),t._v(" "),s("ul",[s("li",[s("a",{attrs:{href:"https://open-eo.github.io/openeo-python-client/index.html",target:"_blank",rel:"noopener noreferrer"}},[t._v("Python client documentation"),s("OutboundLink")],1)]),t._v(" "),s("li",[s("a",{attrs:{href:"https://open-eo.github.io/openeo-js-client/latest/index.html",target:"_blank",rel:"noopener noreferrer"}},[t._v("JavaScript client documentation"),s("OutboundLink")],1)]),t._v(" "),s("li",[s("a",{attrs:{href:"https://open-eo.github.io/openeo-r-client/index.html",target:"_blank",rel:"noopener noreferrer"}},[t._v("R client documentation"),s("OutboundLink")],1)])])]),t._v(" "),s("h2",{attrs:{id:"chapter-1"}},[s("a",{staticClass:"header-anchor",attrs:{href:"#chapter-1"}},[t._v("#")]),t._v(" Chapter 1")]),t._v(" "),s("p",[t._v("In this chapter, we want to explore the different output formats that are possible with openEO. For that, we load and filter a collection (a datacube) of satellite data and calculate the temporal mean of that data. Different steps (e.g. a linear scaling) are done to prepare for the data to be output in one of the formats: Raster or text data.")]),t._v(" "),s("p",[t._v("Throughout this guide, code examples for all three client languages are given. Select your preferred language with the code switcher on the right-hand side to set all examples to that language.")]),t._v(" "),s("h3",{attrs:{id:"connecting-to-a-back-end"}},[s("a",{staticClass:"header-anchor",attrs:{href:"#connecting-to-a-back-end"}},[t._v("#")]),t._v(" Connecting to a back-end")]),t._v(" "),s("p",[t._v("Click the link below to see how to connect to a back-end (via OpenID Connect). You can call the connection object "),s("code",[t._v("con")]),t._v(" as it is done in all following code, to avoid confusion throughout the rest of the tutorials.")]),t._v(" "),s("CodeSwitcher",{scopedSlots:t._u([{key:"py",fn:function(){return[s("p",[s("RouterLink",{attrs:{to:"/documentation/1.0/python/#openid-connect-authentication"}},[t._v("Getting started: Authentication")])],1)]},proxy:!0},{key:"r",fn:function(){return[s("p",[s("RouterLink",{attrs:{to:"/documentation/1.0/r/#openid-connect-authentication"}},[t._v("Getting started: Authentication")])],1)]},proxy:!0},{key:"js",fn:function(){return[s("p",[s("RouterLink",{attrs:{to:"/documentation/1.0/javascript/#openid-connect-authentication"}},[t._v("Getting started: Authentication")])],1)]},proxy:!0}])}),t._v(" "),s("p",[t._v("In R and JavaScript it is very useful to assign a graph-building helper object to a variable, to easily access all openEO processes and add them to the process graph that you will be building. These objects will be used throughout this guide. In Python, it also helps to import a helper object, even though we'll need it less often.")]),t._v(" "),s("CodeSwitcher",{scopedSlots:t._u([{key:"py",fn:function(){return[s("div",{staticClass:"language-python extra-class"},[s("pre",{pre:!0,attrs:{class:"language-python"}},[s("code",[s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# import ProcessBuilder functions")]),t._v("\n"),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("from")]),t._v(" openeo"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),t._v("processes "),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("import")]),t._v(" ProcessBuilder\n")])])]),s("p",[s("strong",[t._v("Note:")]),t._v(" Many functions in "),s("em",[t._v("child processes")]),t._v(" (see below), are instances of this "),s("code",[t._v("ProcessBuilder")]),t._v(" import.")])]},proxy:!0},{key:"r",fn:function(){return[s("div",{staticClass:"language-r extra-class"},[s("pre",{pre:!0,attrs:{class:"language-r"}},[s("code",[s("span",{pre:!0,attrs:{class:"token comment"}},[t._v('# assign the graph-building helper object to "p" for easy access to all openEO processes, see > ?processes()')]),t._v("\np "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("<-")]),t._v(" processes"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n")])])]),s("p",[s("strong",[t._v("Note:")]),t._v(" In all R code, "),s("code",[t._v("p")]),t._v(" is used to select openEO processes.")])]},proxy:!0},{key:"js",fn:function(){return[s("div",{staticClass:"language-js extra-class"},[s("pre",{pre:!0,attrs:{class:"language-js"}},[s("code",[s("span",{pre:!0,attrs:{class:"token comment"}},[t._v('// assign the graph-building helper object to "builder" for easy access to all openEO processes')]),t._v("\n"),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("var")]),t._v(" builder "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("await")]),t._v(" con"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("buildProcess")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(";")]),t._v("\n")])])]),s("p",[s("strong",[t._v("Note:")]),t._v(" In all JavaScript code, "),s("code",[t._v("builder")]),t._v(" is used to select openEO processes.")])]},proxy:!0}])}),t._v(" "),s("h3",{attrs:{id:"input-load-collection"}},[s("a",{staticClass:"header-anchor",attrs:{href:"#input-load-collection"}},[t._v("#")]),t._v(" Input: "),s("code",[t._v("load_collection")])]),t._v(" "),s("p",[t._v("Before loading a collection, we need to find out the exact name of a collection we want to use (back-end-specific, see references "),s("a",{attrs:{href:"#openeo-cookbook"}},[t._v("at the top")]),t._v("). We assign the spatial and temporal extent to variables, so that we can re-use them on other collections we might want to load. Let's look for a Sentinel 2 (preprocessed level 2A preferably) collection and load the green, red and a near-infrared band (bands 3, 4 and 8).")]),t._v(" "),s("div",{staticClass:"custom-block tip"},[s("p",{staticClass:"custom-block-title"},[t._v("Collection and Band Names")]),t._v(" "),s("p",[t._v("The names of collections and bands differ between back-ends. So always check the collection description for the correct names. The differences might be subtle, e.g. "),s("code",[t._v("B8")]),t._v(" vs. "),s("code",[t._v("B08")]),t._v(".")])]),t._v(" "),s("p",[t._v("We'll name our collection very explicitly "),s("code",[t._v("cube_s2_b348")]),t._v(" as to not get confused later on.")]),t._v(" "),s("CodeSwitcher",{scopedSlots:t._u([{key:"py",fn:function(){return[s("div",{staticClass:"language-python extra-class"},[s("pre",{pre:!0,attrs:{class:"language-python"}},[s("code",[s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# make dictionary, containing bounding box")]),t._v("\nurk "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("{")]),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"west"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(":")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("5.5661")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"south"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(":")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("52.6457")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"east"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(":")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("5.7298")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"north"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(":")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("52.7335")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("}")]),t._v("\n"),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# make list, containing the temporal interval")]),t._v("\nt "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"2021-04-26"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"2021-04-30"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),t._v("\n\n"),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# load first datacube")]),t._v("\ncube_s2_b348 "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" con"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),t._v("load_collection"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"COPERNICUS/S2_SR"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n spatial_extent "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" urk"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n temporal_extent "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" t"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n bands "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"B3"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"B4"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"B8"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),t._v("\n"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n")])])])]},proxy:!0},{key:"r",fn:function(){return[s("div",{staticClass:"language-r extra-class"},[s("pre",{pre:!0,attrs:{class:"language-r"}},[s("code",[s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# create variables for loading collection")]),t._v("\nurk "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("<-")]),t._v(" list"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("west "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("5.5661")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" south "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("52.6457")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" east "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("5.7298")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" north "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("52.7335")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n\nt "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("<-")]),t._v(" c"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"2021-04-26"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"2021-04-30"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n\n"),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# load first datacube")]),t._v("\ncube_s2_b348 "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("<-")]),t._v(" p"),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("$")]),t._v("load_collection"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("\n id "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"COPERNICUS/S2_SR"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n spatial_extent "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" urk"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n temporal_extent "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" t"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n bands"),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v("c"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"B3"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"B4"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"B8"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n")])])])]},proxy:!0},{key:"js",fn:function(){return[s("div",{staticClass:"language-js extra-class"},[s("pre",{pre:!0,attrs:{class:"language-js"}},[s("code",[s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("// make spatial and temporal extent")]),t._v("\n"),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("let")]),t._v(" urk "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("{")]),s("span",{pre:!0,attrs:{class:"token string-property property"}},[t._v('"west"')]),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v(":")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("5.5661")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string-property property"}},[t._v('"south"')]),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v(":")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("52.6457")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string-property property"}},[t._v('"east"')]),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v(":")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("5.7298")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string-property property"}},[t._v('"north"')]),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v(":")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("52.7335")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("}")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(";")]),t._v("\n\n"),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("let")]),t._v(" t "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"2021-04-26"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"2021-04-30"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(";")]),t._v(" \n\n"),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("// load first cube")]),t._v("\n"),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("var")]),t._v(" cube_s2_b348 "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" builder"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("load_collection")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"COPERNICUS/S2_SR"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n urk"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n t"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"B3"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"B4"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"B8"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),t._v("\n"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(";")]),t._v("\n")])])]),s("p",[s("strong",[t._v("Note:")]),t._v(" JavaScript doesn't use parameter names (like Python and R), so the parameters need to be in the order that they are defined in the "),s("RouterLink",{attrs:{to:"/documentation/1.0/processes.html"}},[t._v("openEO processes documentation")]),t._v(".")],1)]},proxy:!0}])}),t._v(" "),s("h3",{attrs:{id:"filter-bands-filter-bands"}},[s("a",{staticClass:"header-anchor",attrs:{href:"#filter-bands-filter-bands"}},[t._v("#")]),t._v(" Filter Bands: "),s("code",[t._v("filter_bands")])]),t._v(" "),s("p",[t._v("To go through the desired output formats, we'll need one collection with three bands, and one collection with only one band. Here we use "),s("code",[t._v("filter_bands")]),t._v(", when of course we could also just define a separate collection via "),s("code",[t._v("load_collection")]),t._v(". As our input datacube already has the required three bands, we filter it for a single band to create an additional datacube with the same spatial and temporal extent, but with only one band (band 8).")]),t._v(" "),s("p",[t._v("We'll name this one "),s("code",[t._v("cube_s2_b8")]),t._v(" to distinguish it from the original "),s("code",[t._v("cube_s2_b348")]),t._v(".")]),t._v(" "),s("CodeSwitcher",{scopedSlots:t._u([{key:"py",fn:function(){return[s("div",{staticClass:"language-python extra-class"},[s("pre",{pre:!0,attrs:{class:"language-python"}},[s("code",[s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# filter for band 8")]),t._v("\ncube_s2_b8 "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" cube_s2_b348"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),t._v("filter_bands"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("bands "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"B8"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n")])])])]},proxy:!0},{key:"r",fn:function(){return[s("div",{staticClass:"language-r extra-class"},[s("pre",{pre:!0,attrs:{class:"language-r"}},[s("code",[s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# filter for band 8")]),t._v("\ncube_s2_b8 "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("<-")]),t._v(" p"),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("$")]),t._v("filter_bands"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("data "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" cube_s2_b348"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" bands "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" c"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"B8"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n")])])])]},proxy:!0},{key:"js",fn:function(){return[s("div",{staticClass:"language-js extra-class"},[s("pre",{pre:!0,attrs:{class:"language-js"}},[s("code",[s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("// filter for band 8")]),t._v("\n"),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("var")]),t._v(" cube_s2_b8 "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" builder"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("filter_bands")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("cube_s2_b348"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"B08"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n")])])])]},proxy:!0}])}),t._v(" "),s("h3",{attrs:{id:"temporal-mean-reduce-dimension"}},[s("a",{staticClass:"header-anchor",attrs:{href:"#temporal-mean-reduce-dimension"}},[t._v("#")]),t._v(" Temporal Mean: "),s("code",[t._v("reduce_dimension")])]),t._v(" "),s("p",[t._v("As we don't want to download the raw collection of satellite data, we need to reduce that data somehow. That means, we want to get rid of one dimension. Let's say we calculate a "),s("code",[t._v("mean")]),t._v(" over all timesteps, and then drop the temporal dimension (as it's empty then anyway, see explanation in the "),s("RouterLink",{attrs:{to:"/documentation/1.0/datacubes.html#reduce"}},[t._v("datacube guide")]),t._v("). This can be done via "),s("code",[t._v("reduce_dimension()")]),t._v(". The function requires a reducer, in our case a "),s("code",[t._v("mean")]),t._v(" process, and the dimension over which to reduce, given as a string ("),s("code",[t._v('"t"')]),t._v(").")],1),t._v(" "),s("div",{staticClass:"custom-block tip"},[s("p",{staticClass:"custom-block-title"},[t._v("Child Processes")]),t._v(" "),s("p",[t._v("Here, we need to define a child process: A function that is called by (or passed to) another function, and then works on a subset of the datacube (somewhat similar to the concept of callbacks in JavaScript). In this case: We want "),s("code",[t._v("reduce_dimension")]),t._v(" to use the "),s("code",[t._v("mean")]),t._v(" function to average all timesteps of each pixel. Not any function can be used like this, it must be defined by openEO, of course.")]),t._v(" "),s("p",[t._v("All clients have more or less different specifics when defining a child process. As you can observe directly below, one way to define one is to define the function directly inside the parent process.")]),t._v(" "),s("p",[t._v("For a more clean way to define a child process, see the chapter below.")])]),t._v(" "),s("CodeSwitcher",{scopedSlots:t._u([{key:"py",fn:function(){return[s("div",{staticClass:"language-python extra-class"},[s("pre",{pre:!0,attrs:{class:"language-python"}},[s("code",[s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# reduce all timesteps")]),t._v("\n"),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# mean_time() is a shortcut function")]),t._v("\ncube_s2_b8_red "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" cube_s2_b8"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),t._v("mean_time"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n\n"),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# alternatively, 'reduce_dimension' can be used")]),t._v("\ncube_s2_b8_red "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" cube_s2_b8"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),t._v("reduce_dimension"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("dimension"),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"t"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" reducer"),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"mean"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n\n"),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# additionally, reduce second collection")]),t._v("\ncube_s2_b348_red "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" cube_s2_b348"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),t._v("mean_time"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n")])])]),s("p",[s("strong",[t._v("Note:")]),t._v(" In python, the child process can be a string.")])]},proxy:!0},{key:"r",fn:function(){return[s("div",{staticClass:"language-r extra-class"},[s("pre",{pre:!0,attrs:{class:"language-r"}},[s("code",[s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# reduce dimension, first collection")]),t._v("\ncube_s2_b8_red "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("<-")]),t._v(" p"),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("$")]),t._v("reduce_dimension"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("data "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" cube_s2_b8"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" reducer "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("function")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("data"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" context"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("{")]),t._v(" p"),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("$")]),t._v("mean"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("data"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("}")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" dimension "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"t"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n\n"),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# reduce, second collection")]),t._v("\ncube_s2_b348_red "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("<-")]),t._v(" p"),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("$")]),t._v("reduce_dimension"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("data "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" cube_s2_b348"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" reducer "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("function")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("data"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" context"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("{")]),t._v(" p"),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("$")]),t._v("mean"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("data"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("}")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" dimension "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"t"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n")])])]),s("p",[s("strong",[t._v("Note:")]),t._v(" In R, we can select a child process from the "),s("code",[t._v("p")]),t._v(" helper object.")])]},proxy:!0},{key:"js",fn:function(){return[s("div",{staticClass:"language-js extra-class"},[s("pre",{pre:!0,attrs:{class:"language-js"}},[s("code",[s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("// reduce dimension")]),t._v("\n"),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("var")]),t._v(" cube_s2_b8_red "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" builder"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("reduce_dimension")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("cube_s2_b8"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token parameter"}},[t._v("data"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" _"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" child")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=>")]),t._v(" child"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("mean")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("data"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"t"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(";")]),t._v("\n\n"),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("// second collection")]),t._v("\n"),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("var")]),t._v(" cube_s2_b348_red "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" builder"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("reduce_dimension")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("cube_s2_b348"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token parameter"}},[t._v("data"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" _"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" child")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=>")]),t._v(" child"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("mean")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("data"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"t"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(";")]),t._v("\n")])])]),s("p",[s("strong",[t._v("Note:")]),t._v(" In JavaScript, arrow functions can be used as child processes.")])]},proxy:!0}])}),t._v(" "),s("h3",{attrs:{id:"scale-all-pixels-linearly-apply-linear-scale-range"}},[s("a",{staticClass:"header-anchor",attrs:{href:"#scale-all-pixels-linearly-apply-linear-scale-range"}},[t._v("#")]),t._v(" Scale All Pixels Linearly: "),s("code",[t._v("apply")]),t._v(", "),s("code",[t._v("linear_scale_range")])]),t._v(" "),s("p",[t._v("To create a PNG output, we need to scale the satellite data we have down to the 8bit range of a PNG image. For this, the scale range of our imagery has to be known. For Sentinel 2 over urban and agricultural areas, we can use "),s("code",[t._v("6000")]),t._v(" as a maximum.")]),t._v(" "),s("p",[t._v("We'll use the process "),s("code",[t._v("linear_scale_range")]),t._v(". It takes a number and the four borders of the intervals as input. Because it works on a number and not a datacube as all processes discussed so far, we need to nest the process into an "),s("code",[t._v("apply")]),t._v(", once again defining a child process. "),s("code",[t._v("apply")]),t._v(" applies a unary process to all pixels of a datacube.")]),t._v(" "),s("p",[t._v("This time we'll also define our child processes externally, as to not get confused in too much code nesting.")]),t._v(" "),s("CodeSwitcher",{scopedSlots:t._u([{key:"py",fn:function(){return[s("div",{staticClass:"language-python extra-class"},[s("pre",{pre:!0,attrs:{class:"language-python"}},[s("code",[s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# define child process, use ProcessBuilder")]),t._v("\n"),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("def")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("scale_function")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("x"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(":")]),t._v(" ProcessBuilder"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(":")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("return")]),t._v(" x"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),t._v("linear_scale_range"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("0")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("6000")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("0")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("255")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n\n"),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# apply scale_function to all pixels")]),t._v("\ncube_s2_b348_red_lin "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" cube_s2_b348_red"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token builtin"}},[t._v("apply")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("scale_function"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n")])])]),s("p",[s("strong",[t._v("Resource:")]),t._v(" Refer to the "),s("a",{attrs:{href:"https://open-eo.github.io/openeo-python-client/processes.html#processes-with-child-callbacks",target:"_blank",rel:"noopener noreferrer"}},[t._v("Python client documentation"),s("OutboundLink")],1),t._v(" to learn more about child processes in Python.")])]},proxy:!0},{key:"r",fn:function(){return[s("div",{staticClass:"language-r extra-class"},[s("pre",{pre:!0,attrs:{class:"language-r"}},[s("code",[s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# define child process")]),t._v("\nscale_function "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("<-")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("function")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("x"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" context"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("{")]),t._v("\n p"),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("$")]),t._v("linear_scale_range"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("x"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" inputMin "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("0")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" inputMax "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("6000")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" outputMin "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("0")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" outputMax "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("255")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("}")]),t._v("\n\n"),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# apply scale range to all pixels")]),t._v("\ncube_s2_b348_red_lin "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("<-")]),t._v(" p"),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("$")]),t._v("apply"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("data "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" cube_s2_b348_red"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" process "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" scale_function"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n")])])])]},proxy:!0},{key:"js",fn:function(){return[s("div",{staticClass:"language-js extra-class"},[s("pre",{pre:!0,attrs:{class:"language-js"}},[s("code",[s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("// define child process (long way)")]),t._v("\n"),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("var")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token function-variable function"}},[t._v("scale_function")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("function")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token parameter"}},[t._v("x"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" context")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("{")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("return")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("this")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("linear_scale_range")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("x"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("0")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("6000")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("0")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("255")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("}")]),t._v("\n\n"),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("// we could also use an arrow function here to abbreviate")]),t._v("\n"),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("// var scale_function = (x, context, child) => child.linear_scale_range(x, 0, 6000, 0, 255)")]),t._v("\n\n"),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("// apply child process to all pixels")]),t._v("\n"),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("var")]),t._v(" cube_s2_b348_red_lin "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("builder")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("apply")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("cube_s2_b348_red"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" scale_function"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(";")]),t._v("\n")])])]),s("p",[s("strong",[t._v("Note:")]),t._v(" Given the two ways of defining a child process above, we can see that in the long way, the builder is available as "),s("code",[t._v("this")]),t._v(", while in arrow functions, it has to be passed as the last argument (here called "),s("code",[t._v("child")]),t._v(").")])]},proxy:!0}])}),t._v(" "),s("figure",[s("img",{attrs:{src:a(303),alt:"A comparison between an unscaled and a scaled raster is shown. Unscaled values are much larger, sclaed values much closer together and all below 255."}}),t._v(" "),s("figcaption",[t._v("A part of our original image is displayed here, to observe the effect of applying a linear scale: Original (thus unscaled) imagery is seen on the left, and scaled values on the right.")])]),t._v(" "),s("h3",{attrs:{id:"spatial-aggregation-aggregate-spatial"}},[s("a",{staticClass:"header-anchor",attrs:{href:"#spatial-aggregation-aggregate-spatial"}},[t._v("#")]),t._v(" Spatial Aggregation: "),s("code",[t._v("aggregate_spatial")])]),t._v(" "),s("p",[t._v('To look at text output formats we first need to "de-spatialize" our data. Or put another way: If we\'re interested in e.g. timeseries of various geometries, text output might be very interesting for us.')]),t._v(" "),s("p",[t._v("To aggregate over certain geometries, we use the process "),s("code",[t._v("aggregate_spatial")]),t._v(". It takes valid GeoJSON as input. We can pass a GeoJSON "),s("code",[t._v("FeatureCollection")]),t._v(" in Python and JavaScript, but we need to introduce two packages in R, "),s("code",[t._v("sf")]),t._v(" and "),s("code",[t._v("geojsonsf")]),t._v(", to convert the "),s("code",[t._v("FeatureCollection")]),t._v(" "),s("code",[t._v("string")]),t._v(" to a "),s("code",[t._v("simple feature collection")]),t._v(".")]),t._v(" "),s("CodeSwitcher",{scopedSlots:t._u([{key:"py",fn:function(){return[s("div",{staticClass:"language-python extra-class"},[s("pre",{pre:!0,attrs:{class:"language-python"}},[s("code",[s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# polygons as (geojson) dict")]),t._v("\npolygons "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("{")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"type"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(":")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"FeatureCollection"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"features"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(":")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("{")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"type"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(":")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"Feature"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"properties"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(":")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("{")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("}")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"geometry"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(":")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("{")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"type"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(":")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"Polygon"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"coordinates"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(":")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("5.636715888977051")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("52.6807532675943")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("5.629441738128662")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("52.68157281641395")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("5.633561611175536")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("52.67787822078012")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("5.636715888977051")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("52.6807532675943")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("}")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("}")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("{")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"type"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(":")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"Feature"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"properties"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(":")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("{")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("}")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"geometry"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(":")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("{")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"type"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(":")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"Polygon"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"coordinates"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(":")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("5.622982978820801")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("52.68595649102906")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("5.6201934814453125")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("52.68429152697491")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("5.628776550292969")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("52.683719180920846")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("5.622982978820801")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("52.68595649102906")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("}")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("}")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("}")]),t._v("\n\n"),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# aggregate spatial")]),t._v("\ncube_s2_b8_agg "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" cube_s2_b8"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),t._v("aggregate_spatial"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("geometries "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" polygons"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" reducer "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"mean"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n\n"),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# alternatively, the python client has a shortcut function for this special case")]),t._v("\n"),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# cube_s2_b8_agg = cube_s2_b8.polygonal_mean_timeseries(polygon = polygons)")]),t._v("\n")])])])]},proxy:!0},{key:"r",fn:function(){return[s("div",{staticClass:"language-r extra-class"},[s("pre",{pre:!0,attrs:{class:"language-r"}},[s("code",[s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# load sf and geojsonsf")]),t._v("\nlibrary"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("sf"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\nlibrary"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("geojsonsf"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n\n"),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# create string containing the geojson FeatureCollection")]),t._v("\npolygons_string "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("<-")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('\'{ "type": "FeatureCollection", "features": [ { "type": "Feature", "properties": {}, "geometry": { "type": "Polygon", "coordinates": [ [ [ 5.636715888977051, 52.6807532675943 ], [ 5.629441738128662, 52.68157281641395 ], [ 5.633561611175536, 52.67787822078012 ], [ 5.636715888977051, 52.6807532675943 ] ] ] } }, { "type": "Feature", "properties": {}, "geometry": { "type": "Polygon", "coordinates": [ [ [ 5.622982978820801, 52.68595649102906 ], [ 5.6201934814453125, 52.68429152697491 ], [ 5.628776550292969, 52.683719180920846 ], [ 5.622982978820801, 52.68595649102906 ] ] ] } } ]}\'')]),t._v("\n"),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# convert to sf object")]),t._v("\npolygons "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("<-")]),t._v(" geojson_sf"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("polygons_string"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n\n"),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# add any attribute as a workaround, empty simple features are not accepted")]),t._v("\npolygons"),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("$")]),t._v("anAttribute "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("<-")]),t._v(" c"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("4")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("5")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n\n"),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# aggregate spatially")]),t._v("\ncube_s2_b8_agg "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("<-")]),t._v(" p"),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("$")]),t._v("aggregate_spatial"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("data "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" cube_s2_b8"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" reducer "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("function")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("data"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" context"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("{")]),t._v(" p"),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("$")]),t._v("mean"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("data"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("}")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" geometries "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" polygons"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n")])])]),s("p",[s("strong",[t._v("Note:")]),t._v(" At the time of writing this, empty simple features are not accepted and produce an error. To work around this issue, simply add a random attribute to the "),s("code",[t._v("sf")]),t._v(" object. Above we are assigning the (randomly chosen) values "),s("code",[t._v("4")]),t._v(" and "),s("code",[t._v("5")]),t._v(" to the two polygons in the collection.")])]},proxy:!0},{key:"js",fn:function(){return[s("div",{staticClass:"language-js extra-class"},[s("pre",{pre:!0,attrs:{class:"language-js"}},[s("code",[s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("// define polygons as geojson")]),t._v("\n"),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("var")]),t._v(" polygons "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("{")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token string-property property"}},[t._v('"type"')]),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v(":")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"FeatureCollection"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token string-property property"}},[t._v('"features"')]),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v(":")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("{")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token string-property property"}},[t._v('"type"')]),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v(":")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"Feature"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token string-property property"}},[t._v('"properties"')]),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v(":")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("{")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("}")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token string-property property"}},[t._v('"geometry"')]),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v(":")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("{")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token string-property property"}},[t._v('"type"')]),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v(":")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"Polygon"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token string-property property"}},[t._v('"coordinates"')]),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v(":")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("5.636715888977051")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("52.6807532675943")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("5.629441738128662")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("52.68157281641395")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("5.633561611175536")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("52.67787822078012")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("5.636715888977051")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("52.6807532675943")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("}")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("}")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("{")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token string-property property"}},[t._v('"type"')]),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v(":")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"Feature"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token string-property property"}},[t._v('"properties"')]),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v(":")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("{")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("}")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token string-property property"}},[t._v('"geometry"')]),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v(":")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("{")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token string-property property"}},[t._v('"type"')]),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v(":")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"Polygon"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token string-property property"}},[t._v('"coordinates"')]),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v(":")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("5.622982978820801")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("52.68595649102906")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("5.6201934814453125")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("52.68429152697491")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("5.628776550292969")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("52.683719180920846")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("5.622982978820801")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("52.68595649102906")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("}")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("}")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),t._v("\n"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("}")]),t._v("\n \n"),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("// aggregate spatial")]),t._v("\n"),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("var")]),t._v(" cube_s2_b8_agg "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" builder"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("aggregate_spatial")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("cube_s2_b8"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" polygons"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token parameter"}},[t._v("data"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" _"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" child")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=>")]),t._v(" child"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("mean")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("data"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n")])])])]},proxy:!0}])}),t._v(" "),s("h3",{attrs:{id:"output-save-result"}},[s("a",{staticClass:"header-anchor",attrs:{href:"#output-save-result"}},[t._v("#")]),t._v(" Output: "),s("code",[t._v("save_result")])]),t._v(" "),s("p",[t._v("To get a result, we first need to create a "),s("code",[t._v("save_result")]),t._v(" node, in which we state the desired output format and potential parameters, both dependent on the back-end you are connected to. The output formats and their parameters can e.g. be explored via the Web Editor along with available processes and collections.")]),t._v(" "),s("p",[t._v("We then proceed to send that job to the back-end, "),s("em",[t._v("without executing it")]),t._v(". Refer to the getting started guides on how to process results as batch or synchronous jobs. The way it is stated here allows us to log in to the Web Editor and look at, change, and execute the job from there.")]),t._v(" "),s("h4",{attrs:{id:"raster-formats-gtiff-netcdf"}},[s("a",{staticClass:"header-anchor",attrs:{href:"#raster-formats-gtiff-netcdf"}},[t._v("#")]),t._v(" Raster Formats: GTiff, NetCDF")]),t._v(" "),s("p",[t._v("In the example, GeoTiff files are produced. Refer to the back-end for the available formats, options, and their correct naming. Check the "),s("a",{attrs:{href:"#raster-formats-png"}},[t._v("PNG section")]),t._v(" for passing options.")]),t._v(" "),s("p",[t._v("Different from the creation of a PNG image, the raster format doesn't need scaling and the original datacube can be downloaded as is. However, we need to be careful with the dimensionality of the datacube: How a 4+ - dimensional datacube is handled when converted to a raster format is back-end dependent. That is why we "),s("a",{attrs:{href:"#temporal-mean-reduce-dimension"}},[t._v("made sure")]),t._v(" that our cube would only contain one additional dimension, apart from the spatial "),s("code",[t._v("x")]),t._v(" and "),s("code",[t._v("y")]),t._v(".")]),t._v(" "),s("CodeSwitcher",{scopedSlots:t._u([{key:"py",fn:function(){return[s("div",{staticClass:"language-python extra-class"},[s("pre",{pre:!0,attrs:{class:"language-python"}},[s("code",[s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# save using save_result, give format as string")]),t._v("\nres "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" cube_s2_b8_red"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),t._v("save_result"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token builtin"}},[t._v("format")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"GTiff"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n\n"),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# send job to back-end, do not execute")]),t._v("\njob "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" res"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),t._v("create_job"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("title "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"temporal_mean_as_GTiff_py"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n")])])])]},proxy:!0},{key:"r",fn:function(){return[s("div",{staticClass:"language-r extra-class"},[s("pre",{pre:!0,attrs:{class:"language-r"}},[s("code",[s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# use list_file_formats() to be able to choose from a list")]),t._v("\nformats "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("<-")]),t._v(" list_file_formats"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n\n"),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# save using save_result, give format via list")]),t._v("\nres "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("<-")]),t._v(" p"),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("$")]),t._v("save_result"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("data "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" cube_s2_b8_red"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" format "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" formats"),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("$")]),t._v("output"),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("$")]),t._v("GTiff"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n\n"),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# send job to back-end")]),t._v("\njob "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("<-")]),t._v(" create_job"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("graph "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" res"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" title "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"temporal_mean_as_GTiff_r"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n")])])])]},proxy:!0},{key:"js",fn:function(){return[s("div",{staticClass:"language-js extra-class"},[s("pre",{pre:!0,attrs:{class:"language-js"}},[s("code",[s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("// save using save_result, give fomat as string")]),t._v("\nresult "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" builder"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("save_result")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("cube_s2_b8_red"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"GTiff"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(";")]),t._v("\n\n"),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("// send job to back-end, but don't execute yet; set title")]),t._v("\n"),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("var")]),t._v(" job "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("await")]),t._v(" con"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("createJob")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("result"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"temporal_mean_as_GTiff_js"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(";")]),t._v("\n")])])])]},proxy:!0}])}),t._v(" "),s("h4",{attrs:{id:"raster-formats-png"}},[s("a",{staticClass:"header-anchor",attrs:{href:"#raster-formats-png"}},[t._v("#")]),t._v(" Raster Formats: PNG")]),t._v(" "),s("p",[t._v("For a PNG output, we'll use the datacube with the bands 3, 4 and 8 (green, red and near-infrared) that we've been working on simultaneously with the datacube used above. As we have scaled the data down to 8bit using a "),s("a",{attrs:{href:"#scale-all-pixels-linearly-apply-linear-scale-range"}},[t._v("linear scale")]),t._v(", nothing stands in the way of downloading the data as PNG.")]),t._v(" "),s("p",[t._v("We want to produce a false-color composite highlighting the vegetation in red (as seen below the code). For that, we want to assign the infrared band ("),s("code",[t._v("B8")]),t._v(") to the red channel, the red band ("),s("code",[t._v("B4")]),t._v(") to the green channel and the green band ("),s("code",[t._v("B3")]),t._v(") to the blue channel. Some back-ends may offer to pass along this desired band order as it is shown below. Check with the back-end for available options.")]),t._v(" "),s("div",{staticClass:"custom-block tip"},[s("p",{staticClass:"custom-block-title"},[t._v("Note")]),t._v(" "),s("p",[t._v("If no options can be passed, handling of the bands for PNG output is internal and should be documented by the back-end. You might also be able to tell how this is done by how your PNG looks: As explained in the "),s("RouterLink",{attrs:{to:"/documentation/1.0/datacubes.html#dimensions"}},[t._v("datacube guide")]),t._v(", the order of the "),s("code",[t._v("bands")]),t._v(" dimension is defined when the values are loaded or altered (in our example: "),s("code",[t._v("filter_bands")]),t._v("). As we filter bands in the order "),s("code",[t._v('"B3", "B4", "B8"')]),t._v(" vegetation might be highlighted in blue, given that the back-end uses the input order for the RGB channels.")],1),t._v(" "),s("p",[s("strong",[t._v("The example below uses the "),s("code",[t._v("PNG")]),t._v(" file format as defined by the Google Earth Engine back-end so the parameters "),s("code",[t._v("red")]),t._v(", "),s("code",[t._v("green")]),t._v(" and "),s("code",[t._v("blue")]),t._v(" may not be available on another back-end.")]),t._v(" Make sure to check the file format documentation for your back-end.")])]),t._v(" "),s("CodeSwitcher",{scopedSlots:t._u([{key:"py",fn:function(){return[s("div",{staticClass:"language-python extra-class"},[s("pre",{pre:!0,attrs:{class:"language-python"}},[s("code",[s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# save result cube as PNG")]),t._v("\nres "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" cube_s2_b348_red_lin"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),t._v("save_result"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token builtin"}},[t._v("format")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"PNG"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" options "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("{")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"red"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(":")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"B8"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"green"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(":")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"B4"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"blue"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(":")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"B3"')]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("}")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n\n"),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# send job to back-end")]),t._v("\njob "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" res"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),t._v("create_job"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("title "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"temporal_mean_as_PNG_py"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n")])])]),s("p",[t._v("In python, options are passed as a dictionary")])]},proxy:!0},{key:"r",fn:function(){return[s("div",{staticClass:"language-r extra-class"},[s("pre",{pre:!0,attrs:{class:"language-r"}},[s("code",[s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# use list_file_formats() to be able to choose from a list")]),t._v("\nformats "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("<-")]),t._v(" list_file_formats"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n\n"),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# save result as PNG")]),t._v("\nres "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("<-")]),t._v(" p"),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("$")]),t._v("save_result"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("data "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" cube_s2_b348_red_lin"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" format "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" formats"),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("$")]),t._v("output"),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("$")]),t._v("PNG"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" \n options "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" list"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("red"),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"B8"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" green"),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"B4"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" blue"),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"B3"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n\n"),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# send job to back-end")]),t._v("\njob "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("<-")]),t._v(" create_job"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("graph "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" res"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" title "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"temporal_mean_as_PNG_r"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n")])])]),s("p",[t._v("In R, options are passed as a list.")])]},proxy:!0},{key:"js",fn:function(){return[s("div",{staticClass:"language-js extra-class"},[s("pre",{pre:!0,attrs:{class:"language-js"}},[s("code",[s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("// save result as PNG")]),t._v("\nresult "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" builder"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("save_result")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("cube_s2_b348_red_lin"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"PNG"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("{")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token literal-property property"}},[t._v("red")]),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v(":")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"B8"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token literal-property property"}},[t._v("green")]),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v(":")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"B4"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token literal-property property"}},[t._v("blue")]),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v(":")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"B3"')]),t._v("\n"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("}")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(";")]),t._v("\n \n"),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("// send job to back-end")]),t._v("\n"),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("var")]),t._v(" job "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("await")]),t._v(" con"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("createJob")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("result"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"temporal_mean_as_PNG_js"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(";")]),t._v("\n")])])]),s("p",[t._v("In JavaScript, options are passed as objects.")])]},proxy:!0}])}),t._v(" "),s("figure",[s("img",{attrs:{src:a(304),alt:"Example PNG: false color composite highlighting vegetation in red."}}),t._v(" "),s("figcaption",[t._v("Image above: Example PNG output with the vegetation highlighted in red.")])]),t._v(" "),s("h4",{attrs:{id:"text-formats-json-csv"}},[s("a",{staticClass:"header-anchor",attrs:{href:"#text-formats-json-csv"}},[t._v("#")]),t._v(" Text Formats: JSON, CSV")]),t._v(" "),s("p",[t._v("We can now save the timeseries in the "),s("a",{attrs:{href:"#spatial-aggregation-aggregate-spatial"}},[t._v("aggregated")]),t._v(" datacube as e.g. JSON.")]),t._v(" "),s("CodeSwitcher",{scopedSlots:t._u([{key:"py",fn:function(){return[s("div",{staticClass:"language-python extra-class"},[s("pre",{pre:!0,attrs:{class:"language-python"}},[s("code",[s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# save result cube as JSON")]),t._v("\nres "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" cube_s2_b8_agg"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),t._v("save_result"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token builtin"}},[t._v("format")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"JSON"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n\n"),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# send job to back-end")]),t._v("\njob "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" res"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),t._v("create_job"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("title "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"timeseries_as_JSON_py"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n")])])])]},proxy:!0},{key:"r",fn:function(){return[s("div",{staticClass:"language-r extra-class"},[s("pre",{pre:!0,attrs:{class:"language-r"}},[s("code",[s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# use list_file_formats() to be able to choose from a list")]),t._v("\nformats "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("<-")]),t._v(" list_file_formats"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n\n"),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# save result as JSON")]),t._v("\nres "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("<-")]),t._v(" p"),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("$")]),t._v("save_result"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("data "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" cube_s2_b8_agg"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" format "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" formats"),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("$")]),t._v("output"),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("$")]),t._v("JSON"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n\n"),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# send job to back-end")]),t._v("\njob "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("<-")]),t._v(" create_job"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("graph "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" res"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" title "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"timeseries_as_JSON_r"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n")])])]),s("p",[s("strong",[t._v("Note:")]),t._v(" Because the R client rounds coordinates to four digits, slightly different results are received in comparison to the other clients.")])]},proxy:!0},{key:"js",fn:function(){return[s("div",{staticClass:"language-js extra-class"},[s("pre",{pre:!0,attrs:{class:"language-js"}},[s("code",[s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("// save as CSV")]),t._v("\nresult "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" builder"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("save_result")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("cube_s2_b8_agg"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"JSON"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(";")]),t._v("\n\n"),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("// send job to back-end")]),t._v("\n"),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("var")]),t._v(" job "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("await")]),t._v(" con"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("createJob")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("result"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"timeseries_as_JSON_js"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(";")]),t._v("\n")])])])]},proxy:!0}])}),t._v(" "),s("h3",{attrs:{id:"output-process-as-json"}},[s("a",{staticClass:"header-anchor",attrs:{href:"#output-process-as-json"}},[t._v("#")]),t._v(" Output: Process as JSON")]),t._v(" "),s("p",[t._v("In some cases we want to export the JSON representation of a process we created. If you followed one of the examples above, then your end node is called "),s("code",[t._v("res")]),t._v(". If not, replace that with whatever you called your process end node.")]),t._v(" "),s("CodeSwitcher",{scopedSlots:t._u([{key:"py",fn:function(){return[s("div",{staticClass:"language-python extra-class"},[s("pre",{pre:!0,attrs:{class:"language-python"}},[s("code",[t._v("process "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" res"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),t._v("to_json"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n\n"),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# if needed, write JSON to file, e.g.:")]),t._v("\n"),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("with")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token builtin"}},[t._v("open")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"./process.json"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"w"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("as")]),t._v(" tfile"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(":")]),t._v("\n tfile"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),t._v("write"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("process"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n")])])])]},proxy:!0},{key:"r",fn:function(){return[s("div",{staticClass:"language-r extra-class"},[s("pre",{pre:!0,attrs:{class:"language-r"}},[s("code",[s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# convert process to JSON")]),t._v("\nprocess_json "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("<-")]),t._v(" toJSON"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("as"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("res"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"Process"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n\n"),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# if needed, write JSON to file, e.g.:")]),t._v("\ncat"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("process_json"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" file "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"./process.json"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n")])])])]},proxy:!0},{key:"js",fn:function(){return[s("div",{staticClass:"language-js extra-class"},[s("pre",{pre:!0,attrs:{class:"language-js"}},[s("code",[s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("// set last node as result = true so it is recognized as the result node")]),t._v("\nres"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),t._v("result "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token boolean"}},[t._v("true")]),t._v("\n\nprocess "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token constant"}},[t._v("JSON")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("stringify")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("builder"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("toJSON")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n\n"),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("// if needed, write JSON to file, e.g.:")]),t._v("\n"),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("var")]),t._v(" fs "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("require")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token string"}},[t._v("'fs'")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(";")]),t._v("\nfs"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("writeFileSync")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"./process.json"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" process"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(";")]),t._v("\n")])])]),s("p",[s("strong",[t._v("Note:")]),t._v(" The code to store a file only works with NodeJS. Browsers can't write files to disk.")])]},proxy:!0}])}),t._v(" "),s("h2",{attrs:{id:"chapter-2"}},[s("a",{staticClass:"header-anchor",attrs:{href:"#chapter-2"}},[t._v("#")]),t._v(" Chapter 2")]),t._v(" "),s("p",[t._v("In this second part of the cookbook, things are a bit less linear. We'll explore bandmath, masking and "),s("code",[t._v("apply_*")]),t._v(" functionality, only that these steps are less interconnected than in the first chapter.")]),t._v(" "),s("p",[t._v("As usual we'll load a collection to work with (Sentinel 2, bands "),s("code",[t._v("2")]),t._v(", "),s("code",[t._v("4")]),t._v(", "),s("code",[t._v("8")]),t._v(" and "),s("code",[t._v("SCL")]),t._v("). Let's call it "),s("code",[t._v("cube_s2")]),t._v(". We pre-select a time frame of which we know it only contains one Sentinel 2 scene, so that we're not bothered with multiple timesteps (the collection still contains a time dimension, but with only one timestep in it, so that it can be ignored). The extent has been chosen to provide results that are suitable to show the effect of the processes used, while being considerably small and thus fast to compute. If you want to minimize processing time you are of course free to use much smaller AOIs.")]),t._v(" "),s("p",[t._v("To be able to download and look at the results, refer to the "),s("a",{attrs:{href:"#raster-formats-gtiff-netcdf"}},[t._v("output section of chapter 1")]),t._v(". Most of the images in this tutorial were all downloaded as GTiff and plotted with R.")]),t._v(" "),s("CodeSwitcher",{scopedSlots:t._u([{key:"py",fn:function(){return[s("div",{staticClass:"language-python extra-class"},[s("pre",{pre:!0,attrs:{class:"language-python"}},[s("code",[t._v("pellworm "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("{")]),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"west"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(":")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("8.5464")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"south"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(":")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("54.4473")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"east"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(":")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("9.0724")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"north"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(":")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("54.5685")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("}")]),t._v("\nt "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"2021-03-05"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"2021-03-05"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),t._v("\n\ncube_s2 "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" con"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),t._v("load_collection"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"SENTINEL2_L2A_SENTINELHUB"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n spatial_extent "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" pellworm"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n temporal_extent "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" t"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n bands "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"B02"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"B04"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"B08"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"SCL"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),t._v("\n"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n")])])])]},proxy:!0},{key:"r",fn:function(){return[s("div",{staticClass:"language-r extra-class"},[s("pre",{pre:!0,attrs:{class:"language-r"}},[s("code",[t._v("pellworm "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("<-")]),t._v(" list"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("west "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("8.5464")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" south "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("54.4473")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" east "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("9.0724")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" north "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("54.5685")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\nt "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("<-")]),t._v(" c"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"2021-03-05"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"2021-03-05"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n\ncube_s2 "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("<-")]),t._v(" p"),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("$")]),t._v("load_collection"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("\n id "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"SENTINEL2_L2A_SENTINELHUB"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n spatial_extent "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" pellworm"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n temporal_extent "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" t"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n bands"),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v("c"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"B02"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"B04"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"B08"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"SCL"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n")])])])]},proxy:!0},{key:"js",fn:function(){return[s("div",{staticClass:"language-js extra-class"},[s("pre",{pre:!0,attrs:{class:"language-js"}},[s("code",[s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("let")]),t._v(" pellworm "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("{")]),s("span",{pre:!0,attrs:{class:"token string-property property"}},[t._v('"west"')]),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v(":")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("8.5464")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string-property property"}},[t._v('"south"')]),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v(":")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("54.4473")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string-property property"}},[t._v('"east"')]),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v(":")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("9.0724")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string-property property"}},[t._v('"north"')]),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v(":")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("54.5685")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("}")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(";")]),t._v("\n"),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("let")]),t._v(" t "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"2021-03-05"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"2021-03-05"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(";")]),t._v("\n\n"),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("var")]),t._v(" cube_s2 "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" builder"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("load_collection")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"SENTINEL2_L2A_SENTINELHUB"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n pellworm"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n t"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"B02"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"B04"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"B08"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"SCL"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),t._v("\n"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(";")]),t._v("\n")])])])]},proxy:!0}])}),t._v(" "),s("figure",[s("img",{attrs:{src:a(305),alt:"The AOI around Pellworm is shown as a false color RGB. RGB = red, nir and blue"}}),t._v(" "),s("figcaption",[t._v("This is a false color image of our area of interest for this chapter. The bands 4, 8 and 2 have been assigned to the RGB channels without any further processing. The surrounding area of the island Pellworm is shown at low tide.\n")])]),t._v(" "),s("h3",{attrs:{id:"bandmath"}},[s("a",{staticClass:"header-anchor",attrs:{href:"#bandmath"}},[t._v("#")]),t._v(" Bandmath")]),t._v(" "),s("p",[t._v("Bandmath refers to computations that involve multiple bands, like indices (Normalized Difference Vegetation Index, Normalized Burn Ratio etc.).")]),t._v(" "),s("p",[t._v("In openEO, this goes along with using for example "),s("code",[t._v("reduce_dimension")]),t._v(" over the "),s("code",[t._v("bands")]),t._v(" dimension. In this process, a new pixel value is calculated from the values of different bands using a given formula (the actual bandmath), to then eliminate the "),s("code",[t._v("bands")]),t._v(" dimension alltogether. If e.g. a cube contains a "),s("code",[t._v("red")]),t._v(" and a "),s("code",[t._v("nir")]),t._v(" band in its "),s("code",[t._v("bands")]),t._v(" dimension and we reduce said dimension with a formula for the NDVI, that cube afterwards contains NDVI values, but no "),s("code",[t._v("bands")]),t._v(" dimension anymore.")]),t._v(" "),s("p",[t._v("In the following we'll observe a thorough explanation of how to calculate an NDVI. That section covers different ways (depending on the client) to set up such a process in openEO. Afterwards, we'll see how an EVI is computed in a quicker, less thorough example.")]),t._v(" "),s("h4",{attrs:{id:"example-1-ndvi"}},[s("a",{staticClass:"header-anchor",attrs:{href:"#example-1-ndvi"}},[t._v("#")]),t._v(" Example 1: NDVI")]),t._v(" "),s("p",[t._v("As mentioned above, bandmath is about reducing the "),s("code",[t._v("bands")]),t._v(" dimension with a child process (a formula) that gives us the desired output. In "),s("a",{attrs:{href:"#chapter-1"}},[t._v("chapter one")]),t._v(", we already saw different ways of defining a child process: a) We learned how to use a simple "),s("code",[t._v("mean")]),t._v(" to "),s("RouterLink",{attrs:{to:"/documentation/1.0/cookbook/#temporal-mean-reduce-dimension"}},[t._v("reduce the time dimension")]),t._v(", and b) we saw how to access and use the openEO defined "),s("code",[t._v("linear_scale_range")]),t._v(" function "),s("RouterLink",{attrs:{to:"/documentation/1.0/cookbook/#scale-all-pixels-linearly-apply-linear-scale-range"}},[t._v("to scale all pixels linearly")]),t._v(".")],1),t._v(" "),s("p",[t._v("In this chapter, we'll reiterate these techniques and discuss some subtleties and alternatives. It is up to you to choose one that works best. Special to the NDVI is, given that it is "),s("em",[t._v("the")]),t._v(" most common use case, that openEO has predefined processes that cover the math for us and only need to be given the correct input. There even is a function "),s("code",[t._v("ndvi")]),t._v(" that masks all details and only takes a datacube and the bandnames as input. Further down we'll dig into what this "),s("code",[t._v("ndvi")]),t._v(" process actually masks, how we can reproduce that manually, and thus how we could formulate other bandmath functions, apart from an NDVI.")]),t._v(" "),s("p",[t._v("By using the openEO defined "),s("strong",[s("code",[t._v("ndvi")]),t._v(" function")]),t._v(", calculating an NDVI becomes pretty straightforward. The process can detect the red and near-infrared band based on metadata and doesn't need bandname input (but band names can be passed to calculate other normalized differences). Also, by supplying the optional parameter "),s("code",[t._v("target_band")]),t._v(" we can decide if we want to get a reduced cube with NDVI values and no "),s("code",[t._v("bands")]),t._v(" dimension as result, or if we want to append the new NDVI band to the existing bands of our input cube. If we choose the latter, we only need to supply a name for that new NDVI band.")]),t._v(" "),s("CodeSwitcher",{scopedSlots:t._u([{key:"py",fn:function(){return[s("div",{staticClass:"language-python extra-class"},[s("pre",{pre:!0,attrs:{class:"language-python"}},[s("code",[t._v("cube_s2_ndvi "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" cube_s2"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),t._v("ndvi"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n\n"),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# or name bands explicitly + append the result band to the existing cube")]),t._v("\n"),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v('# cube_s2_ndvi_bands = cube_s2.ndvi(nir = "B08", red = "B04", target_band = "NDVI")')]),t._v("\n")])])])]},proxy:!0},{key:"r",fn:function(){return[s("div",{staticClass:"language-r extra-class"},[s("pre",{pre:!0,attrs:{class:"language-r"}},[s("code",[t._v("cube_s2_ndvi "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("<-")]),t._v(" p"),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("$")]),t._v("ndvi"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("cube_s2"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n\n"),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# or name bands explicitly + append the result band to the existing cube")]),t._v("\n"),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v('# cube_s2_nvdi_bands <- p$ndvi(data = cube_s2, nir = "B08", red = "B04", target_band = "NDVI")')]),t._v("\n")])])])]},proxy:!0},{key:"js",fn:function(){return[s("div",{staticClass:"language-js extra-class"},[s("pre",{pre:!0,attrs:{class:"language-js"}},[s("code",[t._v("cube_s2_ndvi "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" builder"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("ndvi")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("cube_s2"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n\n"),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("// or name bands explicitly + append the result band to the existing cube")]),t._v("\n"),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v('// cube_s2_ndvi_bands = builder.ndvi(cube_s2, "B08", "B04", "NDVI")')]),t._v("\n")])])])]},proxy:!0}])}),t._v(" "),s("p",[t._v("For the purpose of understanding, we'll stick with our NDVI example to explore different ways of defining bandmath in openEO. That gives you the knowledge to define other processes, not just NDVIs. The first method is available in all clients: "),s("strong",[t._v("Defining a function")]),t._v(" and passing it to a process, e.g. "),s("code",[t._v("reduce_dimension")]),t._v(". If available, other possibilities are discussed afterwards.")]),t._v(" "),s("div",{staticClass:"custom-block tip"},[s("p",{staticClass:"custom-block-title"},[t._v("Important: Check Band Indices and Bandnames!")]),t._v(" "),s("p",[t._v("Be careful when handling the names or array indices of bands. While names differ across back-ends, indices can be mixed up easily when some other band is deleted from the input collection. Python and JavaScript have 0-based indices, R indices are 1-based. So double check which bands you're actually using.")])]),t._v(" "),s("CodeSwitcher",{scopedSlots:t._u([{key:"py",fn:function(){return[s("div",{staticClass:"language-python extra-class"},[s("pre",{pre:!0,attrs:{class:"language-python"}},[s("code",[s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# necessary imports")]),t._v("\n"),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("from")]),t._v(" openeo"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),t._v("processes "),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("import")]),t._v(" array_element"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" normalized_difference\n\n"),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# define an NDVI function")]),t._v("\n"),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("def")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("ndvi_function")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("data"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(":")]),t._v("\n B04 "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" array_element"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("data"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" index "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("1")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# array_element takes either an index ..")]),t._v("\n B08 "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" array_element"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("data"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" label "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"B08"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# or a label")]),t._v("\n\n "),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# ndvi = (B08 - B04) / (B08 + B04) # implement NDVI as formula ..")]),t._v("\n ndvi "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" normalized_difference"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("B08"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" B04"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v('# or use the openEO "normalized_difference" process')]),t._v("\n \n "),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("return")]),t._v(" ndvi\n\n"),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v('# supply the defined function to a reduce_dimension process, set dimension = "bands"')]),t._v("\ncube_s2_ndvi "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" cube_s2"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),t._v("reduce_dimension"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("reducer "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" ndvi_function"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" dimension "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"bands"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n")])])]),s("p",[t._v("What we see above:")]),t._v(" "),s("ul",[s("li",[t._v("access specific bands inside the child process: "),s("code",[t._v("array_element")]),t._v(" (supply data and index/label)")]),t._v(" "),s("li",[t._v("call openEO defined functions inside the child process by importing it: "),s("code",[t._v("from openeo.processes import normalized_difference")])]),t._v(" "),s("li",[t._v("write math as formula inside the child process: "),s("code",[t._v("ndvi = (B08 - B04) / (B08 + B04)")])])]),t._v(" "),s("p",[t._v("The python client also holds a second possibility to do the above. It has a "),s("strong",[t._v("function "),s("code",[t._v("band")])]),t._v(" that does "),s("code",[t._v("array_element")]),t._v(" and "),s("code",[t._v('reduce_dimension(dimension = "bands")')]),t._v(" for us. When using it, we can type out the NDVI formula right in the script (since "),s("code",[t._v(".band")]),t._v(" reduced the cube for us).")]),t._v(" "),s("div",{staticClass:"language-python extra-class"},[s("pre",{pre:!0,attrs:{class:"language-python"}},[s("code",[t._v("B04 "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" cube_s2"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),t._v("band"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"B04"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\nB08 "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" cube_s2"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),t._v("band"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"B08"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n\ncube_s2_ndvi "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("B08 "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("-")]),t._v(" B04"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("/")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("B08 "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("+")]),t._v(" B04"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# type math formula")]),t._v("\n")])])])]},proxy:!0},{key:"r",fn:function(){return[s("div",{staticClass:"language-r extra-class"},[s("pre",{pre:!0,attrs:{class:"language-r"}},[s("code",[s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# define an NDVI function")]),t._v("\nndvi_function "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("<-")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("function")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("data"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" context"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("{")]),t._v("\n B04 "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("<-")]),t._v(" data"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("2")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# we can supply an index (1-based in R) ..")]),t._v("\n B08 "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("<-")]),t._v(" data"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"B08"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# or a label")]),t._v("\n \n "),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# ndvi <- (B08 - B04) / (B08 + B04) # implement NDVI as formula ..")]),t._v("\n ndvi "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("<-")]),t._v(" p"),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("$")]),t._v("normalized_difference"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("B08"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" B04"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v('# or use the openEO "normalized_difference" process')]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# ndvi <- p$normalized_difference(data[2], data[3]) # or shorten all in one line")]),t._v("\n\n return"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("ndvi"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("}")]),t._v("\n\n"),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v('# supply the defined function to a reduce_dimension process, set dimension = "bands"')]),t._v("\ncube_s2_ndvi "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("<-")]),t._v(" p"),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("$")]),t._v("reduce_dimension"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("data "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" cube_s2"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" reducer "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" ndvi_function"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" dimension "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"bands"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n")])])]),s("p",[t._v("What we see above:")]),t._v(" "),s("ul",[s("li",[t._v("access specific bands inside the child process by using array subset: "),s("code",[t._v("data[index]")]),t._v(" or "),s("code",[t._v('data["bandname"]')])]),t._v(" "),s("li",[t._v("call openEO defined functions inside the child process by calling it via the "),s("code",[t._v("p")]),t._v(" processes environment: "),s("code",[t._v("p$normalized_difference")])]),t._v(" "),s("li",[t._v("write math as formulas inside the child process: "),s("code",[t._v("ndvi <- (B08 - B04) / (B08 + B04)")])])]),t._v(" "),s("p",[t._v("In R, there are no other ways to define a child process than through defining a function as seen above.")])]},proxy:!0},{key:"js",fn:function(){return[s("div",{staticClass:"language-js extra-class"},[s("pre",{pre:!0,attrs:{class:"language-js"}},[s("code",[s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("// define NDVI function")]),t._v("\n"),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("var")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token function-variable function"}},[t._v("ndvi_function")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("function")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token parameter"}},[t._v("data"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" context")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("{")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token constant"}},[t._v("B04")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" data"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("1")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("// use array operator to extract bands")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token constant"}},[t._v("B08")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" data"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"B08"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("// or supply label")]),t._v("\n\n ndvi "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("this")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("normalized_difference")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token constant"}},[t._v("B08")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token constant"}},[t._v("B04")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v('// use "this" to access openEO processes inside this function')]),t._v("\n\n "),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v('// ndvi = this.normalized_difference(data["B08"], data["B04"]) // or shorten it all into one line')]),t._v("\n \n "),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("return")]),t._v(" ndvi\n"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("}")]),t._v("\n\n"),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v('// supply the defined function to a reduce_dimension process, set dimension = "bands"')]),t._v("\ncube_s2_ndvi "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" builder"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("reduce_dimension")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("cube_s2"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" ndvi_function"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"bands"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n")])])]),s("p",[t._v("What we see above:")]),t._v(" "),s("ul",[s("li",[t._v("access specific bands inside the child process by using array subset: "),s("code",[t._v("data[index]")]),t._v(" or "),s("code",[t._v('data["bandname"]')])]),t._v(" "),s("li",[t._v("call openEO defined functions inside the child process by calling it via "),s("code",[t._v("this")])])]),t._v(" "),s("p",[t._v("We note that JavaScript doesn't support just typing out math functions as R and Python do. But the JS client has another, even simpler way of defining quick bandmath: "),s("strong",[t._v("using "),s("code",[t._v("new Formula")])]),t._v(".")]),t._v(" "),s("div",{staticClass:"language-js extra-class"},[s("pre",{pre:!0,attrs:{class:"language-js"}},[s("code",[s("span",{pre:!0,attrs:{class:"token comment"}},[t._v('// using "New Formula()", both $index and $label are valid as seen here, $1 refers to B04')]),t._v("\ncube_s2_ndvi "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" builder"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("reduce_dimension")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("cube_s2"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("new")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token class-name"}},[t._v("Formula")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"($B08 - $1) / ($B08 + $1)"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"bands"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n")])])]),s("p",[t._v("We see that using "),s("code",[t._v('new Formula("")')]),t._v(" is much faster than defining a whole child process. We use "),s("code",[t._v("$")]),t._v(" to access bands (works with "),s("code",[t._v("$indices")]),t._v(" or "),s("code",[t._v("$bandnames")]),t._v("). If we want to use openEO defined processes, there's also the "),s("strong",[t._v("arrow function")]),t._v(" to still be able to do that in-line.")]),t._v(" "),s("div",{staticClass:"language-js extra-class"},[s("pre",{pre:!0,attrs:{class:"language-js"}},[s("code",[s("span",{pre:!0,attrs:{class:"token comment"}},[t._v('// using an arrow function to call openeo process "normalized_difference"')]),t._v("\ncube_s2_ndvi "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" builder"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("reduce_dimension")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("cube_s2"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token parameter"}},[t._v("data"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" _"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" child")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=>")]),t._v(" child"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("normalized_difference")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("data"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("2")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" data"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("1")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"bands"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n")])])]),s("p",[t._v("In an arrow function, we can use array subsets again.")]),t._v(" "),s("p",[t._v("To sum up: Although "),s("code",[t._v("new Formula")]),t._v(" is probably the most straightforward way of calculating an NDVI, it is up to you to decide on a method that suits your use-case.")])]},proxy:!0}])}),t._v(" "),s("figure",[s("img",{attrs:{src:a(306),alt:"NDVI image of the AOI"}}),t._v(" "),s("figcaption",[t._v("A correctly calculated NDVI would look as displayed here (scaled linearly).")])]),t._v(" "),s("h4",{attrs:{id:"example-2-evi"}},[s("a",{staticClass:"header-anchor",attrs:{href:"#example-2-evi"}},[t._v("#")]),t._v(" Example 2: EVI")]),t._v(" "),s("p",[t._v("The formula for the Enhanced Vegetation Index is a bit more complicated than the NDVI one and contains constants. But we also don't necessarily need an openEO defined function and can concentrate on implementing a more complex formula. Here's the most efficient way to do this, per client.")]),t._v(" "),s("CodeSwitcher",{scopedSlots:t._u([{key:"py",fn:function(){return[s("div",{staticClass:"language-python extra-class"},[s("pre",{pre:!0,attrs:{class:"language-python"}},[s("code",[s("span",{pre:!0,attrs:{class:"token comment"}},[t._v('# extract and reduce all bands via "band"')]),t._v("\nB02 "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" cube_s2"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),t._v("band"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"B02"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\nB04 "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" cube_s2"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),t._v("band"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"B04"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\nB08 "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" cube_s2"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),t._v("band"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"B08"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n\n"),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# write formula")]),t._v("\ncube_s2_evi "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("2.5")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("*")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("B08 "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("-")]),t._v(" B04"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("/")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("B08 "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("+")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("6.0")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("*")]),t._v(" B04 "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("-")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("7.5")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("*")]),t._v(" B02"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("+")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("1.0")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n")])])])]},proxy:!0},{key:"r",fn:function(){return[s("div",{staticClass:"language-r extra-class"},[s("pre",{pre:!0,attrs:{class:"language-r"}},[s("code",[s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# in R, there's no shorter way to define bandmath")]),t._v("\nevi_ "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("<-")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("function")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("x"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" context"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("{")]),t._v("\n b2 "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("<-")]),t._v(" x"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("1")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),t._v("\n b4 "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("<-")]),t._v(" x"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("2")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),t._v("\n b8 "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("<-")]),t._v(" x"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("3")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),t._v("\n return"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("2.5")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("*")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("b8 "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("-")]),t._v(" b4"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("/")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("b8 "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("+")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("6")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("*")]),t._v(" b4 "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("-")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("7.5")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("*")]),t._v(" b2"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("+")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("1")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("}")]),t._v("\n\n"),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# reduce_dimension bands with the defined formula")]),t._v("\ncube_s2_evi "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("<-")]),t._v(" p"),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("$")]),t._v("reduce_dimension"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("data "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" cube_s2"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" reducer "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" evi_"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" dimension "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"bands"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n")])])])]},proxy:!0},{key:"js",fn:function(){return[s("div",{staticClass:"language-js extra-class"},[s("pre",{pre:!0,attrs:{class:"language-js"}},[s("code",[s("span",{pre:!0,attrs:{class:"token comment"}},[t._v('// "new Formula" is the quickest way to provide a bandmath formula')]),t._v("\ncube_s2_evi "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" builder"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("reduce_dimension")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("cube_s2"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("new")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token class-name"}},[t._v("Formula")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"(2.5 * ($B08 - $B04)) / (($B08 + 6 * $B04 - 7.5 * $B02) + 1)"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"bands"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n")])])])]},proxy:!0}])}),t._v(" "),s("h3",{attrs:{id:"masks-mask"}},[s("a",{staticClass:"header-anchor",attrs:{href:"#masks-mask"}},[t._v("#")]),t._v(" Masks: "),s("code",[t._v("mask")])]),t._v(" "),s("p",[t._v("Masking generally refers to excluding (or replacing) specific areas from an image. This is usually done by providing a boolean mask that detemines which pixels to replace with a no-data value, and which to leave as they are. In the following we will consider two cases: a) Creating a mask from classification classes and b) creating a mask by thresholding an image.")]),t._v(" "),s("h4",{attrs:{id:"mask-out-specific-values"}},[s("a",{staticClass:"header-anchor",attrs:{href:"#mask-out-specific-values"}},[t._v("#")]),t._v(" Mask Out Specific Values")]),t._v(" "),s("p",[t._v("In some cases we want to mask our data with other data. A common example is to mask out clouds, which optical satellites can not see through. Some Sentinel 2 collections provide the "),s("code",[t._v("SCL")]),t._v(" classification band (see the table of classes "),s("a",{attrs:{href:"https://sentinels.copernicus.eu/web/sentinel/technical-guides/sentinel-2-msi/level-2a/algorithm",target:"_blank",rel:"noopener noreferrer"}},[t._v("at the bottom here"),s("OutboundLink")],1),t._v("), providing a representation coded into land cover classes. In this classification, vegetation is coded as "),s("code",[t._v("4")]),t._v(" and non-vegetation as "),s("code",[t._v("5")]),t._v(", while e.g. clouds are coded as "),s("code",[t._v("8")]),t._v(" to "),s("code",[t._v("10")]),t._v(".")]),t._v(" "),s("p",[t._v("In the following, we're building a mask using some logical operations as a child process while reducing the dimension "),s("code",[t._v("bands")]),t._v(". As explained at "),s("a",{attrs:{href:"#example-1-ndvi"}},[t._v("Example 1: NDVI")]),t._v(" this is done to be left with a cube that has no dimension "),s("code",[t._v("bands")]),t._v(". In R and JavaScript, we write a function "),s("code",[t._v("filter_")]),t._v(" that turns the values of the "),s("code",[t._v("SCL")]),t._v(" band into "),s("code",[t._v("0")]),t._v("s (for (non-) vegetation) and "),s("code",[t._v("1")]),t._v("s (for all others), and ignores all other bands. During "),s("code",[t._v("mask")]),t._v(", all "),s("code",[t._v("1")]),t._v("s (i.e. "),s("code",[t._v("TRUE")]),t._v(") pixels will be replaced, and as we don't define a replacement they will simply be set to "),s("code",[t._v("null")]),t._v(". In Python, in-line logical operations can be used.")]),t._v(" "),s("CodeSwitcher",{scopedSlots:t._u([{key:"py",fn:function(){return[s("div",{staticClass:"language-python extra-class"},[s("pre",{pre:!0,attrs:{class:"language-python"}},[s("code",[s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# get classification band")]),t._v("\nSCL "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" cube_s2"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),t._v("band"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"SCL"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n\n"),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# we want to mask all other values, so NOT (4 OR 5)")]),t._v("\ncube_s2_mask "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("~")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("SCL "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("==")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("4")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("|")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("SCL "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("==")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("5")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n\n"),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# masking")]),t._v("\ncube_s2_masked "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" cube_s2"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),t._v("mask"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("cube_s2_mask"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n")])])])]},proxy:!0},{key:"r",fn:function(){return[s("div",{staticClass:"language-r extra-class"},[s("pre",{pre:!0,attrs:{class:"language-r"}},[s("code",[s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# define filter function to create mask")]),t._v("\nfilter_function "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("<-")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("function")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("data"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" context"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("{")]),t._v("\n vegetation "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("<-")]),t._v(" p"),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("$")]),t._v("eq"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("data"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"SCL"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("4")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# vegetation is 4")]),t._v("\n non_vegetation "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("<-")]),t._v(" p"),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("$")]),t._v("eq"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("data"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"SCL"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("5")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# non-vegetation is 5")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# we want to mask all other values, so NOT (4 OR 5)")]),t._v("\n return"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("p"),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("$")]),t._v("not"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("p"),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("$")]),t._v("or"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("vegetation"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" non_vegetation"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("}")]),t._v("\n\n"),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# create mask by reducing bands with our defined formula")]),t._v("\ncube_s2_mask "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("<-")]),t._v(" p"),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("$")]),t._v("reduce_dimension"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("data "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" cube_s2"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" reducer "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" filter_function"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" dimension "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"bands"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n\n"),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# mask the NDVI data")]),t._v("\ncube_s2_masked "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("<-")]),t._v(" p"),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("$")]),t._v("mask"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("cube_s2"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" cube_s2_mask"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n")])])])]},proxy:!0},{key:"js",fn:function(){return[s("div",{staticClass:"language-js extra-class"},[s("pre",{pre:!0,attrs:{class:"language-js"}},[s("code",[s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("// filter classification layer")]),t._v("\n"),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("var")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token function-variable function"}},[t._v("filter_function")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("function")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token parameter"}},[t._v("data"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" context")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("{")]),t._v("\n vegetation "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("this")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("eq")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("data"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"SCL"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("4")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("// vegetation is 4")]),t._v("\n non_vegetation "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("this")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("eq")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("data"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"SCL"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("5")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("// non-vegetation is 5")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("// we want to mask all other values, so NOT (4 OR 5)")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("return")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("this")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("not")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("this")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("or")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("vegetation"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" non_vegetation"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("}")]),t._v("\n\n"),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("// create mask by reducing bands")]),t._v("\ncube_s2_mask "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" builder"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("reduce_dimension")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("cube_s2"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" filter_function"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"bands"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n\n"),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("// mask")]),t._v("\ncube_s2_masked "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" builder"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("mask")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("cube_s2"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" cube_s2_mask"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n")])])])]},proxy:!0}])}),t._v(" "),s("p",[t._v('As with all functionality there are differences between back-ends. If this first example "Mask Out Specific Values" doesn\'t work for you, that could be because we are trying to apply a mask (a cube with dimensions '),s("code",[t._v("x")]),t._v(", "),s("code",[t._v("y")]),t._v(", "),s("code",[t._v("t")]),t._v(") to the input data (a cube with dimensions "),s("code",[t._v("x")]),t._v(", "),s("code",[t._v("y")]),t._v(", "),s("code",[t._v("t")]),t._v(", "),s("code",[t._v("bands")]),t._v(") and thus, cubes with different dimensionality. If you encounter such a problem, try applying the first mask to the NDVI cube (with dimensions "),s("code",[t._v("x")]),t._v(", "),s("code",[t._v("y")]),t._v(", "),s("code",[t._v("t")]),t._v(') as it is shown in the second example "Thresholds".')]),t._v(" "),s("h4",{attrs:{id:"thresholds"}},[s("a",{staticClass:"header-anchor",attrs:{href:"#thresholds"}},[t._v("#")]),t._v(" Thresholds")]),t._v(" "),s("p",[t._v("In this scenario we want an image that contains all NDVI values above 0.3, and holds no-data values otherwise. This could be useful to have a look at the vegetation in the area, without being distracted by all other NDVI values. For this example we reuse the NDVI cube "),s("code",[t._v("cube_s2_ndvi")]),t._v(" that was calculated in the "),s("a",{attrs:{href:"#example-1-ndvi"}},[t._v("NDVI bandmath-example")]),t._v(", thus for this to work you must include said code into your script.")]),t._v(" "),s("p",[t._v("If you look closely, you'll notice that this time we're not using "),s("code",[t._v("reduce_dimension")]),t._v(" to construct our masking cube (in contrast to "),s("a",{attrs:{href:"#mask-out-specific-values"}},[t._v("Mask out Specific Values")]),t._v("). In R and JavaScript we use "),s("code",[t._v("apply")]),t._v(" instead, and in the python client no "),s("code",[t._v(".band()")]),t._v(" is necessary anymore. This is because when we were masking using specific values of the band "),s("code",[t._v("SCL")]),t._v(", we were using the "),s("code",[t._v("cube_s2")]),t._v(" (with the bands "),s("code",[t._v("B02")]),t._v(", "),s("code",[t._v("B04")]),t._v(", "),s("code",[t._v("B08")]),t._v(" and "),s("code",[t._v("SCL")]),t._v(") as input. We then reduced the "),s("code",[t._v("bands")]),t._v(" dimension by writing and passing the function "),s("code",[t._v("filter_")]),t._v(", which returned a cube that had no "),s("code",[t._v("bands")]),t._v(" dimension anymore but "),s("code",[t._v("1")]),t._v("s and "),s("code",[t._v("0")]),t._v("s according to what we wanted to mask.")]),t._v(" "),s("p",[t._v("Here, we are making a mask out of the "),s("code",[t._v("cube_s2_ndvi")]),t._v(", a cube that had its "),s("code",[t._v("band")]),t._v(" dimension already reduced when the NDVI was calculated. To turn its values into "),s("code",[t._v("1")]),t._v("s and "),s("code",[t._v("0")]),t._v("s, we only need to "),s("code",[t._v("apply")]),t._v(" a threshold function. For this we utilize the openEO defined function "),s("code",[t._v("lt")]),t._v(' ("less than"). As usual the clients expose different ways of getting to that function, one of which is shown below.')]),t._v(" "),s("CodeSwitcher",{scopedSlots:t._u([{key:"py",fn:function(){return[s("div",{staticClass:"language-python extra-class"},[s("pre",{pre:!0,attrs:{class:"language-python"}},[s("code",[s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# create mask that is TRUE for NDVI < 0.3")]),t._v("\nndvi_threshold "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" cube_s2_ndvi "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("<")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("0.3")]),t._v("\n\n"),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# apply mask to NDVI")]),t._v("\ncube_s2_ndvi_masked "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" cube_s2_ndvi"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),t._v("mask"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("ndvi_threshold"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n")])])])]},proxy:!0},{key:"r",fn:function(){return[s("div",{staticClass:"language-r extra-class"},[s("pre",{pre:!0,attrs:{class:"language-r"}},[s("code",[t._v("threshold_ "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("<-")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("function")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("data"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" context"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("{")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# create mask that is TRUE for NDVI < 0.3")]),t._v("\n threshold "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("<-")]),t._v(" p"),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("$")]),t._v("lt"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("data"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("1")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("0.3")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n return"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("threshold"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("}")]),t._v("\n\n"),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# apply the threshold to the NDVI cube")]),t._v("\nndvi_threshold "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("<-")]),t._v(" p"),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("$")]),t._v("apply"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("data "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" cube_s2_ndvi"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" process "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" threshold_"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n\n"),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# mask the NDVI cube with the calculated mask")]),t._v("\ncube_s2_ndvi_masked "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("<-")]),t._v(" p"),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("$")]),t._v("mask"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("cube_s2_ndvi"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" ndvi_threshold"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n")])])])]},proxy:!0},{key:"js",fn:function(){return[s("div",{staticClass:"language-js extra-class"},[s("pre",{pre:!0,attrs:{class:"language-js"}},[s("code",[s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("// create mask that is TRUE for NDVI < 0.3 via an arrow function")]),t._v("\nndvi_threshold "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("builder")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("apply")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("cube_s2_ndvi"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token parameter"}},[t._v("data"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" _"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" child")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=>")]),t._v(" child"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("lt")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("data"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("0")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("0.3")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n\n"),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("// apply mask to NDVI cube")]),t._v("\ncube_s2_ndvi_masked "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" builder"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("mask")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("cube_s2_ndvi"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" ndvi_threshold"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n")])])])]},proxy:!0}])}),t._v(" "),s("figure",[s("img",{attrs:{src:a(307),alt:"The NDVI with a threshold of 0.3 applied"}}),t._v(" "),s("figcaption",[t._v("Applying the above described threshold to the NDVI yields this result. Water and artificial surfaces are mostly masked from the image.")])]),t._v(" "),s("h3",{attrs:{id:"pixel-operations-apply"}},[s("a",{staticClass:"header-anchor",attrs:{href:"#pixel-operations-apply"}},[t._v("#")]),t._v(" Pixel Operations: "),s("code",[t._v("apply")])]),t._v(" "),s("p",[t._v("As we remember from the "),s("RouterLink",{attrs:{to:"/documentation/1.0/datacubes.html#apply"}},[t._v("datacube guide")]),t._v(", unary processes take only the pixel itself into account when calculating new pixel values. We can implement that with the "),s("code",[t._v("apply")]),t._v(" function and a child process that is in charge of modifying the pixel values. In our first example, that will be the square root. The openEO function is called "),s("code",[t._v("sqrt")]),t._v(". In the following we'll see how to pass it to the "),s("code",[t._v("apply")]),t._v(" process.")],1),t._v(" "),s("CodeSwitcher",{scopedSlots:t._u([{key:"py",fn:function(){return[s("div",{staticClass:"language-python extra-class"},[s("pre",{pre:!0,attrs:{class:"language-python"}},[s("code",[s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# pass unary child process as string")]),t._v("\ncube_s2_sqrt "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" cube_s2"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token builtin"}},[t._v("apply")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"sqrt"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n")])])])]},proxy:!0},{key:"r",fn:function(){return[s("div",{staticClass:"language-r extra-class"},[s("pre",{pre:!0,attrs:{class:"language-r"}},[s("code",[s("span",{pre:!0,attrs:{class:"token comment"}},[t._v('# pass unary child process as a function, call "sqrt" from openEO processes "p"')]),t._v("\ncube_s2_sqrt "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("<-")]),t._v(" p"),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("$")]),t._v("apply"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("cube_s2"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("function")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("x"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" context"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("{")]),t._v(" return"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("sqrt"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("x"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("}")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n")])])])]},proxy:!0},{key:"js",fn:function(){return[s("div",{staticClass:"language-js extra-class"},[s("pre",{pre:!0,attrs:{class:"language-js"}},[s("code",[s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("// pass unary child process via arrow function")]),t._v("\n"),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("var")]),t._v(" cube_s2_sqrt "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("builder")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("apply")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("cube_s2"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token parameter"}},[t._v("data"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" _"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" child")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=>")]),t._v(" child"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("sqrt")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("data"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n")])])])]},proxy:!0}])}),t._v(" "),s("p",[t._v("Let's say we're not looking at optical but SAR imagery. Depending on the collection held by the back-end, this data could already be log-scaled. In case it isn't, we may want to transform our data from intensity values to db. This formula is a bit more complicated: 10 * log"),s("sub",[t._v("10")]),t._v("(x). So we'll need a multiplication (by 10) and a "),s("code",[t._v("log")]),t._v(" process (to the "),s("code",[t._v("base")]),t._v(" 10).")]),t._v(" "),s("p",[t._v("Prior to applying the following code, we must load a collection containing SAR intensity data (e.g. Sentinel 1 GRD product).")]),t._v(" "),s("CodeSwitcher",{scopedSlots:t._u([{key:"py",fn:function(){return[s("div",{staticClass:"language-python extra-class"},[s("pre",{pre:!0,attrs:{class:"language-python"}},[s("code",[s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# import the defined openEO process")]),t._v("\n"),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("from")]),t._v(" openeo"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),t._v("processes "),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("import")]),t._v(" log\n\n"),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# define a child process")]),t._v("\n"),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("def")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("log_")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("x"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(":")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("return")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("10")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("*")]),t._v(" log"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("x"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("10")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n\n"),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v('# supply that function to the "apply" call')]),t._v("\ncube_s1_log10 "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" cube_s1"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token builtin"}},[t._v("apply")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("log_"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n")])])])]},proxy:!0},{key:"r",fn:function(){return[s("div",{staticClass:"language-r extra-class"},[s("pre",{pre:!0,attrs:{class:"language-r"}},[s("code",[s("span",{pre:!0,attrs:{class:"token comment"}},[t._v('# call multiply, log functions from "p"')]),t._v("\ncube_s1_log10 "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("<-")]),t._v(" p"),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("$")]),t._v("apply"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("cube_s1"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("function")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("x"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" context"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("{")]),t._v("p"),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("$")]),t._v("multiply"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("10")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" p"),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("$")]),t._v("log"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("x"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("10")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("}")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n")])])])]},proxy:!0},{key:"js",fn:function(){return[s("div",{staticClass:"language-js extra-class"},[s("pre",{pre:!0,attrs:{class:"language-js"}},[s("code",[s("span",{pre:!0,attrs:{class:"token comment"}},[t._v('// use openEO "log", "multiply" via arrow function')]),t._v("\ncube_s1_log10 "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("builder")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("apply")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("cube_s1"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token parameter"}},[t._v("data"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" _"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" child")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=>")]),t._v(" child"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("multiply")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("10")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" child"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("log")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("data"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("10")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n")])])])]},proxy:!0}])}),t._v(" "),s("figure",[s("img",{attrs:{src:a(308),alt:"The AOI image is split into two parts: The upper part depicts SAR data with some very bright and many very dark pixels, the lower part is more balanced."}}),t._v(" "),s("figcaption",[t._v("Here we see the effect of transforming intensity data to db: Both parts of the image are linearly scaled, but only the lower part has been log-transformed. It makes the interpretation much easier because image pixels take on less 'extreme' values.")])]),t._v(" "),s("h3",{attrs:{id:"image-kernels-apply-kernel"}},[s("a",{staticClass:"header-anchor",attrs:{href:"#image-kernels-apply-kernel"}},[t._v("#")]),t._v(" Image Kernels: "),s("code",[t._v("apply_kernel")])]),t._v(" "),s("p",[t._v("The process "),s("code",[t._v("apply_kernel")]),t._v(" takes an array of weights that is used as a moving window to calculate new pixel values. This is often used to smooth or sharped the image (e.g. Gaussian blur or highpass filter, respectively). Here, we show two Sobel edge detection kernels (both vertical and horizontal) and a highpass filter.")]),t._v(" "),s("p",[t._v("We'll only consider band 8 to shorten computation time.")]),t._v(" "),s("CodeSwitcher",{scopedSlots:t._u([{key:"py",fn:function(){return[s("div",{staticClass:"language-python extra-class"},[s("pre",{pre:!0,attrs:{class:"language-python"}},[s("code",[t._v("cube_s2_b8 "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" cube_s2"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),t._v("filter_bands"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"B08"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n")])])])]},proxy:!0},{key:"r",fn:function(){return[s("div",{staticClass:"language-r extra-class"},[s("pre",{pre:!0,attrs:{class:"language-r"}},[s("code",[t._v("cube_s2_b8 "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("<-")]),t._v(" p"),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("$")]),t._v("filter_bands"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("cube_s2"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" c"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"B08"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n")])])])]},proxy:!0},{key:"js",fn:function(){return[s("div",{staticClass:"language-js extra-class"},[s("pre",{pre:!0,attrs:{class:"language-js"}},[s("code",[t._v("cube_s2_b8 "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" builder"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("filter_bands")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("cube_s2"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"B08"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n")])])])]},proxy:!0}])}),t._v(" "),s("p",[t._v("Throughout all clients we can define the kernel as an array of arrays, of which the inner arrays represent lines ("),s("code",[t._v("x")]),t._v(") and the outer arrays columns ("),s("code",[t._v("y")]),t._v("). This means that by adding a line break after each inner array, a true representation of the kernel can be created (see "),s("code",[t._v("highpass")]),t._v(" in Python or JavaScript tab).")]),t._v(" "),s("p",[t._v("The parameters "),s("code",[t._v("factor")]),t._v(" and "),s("code",[t._v("border")]),t._v(" are not needed here and are left out to fall back to default. "),s("code",[t._v("factor")]),t._v(" (default "),s("code",[t._v("1")]),t._v(") is multiplied with each pixel after the focal operation, while "),s("code",[t._v("border")]),t._v(" (default "),s("code",[t._v("0")]),t._v(") defines how overlaps between the kernel and the image borders are handled (should pixel values be mirrored, replicated or simply set to 0?, see "),s("RouterLink",{attrs:{to:"/documentation/1.0/processes.html#apply_kernel"}},[s("code",[t._v("apply_kernel")])]),t._v(").")],1),t._v(" "),s("CodeSwitcher",{scopedSlots:t._u([{key:"py",fn:function(){return[s("div",{staticClass:"language-python extra-class"},[s("pre",{pre:!0,attrs:{class:"language-python"}},[s("code",[s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# we can pass a kernel as an array of arrays")]),t._v("\nsobel_vertical "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("1")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("2")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("1")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("0")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("0")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("0")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("-")]),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("1")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("-")]),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("2")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("-")]),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("1")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# e.g. 3x3 edge detection")]),t._v("\nsobel_horizontal "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("1")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("0")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("-")]),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("1")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("2")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("0")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("-")]),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("2")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("1")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("0")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("-")]),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("1")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),t._v("\n\nhighpass "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# or 5x5 highpass filter")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("-")]),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("1")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("-")]),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("1")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("-")]),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("1")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("-")]),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("1")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("-")]),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("1")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("-")]),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("1")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("-")]),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("1")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("-")]),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("1")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("-")]),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("1")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("-")]),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("1")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("-")]),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("1")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("-")]),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("1")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("24")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("-")]),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("1")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("-")]),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("1")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("-")]),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("1")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("-")]),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("1")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("-")]),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("1")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("-")]),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("1")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("-")]),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("1")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("-")]),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("1")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("-")]),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("1")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("-")]),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("1")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("-")]),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("1")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("-")]),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("1")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),t._v("\n"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),t._v("\n\n"),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# apply to cube")]),t._v("\ncube_s2_highpass "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" cube_s2_b8"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),t._v("apply_kernel"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("highpass"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n")])])])]},proxy:!0},{key:"r",fn:function(){return[s("div",{staticClass:"language-r extra-class"},[s("pre",{pre:!0,attrs:{class:"language-r"}},[s("code",[s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# we can pass a kernel as an array of arrays")]),t._v("\nsobel_vertical "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("<-")]),t._v(" matrix"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("c"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("1")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("2")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("1")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("0")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("0")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("0")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("-")]),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("1")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("-")]),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("2")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("-")]),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("1")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" nrow "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("3")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" byrow "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token boolean"}},[t._v("TRUE")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v(" \nsobel_horizontal "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("<-")]),t._v(" matrix"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("c"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("1")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("2")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("1")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("0")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("0")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("0")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("-")]),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("1")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("-")]),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("2")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("-")]),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("1")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" nrow "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("3")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# e.g. 3x3 edge detection")]),t._v("\n\nhighpass_vector "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("<-")]),t._v(" c"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("rep"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("-")]),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("1")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("12")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("24")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" rep"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("-")]),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("1")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("12")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\nhighpass "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("<-")]),t._v(" matrix"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("highpass_vector"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" nrow "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("5")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# or 5x5 highpass filter")]),t._v("\n\n"),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# apply to cube")]),t._v("\ncube_s2_b8_highpass "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("<-")]),t._v(" p"),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("$")]),t._v("apply_kernel"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("data "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" cube_s2_b8"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" kernel "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" highpass"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n")])])])]},proxy:!0},{key:"js",fn:function(){return[s("div",{staticClass:"language-js extra-class"},[s("pre",{pre:!0,attrs:{class:"language-js"}},[s("code",[s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("// we can pass a kernel as an array of arrays")]),t._v("\n"),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("let")]),t._v(" sobel_vertical "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("1")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("2")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("1")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("0")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("0")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("0")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("-")]),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("1")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("-")]),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("2")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("-")]),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("1")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("// e.g. 3x3 edge detection")]),t._v("\n"),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("let")]),t._v(" sobel_horizontal "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("1")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("0")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("-")]),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("1")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("2")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("0")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("-")]),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("2")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("1")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("0")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("-")]),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("1")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),t._v("\n\n"),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("let")]),t._v(" highpass "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("// or 5x5 highpass filter")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("-")]),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("1")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("-")]),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("1")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("-")]),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("1")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("-")]),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("1")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("-")]),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("1")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("-")]),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("1")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("-")]),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("1")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("-")]),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("1")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("-")]),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("1")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("-")]),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("1")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("-")]),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("1")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("-")]),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("1")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("24")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("-")]),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("1")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("-")]),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("1")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("-")]),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("1")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("-")]),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("1")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("-")]),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("1")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("-")]),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("1")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("-")]),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("1")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("-")]),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("1")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("-")]),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("1")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("-")]),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("1")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("-")]),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("1")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("-")]),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("1")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),t._v("\n"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),t._v("\n\n"),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("// apply to cube")]),t._v("\n"),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("var")]),t._v(" cube_s2_highpass "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" builder"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("apply_kernel")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("cube_s2_b8"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" highpass"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n")])])])]},proxy:!0}])}),t._v(" "),s("figure",[s("img",{attrs:{src:a(309),alt:"A combined edge detection RGB. Sobel vertical and horizontal are displayed as red and green, a 5x5 highpass filter is displayed as blue."}}),t._v(" "),s("figcaption",[t._v("Above a combined edge detection RGB can be seen. Sobel 3x3 vertical and horizontal edge detections are displayed as red and green, and a 5x5 highpass filter is displayed as blue. For this, all kernels in the code block above were applied and the sucessive cubes were merged afterwards.")])]),t._v(" "),s("h2",{attrs:{id:"endnote"}},[s("a",{staticClass:"header-anchor",attrs:{href:"#endnote"}},[t._v("#")]),t._v(" Endnote")]),t._v(" "),s("p",[t._v("You have "),s("strong",[t._v("feedback or")]),t._v(" noticed an "),s("strong",[t._v("error")]),t._v("? Feel free to open an issue in the "),s("a",{attrs:{href:"https://github.com/Open-EO/openeo.org",target:"_blank",rel:"noopener noreferrer"}},[t._v("github repository"),s("OutboundLink")],1),t._v(" or use the "),s("a",{attrs:{href:"https://openeo.org/contact.html",target:"_blank",rel:"noopener noreferrer"}},[t._v("other communication channels"),s("OutboundLink")],1)])],1)}),[],!1,null,null,null);s.default=e.exports}}]); \ No newline at end of file diff --git a/assets/js/19.6ea94681.js b/assets/js/19.65975aee.js similarity index 97% rename from assets/js/19.6ea94681.js rename to assets/js/19.65975aee.js index 88d0af871..b8d733724 100644 --- a/assets/js/19.6ea94681.js +++ b/assets/js/19.65975aee.js @@ -1 +1 @@ -(window.webpackJsonp=window.webpackJsonp||[]).push([[19,52],{164:function(e,t,s){"use strict";s.r(t);var a={computed:{unreleased(){return null!==this.version.apiTag.match(/(draft|alpha|beta)/i)},versioned(){return null!==this.$page.regularPath.match(/\/documentation\/([^\/]+)\//)},otherVersions(){return this.$site.themeConfig.versions.map((e,t)=>{var s=this.$site.themeConfig.versions[this.versionIndex],a=this.$site.themeConfig.versions[t];return e.regularPath=this.$page.regularPath.replace(s.path,a.path),e}).filter((e,t)=>t!==this.versionIndex&&this.$site.pages.findIndex(t=>t.regularPath==e.regularPath)>=0)},version(){return this.$site.themeConfig.versions[this.versionIndex]},defaultVersion(){return this.$site.themeConfig.versions[this.$site.themeConfig.defaultVersion]},versionIndex(){const{themeConfig:e}=this.$site;var t=this.$page.regularPath.match(/\/documentation\/([^\/]+)\//);if(Array.isArray(t)&&"string"==typeof t[1])for(var s in e.versions)if(e.versions[s].folder===t[1])return parseInt(s);return 0}}},i=s(4),r=Object(i.a)(a,void 0,void 0,!1,null,null,null);t.default=r.exports},339:function(e,t){function s(e){var t=new Error("Cannot find module '"+e+"'");throw t.code="MODULE_NOT_FOUND",t}s.keys=function(){return[]},s.resolve=s,e.exports=s,s.id=339},340:function(e,t,s){var a={"./0.4/developers/api/errors.json":341,"./1.0/developers/api/errors.json":342};function i(e){var t=r(e);return s(t)}function r(e){if(!s.o(a,e)){var t=new Error("Cannot find module '"+e+"'");throw t.code="MODULE_NOT_FOUND",t}return a[e]}i.keys=function(){return Object.keys(a)},i.resolve=r,e.exports=i,i.id=340},341:function(e){e.exports=JSON.parse('{"Internal":{"description":"An internal server error with a proprietary message.","message":"Server error: {message}","http":500,"tags":["General"]},"NotFound":{"description":"To be used if the requested resource does not exist. Note: Unsupported endpoints MUST send an \'FeatureUnsupported\' error. There are also specialized errors for missing jobs (JobNotFound), files (FileNotFound), etc.","message":"Resource not found.","http":404,"tags":["General"]},"FeatureUnsupported":{"description":"The back-end responds with this error whenever an endpoint is specified in the openEO API, but is not supported.","message":"Feature not supported.","http":501,"tags":["General"]},"InfrastructureMaintenance":{"description":"Service is currently not available, but the infrastructure is currently undergoing maintenance work.","message":"Service is not available at the moment due to maintenance work. Please try again later.","http":503,"tags":["General"]},"InfrastructureBusy":{"description":"Service is generally available, but the infrastructure can\'t handle it at the moment as too many requests are processed.","message":"Service is not available at the moment due to overloading. Please try again later.","http":503,"tags":["General"]},"Timeout":{"description":"The request took too long and timed out.","message":"Request timed out.","http":408,"tags":["General","Job Management"]},"CRSInvalid":{"description":"Invalid or unsupported CRS specified.","message":"CRS \'{crs}\' is invalid.","http":400,"tags":["Processes"]},"CoordinateOutOfBounds":{"description":null,"message":"Coordinate is out of bounds.","http":400,"tags":["Processes"]},"BudgetInvalid":{"description":"The budget is too low as it is either smaller than or equal to 0 or below the costs.","message":"The budget is too low.","http":400,"tags":["Job Management","Secondary Services Management"]},"NoDataForUpdate":{"description":"For PATCH requests: No valid data specified at all.","message":"No valid data specified to be updated.","http":400,"tags":["Job Management","Secondary Services Management","Process Graph Management"]},"PropertyNotEditable":{"description":"For PATCH requests: The specified parameter can\'t be updated. It is read-only.","message":"Property \'{property}\' is read-only.","http":400,"tags":["Job Management","Secondary Services Management","Process Graph Management"]},"WebSocketUpgradeNotRequested":{"description":"In order to subscribe the connection must be upgradable to WebSockets.","message":"Client sent invalid request to establish subscriptions.","http":400,"tags":["Subscriptions"]},"CollectionNotFound":{"description":"The requested collection does not exist.","message":"Collection does not exist.","http":404,"tags":["EO Data Discovery","Processes"]},"StorageFailure":{"description":"Server couldn\'t store file(s) due to server-side reasons.","message":"Unable to store file(s).","http":500,"tags":["File Management","Job Management"]},"StorageQuotaExceeded":{"description":"The storage quota has been exceeded by the user.","message":"Insufficient Storage.","http":400,"tags":["File Management","Job Management"]},"FileNotFound":{"description":"The requested file does not exist.","message":"File does not exist.","http":404,"tags":["File Management","Processes"]},"FilePathInvalid":{"description":"The specified path is invalid or not accessible. Path could contain invalid characters, an invalid user ID or point to an existing folder or a location outside of the user folder.","message":"File path is invalid.","http":400,"tags":["File Management"]},"FileOperationUnsupported":{"description":"The specified path is not a file and the operation is only supported for files. Path is likely a directory.","message":"Operation is only supported for files.","http":400,"tags":["File Management"]},"ContentTypeInvalid":{"description":"The specified media (MIME) type used in the Content-Type header is not allowed.","message":"The media type is not supported. Allowed: {types}","http":400,"tags":["File Management","General"]},"FileTypeInvalid":{"description":"File format, file extension or media (MIME) type is not allowed.","message":"File type not allowed. Allowed file types: {types}","http":400,"tags":["File Management"]},"FileSizeExceeded":{"description":"File exceeds allowed maximum file size.","message":"File size it too large. Maximum file size: {size}","http":400,"tags":["File Management"]},"FileContentInvalid":{"description":"The content of the file is invalid.","message":"File content is invalid.","http":400,"tags":["File Management","Processes"]},"FileLocked":{"description":"The file is locked by a running job or another process.","message":"File \'{file}\' is locked.","http":400,"tags":["File Management"]},"ProcessGraphNotFound":{"description":"The requested process graph does not exist.","message":"Process graph does not exist.","http":404,"tags":["Process Graph Management"]},"ProcessGraphMissing":{"description":null,"message":"No valid process graph specified.","http":400,"tags":["Process Graph Management","Job Management","Secondary Services Management"]},"VariableValueMissing":{"description":null,"message":"No value specified for process graph variable \'{variable_id}\'.","http":400,"tags":["Process Graph Management","Job Management","Secondary Services Management"]},"VariableDefaultValueTypeInvalid":{"description":null,"message":"The default value for the process graph variable \'{variable_id}\' is not of type \'{type}\'.","http":400,"tags":["Process Graph Management","Job Management"]},"VariableIdInvalid":{"description":null,"message":"A specified variable ID is not valid.","http":400,"tags":["Process Graph Management","Job Management"]},"VariableTypeInvalid":{"description":null,"message":"The data type for the process graph variable \'{variable_id}\' is invalid. Must be one of: string, boolean, number, array or object.","http":400,"tags":["Process Graph Management","Job Management"]},"ProcessUnsupported":{"description":null,"message":"Process \'{process}\' is not supported.","http":400,"tags":["Processes"]},"ProcessArgumentUnsupported":{"description":null,"message":"Process \'{process}\' does not support argument \'{argument}\'.","http":400,"tags":["Processes"]},"ProcessArgumentInvalid":{"description":null,"message":"The argument \'{argument}\' in process \'{process}\' is invalid: {reason}","http":400,"tags":["Processes"]},"ProcessArgumentRequired":{"description":null,"message":"Process \'{process}\' requires argument \'{argument}\'.","http":400,"tags":["Processes"]},"ProcessArgumentsMissing":{"description":null,"message":"Process \'{process}\' requires at least {min_parameters} parameters.","http":400,"tags":["Processes"]},"JobNotFound":{"description":"The requested job does not exist.","message":"The job does not exist.","http":404,"tags":["Job Management","Processes"]},"FormatUnsupported":{"description":null,"message":"Output format not supported.","http":400,"tags":["Job Management"]},"FormatArgumentUnsupported":{"description":null,"message":"Output format argument \'{argument}\' is not supported.","http":400,"tags":["Job Management"]},"FormatArgumentInvalid":{"description":null,"message":"The output format argument \'{argument}\' is invalid: {reason}","http":400,"tags":["Job Management"]},"FormatUnsuitable":{"description":null,"message":"Data can\'t be transformed into the requested output format.","http":400,"tags":["Job Management"]},"JobLocked":{"description":"The job is currently locked due to a running batch computation and can\'t be modified meanwhile.","message":"Job is locked due to a queued or running batch computation.","http":400,"tags":["Job Management"]},"JobNotFinished":{"description":null,"message":"Job has not finished computing the results yet. Please try again later.","http":400,"tags":["Job Management"]},"JobNotStarted":{"description":"Job has not been queued or started yet or was canceled and not restarted by the user.","message":"Job hasn\'t been started yet.","http":400,"tags":["Job Management"]},"PaymentRequired":{"description":"The budget required to fulfil the request are insufficient.","message":"Payment required.","http":402,"tags":["Job Management","Secondary Services Management"]},"BillingPlanInvalid":{"description":"The billing plan is not on the list of available plans.","message":"The billing plan is not valid.","http":400,"tags":["Job Management","Secondary Services Management"]},"AuthenticationRequired":{"description":"The client did not provide any authentication details for a resource requiring authentication or the provided authentication details are not correct.","message":"Unauthorized.","http":401,"tags":["Account Management"]},"AuthenticationSchemeInvalid":{"description":"Invalid authentication scheme (e.g. Bearer).","message":"Authentication method not supported.","http":403,"tags":["Account Management"]},"TokenInvalid":{"description":"Authorization token invalid or expired.","message":"Session has expired.","http":403,"tags":["Account Management"]},"CredentialsInvalid":{"description":null,"message":"Credentials are not correct.","http":403,"tags":["Account Management"]},"ServiceNotFound":{"description":"The requested secondary service does not exist.","message":"Service does not exist.","http":404,"tags":["Secondary Services Management"]},"ServiceUnsupported":{"description":null,"message":"Secondary service type is not supported.","http":400,"tags":["Secondary Services Management"]},"ServiceArgumentUnsupported":{"description":null,"message":"Secondary service argument \'{argument}\' is not supported.","http":400,"tags":["Secondary Services Management"]},"ServiceArgumentInvalid":{"description":null,"message":"The secondary service argument \'{argument}\' is invalid: {reason}","http":400,"tags":["Secondary Services Management"]},"ServiceArgumentRequired":{"description":null,"message":"Required secondary service argument \'{argument}\' is missing.","http":400,"tags":["Secondary Services Management"]}}')},342:function(e){e.exports=JSON.parse('{"Internal":{"description":"An internal server error with a proprietary message.","message":"Server error: {message}","http":500,"tags":["General"]},"NotFound":{"description":"To be used if the requested resource does not exist. Note: There are specialized errors for missing jobs (JobNotFound), files (FileNotFound), etc. Unsupported endpoints MAY send an \'FeatureUnsupported\' (501) error.","message":"Resource not found.","http":404,"tags":["General"]},"FeatureUnsupported":{"description":"The back-end responds with this error whenever an endpoint is specified in the openEO API, but is not supported.","message":"Feature not supported.","http":501,"tags":["General"]},"InfrastructureMaintenance":{"description":"Service is currently not available as the infrastructure is currently undergoing maintenance work.","message":"Service is not available at the moment due to maintenance work. Please try again later or contact our support.","http":503,"tags":["General"]},"InfrastructureBusy":{"description":"Service is generally available, but the infrastructure can\'t handle it at the moment as too many requests are processed.","message":"Service is not available at the moment due to overloading. Please try again later or contact our support.","http":503,"tags":["General"]},"UnsupportedApiVersion":{"description":"The service doesn\'t support the openEO API version specified in the request URL. Clients should check well-known document for supported versions.","message":"The requested API version \'{version}\' is not supported.","http":404,"tags":["General"]},"RequestTimeout":{"description":"The request took too long and timed out.","message":"Request timed out.","http":408,"tags":["General","Data Processing"]},"BudgetInvalid":{"description":"The budget is too low as it is either smaller than or equal to 0 or below the costs.","message":"The specified budget is too low.","http":400,"tags":["Batch Jobs","Secondary Services","Data Processing"]},"EstimateComplexity":{"description":"The process is too complex to calculate an estimate, e.g. due to a UDF or other processes that are complex to estimate costs reliably.","message":"The process is too complex to calculate an estimate.","http":500,"tags":["Batch Jobs"]},"NoDataForUpdate":{"description":"For PATCH requests: No valid data specified at all.","message":"No data specified to be updated.","http":400,"tags":["Batch Jobs","Secondary Services"]},"PropertyNotEditable":{"description":"For PATCH requests: The specified parameter can\'t be updated. It is read-only.","message":"The specified property \'{property}\' is read-only.","http":400,"tags":["Batch Jobs","Secondary Services"]},"CollectionNotFound":{"description":"The requested collection does not exist.","message":"Collection \'{identifier}\' does not exist.","http":404,"tags":["EO Data Discovery"]},"StorageFailure":{"description":"Server couldn\'t store file(s) due to server-side reasons.","message":"Unable to store files due to a server error. Please try again later or contact our support.","http":500,"tags":["File Management","Batch Jobs"]},"StorageQuotaExceeded":{"description":"The storage quota has been exceeded by the user.","message":"Your storage quota has been exceeded.","http":400,"tags":["File Management","Batch Jobs"]},"FileNotFound":{"description":"The requested file does not exist.","message":"File \'{file}\' does not exist.","http":404,"tags":["File Management"]},"FilePathInvalid":{"description":"The specified path is invalid or not accessible. Path could contain invalid characters, point to an existing folder or a location outside of the user folder.","message":"File path is invalid: {reason}","http":400,"tags":["File Management"]},"FileOperationUnsupported":{"description":null,"message":"The file operation is not supported for the specified path.","http":400,"tags":["File Management"]},"FolderOperationUnsupported":{"description":"The specified path is a folder and the operation is only supported for files.","message":"Operation is only supported for files, not folders.","http":400,"tags":["File Management"]},"ContentTypeInvalid":{"description":"The specified media (MIME) type used in the Content-Type header is not allowed.","message":"The media type is not supported. Allowed: {types}","http":400,"tags":["File Management","General"]},"FileTypeInvalid":{"description":"File format or file extension is not allowed.","message":"File format {type} not allowed. Allowed file formats: {types}","http":400,"tags":["File Management"]},"FileSizeExceeded":{"description":"File exceeds allowed maximum file size.","message":"File size it too large. Maximum file size: {size}","http":400,"tags":["File Management"]},"FileContentInvalid":{"description":"The content of the file is invalid.","message":"File content is invalid.","http":400,"tags":["File Management"]},"FileLocked":{"description":"The file is locked by a running job or another process.","message":"File \'{file}\' is locked by another process.","http":400,"tags":["File Management"]},"ProcessGraphNotFound":{"description":"The requested user-defined process does not exist. To be used for all endpoints starting with `/process_graphs`.","message":"User-defined process \'{identifier}\' does not exist.","http":404,"tags":["User-Defined Processes"]},"ProcessInvalid":{"description":"The process given is invalid, which ususlly means that the process metadata is invalid.","message":"Invalid process specified.","http":400,"tags":["User-Defined Processes","Batch Jobs","Secondary Services","Data Processing"]},"ProcessGraphMissing":{"description":"The process doesn\'t contain a process graph. For jobs, services, and sync. processing the parameter `process` must contain a `process_graph`.","message":"Invalid process specified. It doesn\'t contain a process graph.","http":400,"tags":["User-Defined Processes","Batch Jobs","Secondary Services","Data Processing"]},"ProcessGraphInvalid":{"description":"The process doesn\'t contain a valid process graph, which means it doesn\'t comply to the general structure / schema.","message":"Invalid process graph specified.","http":400,"tags":["User-Defined Processes","Batch Jobs","Secondary Services","Data Processing"]},"PredefinedProcessExists":{"description":"If a user wants to store a user-defined process with the id of a predefined process.","message":"A predefined process with the given identifier exists.","http":400,"tags":["User-Defined Processes"]},"ProcessGraphComplexity":{"description":"The process graph is too complex for synchronous processing and will likely time out. Please use a batch job instead.","message":"The process is too complex for for synchronous processing. Please use a batch job instead.","http":400,"tags":["Data Processing"]},"ProcessUnsupported":{"description":"A process (predefined or user-defined) with the specified identifier is not available. To be used when validating or executing process graphs.","message":"Process with identifier \'{process}\' is not available in namespace \'{namespace}\'.","http":400,"tags":["Data Processing"]},"ProcessParameterUnsupported":{"description":null,"message":"Process \'{process}\' does not support parameter \'{parameter}\'.","http":400,"tags":["Data Processing"]},"ProcessParameterInvalid":{"description":null,"message":"The value passed for parameter \'{parameter}\' in process \'{process}\' is invalid: {reason}","http":400,"tags":["Data Processing"]},"ProcessParameterRequired":{"description":null,"message":"Process \'{process}\' parameter \'{parameter}\' is required.","http":400,"tags":["Data Processing"]},"JobNotFound":{"description":"The requested job does not exist.","message":"The batch job \'{identifier}\' does not exist.","http":404,"tags":["Batch Jobs"]},"JobLocked":{"description":"The job is currently locked due to a running batch computation and can\'t be modified meanwhile.","message":"Batch job is locked due to a queued or running batch computation.","http":400,"tags":["Batch Jobs"]},"JobNotFinished":{"description":null,"message":"Batch job has not finished computing the results yet. Please try again later or contact our support.","http":400,"tags":["Batch Jobs"]},"JobNotStarted":{"description":"Job has not been queued or started yet or was canceled and not restarted by the user.","message":"Batch job must be started first.","http":400,"tags":["Batch Jobs"]},"ResultLinkExpired":{"description":"The signed URLs for batch job results have expired. Please send a request to `GET /jobs/{job_id}/results` to refresh the links.","message":"The link to the batch job result has expired. Please request the results again.","http":410,"tags":["Batch Jobs"]},"PaymentRequired":{"description":"The budget required to fulfil the request is insufficient.","message":"The budget required to fulfil the request is not sufficient. A payment is required first.","http":402,"tags":["Batch Jobs","Secondary Services"]},"BillingPlanInvalid":{"description":"The billing plan is not on the list of available plans.","message":"The billing plan is invalid.","http":400,"tags":["Batch Jobs","Secondary Services","Data Processing"]},"BillingPlanMissing":{"description":"No billing plan has been specified by the user and the billing plan can\'t be determined unambiguously.","message":"A billing plan must be specified.","http":400,"tags":["Batch Jobs","Secondary Services","Data Processing"]},"AuthenticationRequired":{"description":"The client did not provide any authentication details for a resource requiring authentication or the provided authentication details are not correct.","message":"Unauthorized.","http":401,"tags":["Account Management"]},"AuthenticationSchemeInvalid":{"description":"Invalid authentication scheme (e.g. Bearer).","message":"Authentication method not supported.","http":403,"tags":["Account Management"]},"TokenInvalid":{"description":null,"message":"Authorization token has expired or is invalid. Please authenticate again.","http":403,"tags":["Account Management"]},"CredentialsInvalid":{"description":null,"message":"Credentials are not correct.","http":403,"tags":["Account Management"]},"PermissionsInsufficient":{"description":"Forbidden. The client did provided correct authentication details, but the privileges/permissions of the provided credentials do not allow to request the resource.","message":"Forbidden. The permissions of the authenticated account do not allow to request the requested resource.","http":403,"tags":["Account Management"]},"ServiceNotFound":{"description":"The requested secondary service does not exist.","message":"Service \'{identifier}\' does not exist.","http":404,"tags":["Secondary Services"]},"ServiceUnsupported":{"description":null,"message":"Service type \'{type}\' is not supported.","http":400,"tags":["Secondary Services"]},"ServiceConfigUnsupported":{"description":"Refers to the secondary service `configuration` object.","message":"Service parameter \'{parameter}\' is not supported.","http":400,"tags":["Secondary Services"]},"ServiceConfigInvalid":{"description":"Refers to the secondary service `configuration` object.","message":"The value passed for the service parameter \'{parameter}\' is invalid: {reason}","http":400,"tags":["Secondary Services"]},"ServiceConfigRequired":{"description":"Refers to the secondary service `configuration` object.","message":"Service parameter \'{parameter}\' is required.","http":400,"tags":["Secondary Services"]}}')},480:function(e,t,s){"use strict";s.r(t);var a={name:"ErrorCodes",mixins:[s(164).default],props:["file"],data:()=>({errors:{},tags:[]}),filters:{slugify:e=>e.toLowerCase().replace(" ","_")},created(){var e;try{e=s(339)("./"+this.version.folder+"/developers/api/errors.json")}catch(t){e=s(340)("./"+this.version.folder+"/developers/api/errors.json")}for(var t in e){var a=e[t];for(var i in a.description||(a.description=""),a.message||console.log("No message specified for error: "+t),a.http||console.log("No HTTP status code specified for error: "+t),a.tags&&Array.isArray(a.tags)&&0!==a.tags.length||console.warn("No tags specified for error: "+t),a.tags){var r=a.tags[i];void 0===this.errors[r]&&(this.errors[r]={}),this.errors[r][t]=a}}this.tags=Object.keys(this.errors),this.tags.sort()}},i=s(4),r=Object(i.a)(a,(function(){var e=this,t=e._self._c;return t("div",{staticClass:"error-codes"},[t("p",[e._v("The whole table of error codes is available as "),t("a",{attrs:{href:"/documentation/"+e.version.folder+"/developers/api/errors.json",target:"_blank"}},[e._v("JSON file")]),e._v(", which can be used by implementors to automatically generate error responses.")]),e._v(" "),e._l(e.tags,(function(s){return t("div",[t("a",{attrs:{name:e._f("slugify")(s)}}),e._v(" "),t("h2",[e._v(e._s(s))]),e._v(" "),t("table",[e._m(0,!0),e._v(" "),e._l(e.errors[s],(function(s,a){return t("tr",[t("td",[e._v(e._s(a))]),e._v(" "),t("td",[e._v(e._s(s.description))]),e._v(" "),t("td",[e._v(e._s(s.message))]),e._v(" "),t("td",[e._v(e._s(s.http))])])}))],2)])}))],2)}),[function(){var e=this._self._c;return e("tr",[e("th",{attrs:{width:"20%"}},[this._v("openEO Error Code")]),this._v(" "),e("th",{attrs:{width:"40%"}},[this._v("Description")]),this._v(" "),e("th",{attrs:{width:"35%"}},[this._v("Example Message")]),this._v(" "),e("th",{attrs:{width:"5%"}},[this._v("HTTP Status Code")])])}],!1,null,null,null);t.default=r.exports}}]); \ No newline at end of file +(window.webpackJsonp=window.webpackJsonp||[]).push([[19,52],{164:function(e,t,s){"use strict";s.r(t);var a={computed:{unreleased(){return null!==this.version.apiTag.match(/(draft|alpha|beta)/i)},versioned(){return null!==this.$page.regularPath.match(/\/documentation\/([^\/]+)\//)},otherVersions(){return this.$site.themeConfig.versions.map((e,t)=>{var s=this.$site.themeConfig.versions[this.versionIndex],a=this.$site.themeConfig.versions[t];return e.regularPath=this.$page.regularPath.replace(s.path,a.path),e}).filter((e,t)=>t!==this.versionIndex&&this.$site.pages.findIndex(t=>t.regularPath==e.regularPath)>=0)},version(){return this.$site.themeConfig.versions[this.versionIndex]},defaultVersion(){return this.$site.themeConfig.versions[this.$site.themeConfig.defaultVersion]},versionIndex(){const{themeConfig:e}=this.$site;var t=this.$page.regularPath.match(/\/documentation\/([^\/]+)\//);if(Array.isArray(t)&&"string"==typeof t[1])for(var s in e.versions)if(e.versions[s].folder===t[1])return parseInt(s);return 0}}},i=s(4),r=Object(i.a)(a,void 0,void 0,!1,null,null,null);t.default=r.exports},340:function(e,t){function s(e){var t=new Error("Cannot find module '"+e+"'");throw t.code="MODULE_NOT_FOUND",t}s.keys=function(){return[]},s.resolve=s,e.exports=s,s.id=340},341:function(e,t,s){var a={"./0.4/developers/api/errors.json":342,"./1.0/developers/api/errors.json":343};function i(e){var t=r(e);return s(t)}function r(e){if(!s.o(a,e)){var t=new Error("Cannot find module '"+e+"'");throw t.code="MODULE_NOT_FOUND",t}return a[e]}i.keys=function(){return Object.keys(a)},i.resolve=r,e.exports=i,i.id=341},342:function(e){e.exports=JSON.parse('{"Internal":{"description":"An internal server error with a proprietary message.","message":"Server error: {message}","http":500,"tags":["General"]},"NotFound":{"description":"To be used if the requested resource does not exist. Note: Unsupported endpoints MUST send an \'FeatureUnsupported\' error. There are also specialized errors for missing jobs (JobNotFound), files (FileNotFound), etc.","message":"Resource not found.","http":404,"tags":["General"]},"FeatureUnsupported":{"description":"The back-end responds with this error whenever an endpoint is specified in the openEO API, but is not supported.","message":"Feature not supported.","http":501,"tags":["General"]},"InfrastructureMaintenance":{"description":"Service is currently not available, but the infrastructure is currently undergoing maintenance work.","message":"Service is not available at the moment due to maintenance work. Please try again later.","http":503,"tags":["General"]},"InfrastructureBusy":{"description":"Service is generally available, but the infrastructure can\'t handle it at the moment as too many requests are processed.","message":"Service is not available at the moment due to overloading. Please try again later.","http":503,"tags":["General"]},"Timeout":{"description":"The request took too long and timed out.","message":"Request timed out.","http":408,"tags":["General","Job Management"]},"CRSInvalid":{"description":"Invalid or unsupported CRS specified.","message":"CRS \'{crs}\' is invalid.","http":400,"tags":["Processes"]},"CoordinateOutOfBounds":{"description":null,"message":"Coordinate is out of bounds.","http":400,"tags":["Processes"]},"BudgetInvalid":{"description":"The budget is too low as it is either smaller than or equal to 0 or below the costs.","message":"The budget is too low.","http":400,"tags":["Job Management","Secondary Services Management"]},"NoDataForUpdate":{"description":"For PATCH requests: No valid data specified at all.","message":"No valid data specified to be updated.","http":400,"tags":["Job Management","Secondary Services Management","Process Graph Management"]},"PropertyNotEditable":{"description":"For PATCH requests: The specified parameter can\'t be updated. It is read-only.","message":"Property \'{property}\' is read-only.","http":400,"tags":["Job Management","Secondary Services Management","Process Graph Management"]},"WebSocketUpgradeNotRequested":{"description":"In order to subscribe the connection must be upgradable to WebSockets.","message":"Client sent invalid request to establish subscriptions.","http":400,"tags":["Subscriptions"]},"CollectionNotFound":{"description":"The requested collection does not exist.","message":"Collection does not exist.","http":404,"tags":["EO Data Discovery","Processes"]},"StorageFailure":{"description":"Server couldn\'t store file(s) due to server-side reasons.","message":"Unable to store file(s).","http":500,"tags":["File Management","Job Management"]},"StorageQuotaExceeded":{"description":"The storage quota has been exceeded by the user.","message":"Insufficient Storage.","http":400,"tags":["File Management","Job Management"]},"FileNotFound":{"description":"The requested file does not exist.","message":"File does not exist.","http":404,"tags":["File Management","Processes"]},"FilePathInvalid":{"description":"The specified path is invalid or not accessible. Path could contain invalid characters, an invalid user ID or point to an existing folder or a location outside of the user folder.","message":"File path is invalid.","http":400,"tags":["File Management"]},"FileOperationUnsupported":{"description":"The specified path is not a file and the operation is only supported for files. Path is likely a directory.","message":"Operation is only supported for files.","http":400,"tags":["File Management"]},"ContentTypeInvalid":{"description":"The specified media (MIME) type used in the Content-Type header is not allowed.","message":"The media type is not supported. Allowed: {types}","http":400,"tags":["File Management","General"]},"FileTypeInvalid":{"description":"File format, file extension or media (MIME) type is not allowed.","message":"File type not allowed. Allowed file types: {types}","http":400,"tags":["File Management"]},"FileSizeExceeded":{"description":"File exceeds allowed maximum file size.","message":"File size it too large. Maximum file size: {size}","http":400,"tags":["File Management"]},"FileContentInvalid":{"description":"The content of the file is invalid.","message":"File content is invalid.","http":400,"tags":["File Management","Processes"]},"FileLocked":{"description":"The file is locked by a running job or another process.","message":"File \'{file}\' is locked.","http":400,"tags":["File Management"]},"ProcessGraphNotFound":{"description":"The requested process graph does not exist.","message":"Process graph does not exist.","http":404,"tags":["Process Graph Management"]},"ProcessGraphMissing":{"description":null,"message":"No valid process graph specified.","http":400,"tags":["Process Graph Management","Job Management","Secondary Services Management"]},"VariableValueMissing":{"description":null,"message":"No value specified for process graph variable \'{variable_id}\'.","http":400,"tags":["Process Graph Management","Job Management","Secondary Services Management"]},"VariableDefaultValueTypeInvalid":{"description":null,"message":"The default value for the process graph variable \'{variable_id}\' is not of type \'{type}\'.","http":400,"tags":["Process Graph Management","Job Management"]},"VariableIdInvalid":{"description":null,"message":"A specified variable ID is not valid.","http":400,"tags":["Process Graph Management","Job Management"]},"VariableTypeInvalid":{"description":null,"message":"The data type for the process graph variable \'{variable_id}\' is invalid. Must be one of: string, boolean, number, array or object.","http":400,"tags":["Process Graph Management","Job Management"]},"ProcessUnsupported":{"description":null,"message":"Process \'{process}\' is not supported.","http":400,"tags":["Processes"]},"ProcessArgumentUnsupported":{"description":null,"message":"Process \'{process}\' does not support argument \'{argument}\'.","http":400,"tags":["Processes"]},"ProcessArgumentInvalid":{"description":null,"message":"The argument \'{argument}\' in process \'{process}\' is invalid: {reason}","http":400,"tags":["Processes"]},"ProcessArgumentRequired":{"description":null,"message":"Process \'{process}\' requires argument \'{argument}\'.","http":400,"tags":["Processes"]},"ProcessArgumentsMissing":{"description":null,"message":"Process \'{process}\' requires at least {min_parameters} parameters.","http":400,"tags":["Processes"]},"JobNotFound":{"description":"The requested job does not exist.","message":"The job does not exist.","http":404,"tags":["Job Management","Processes"]},"FormatUnsupported":{"description":null,"message":"Output format not supported.","http":400,"tags":["Job Management"]},"FormatArgumentUnsupported":{"description":null,"message":"Output format argument \'{argument}\' is not supported.","http":400,"tags":["Job Management"]},"FormatArgumentInvalid":{"description":null,"message":"The output format argument \'{argument}\' is invalid: {reason}","http":400,"tags":["Job Management"]},"FormatUnsuitable":{"description":null,"message":"Data can\'t be transformed into the requested output format.","http":400,"tags":["Job Management"]},"JobLocked":{"description":"The job is currently locked due to a running batch computation and can\'t be modified meanwhile.","message":"Job is locked due to a queued or running batch computation.","http":400,"tags":["Job Management"]},"JobNotFinished":{"description":null,"message":"Job has not finished computing the results yet. Please try again later.","http":400,"tags":["Job Management"]},"JobNotStarted":{"description":"Job has not been queued or started yet or was canceled and not restarted by the user.","message":"Job hasn\'t been started yet.","http":400,"tags":["Job Management"]},"PaymentRequired":{"description":"The budget required to fulfil the request are insufficient.","message":"Payment required.","http":402,"tags":["Job Management","Secondary Services Management"]},"BillingPlanInvalid":{"description":"The billing plan is not on the list of available plans.","message":"The billing plan is not valid.","http":400,"tags":["Job Management","Secondary Services Management"]},"AuthenticationRequired":{"description":"The client did not provide any authentication details for a resource requiring authentication or the provided authentication details are not correct.","message":"Unauthorized.","http":401,"tags":["Account Management"]},"AuthenticationSchemeInvalid":{"description":"Invalid authentication scheme (e.g. Bearer).","message":"Authentication method not supported.","http":403,"tags":["Account Management"]},"TokenInvalid":{"description":"Authorization token invalid or expired.","message":"Session has expired.","http":403,"tags":["Account Management"]},"CredentialsInvalid":{"description":null,"message":"Credentials are not correct.","http":403,"tags":["Account Management"]},"ServiceNotFound":{"description":"The requested secondary service does not exist.","message":"Service does not exist.","http":404,"tags":["Secondary Services Management"]},"ServiceUnsupported":{"description":null,"message":"Secondary service type is not supported.","http":400,"tags":["Secondary Services Management"]},"ServiceArgumentUnsupported":{"description":null,"message":"Secondary service argument \'{argument}\' is not supported.","http":400,"tags":["Secondary Services Management"]},"ServiceArgumentInvalid":{"description":null,"message":"The secondary service argument \'{argument}\' is invalid: {reason}","http":400,"tags":["Secondary Services Management"]},"ServiceArgumentRequired":{"description":null,"message":"Required secondary service argument \'{argument}\' is missing.","http":400,"tags":["Secondary Services Management"]}}')},343:function(e){e.exports=JSON.parse('{"Internal":{"description":"An internal server error with a proprietary message.","message":"Server error: {message}","http":500,"tags":["General"]},"NotFound":{"description":"To be used if the requested resource does not exist. Note: There are specialized errors for missing jobs (JobNotFound), files (FileNotFound), etc. Unsupported endpoints MAY send an \'FeatureUnsupported\' (501) error.","message":"Resource not found.","http":404,"tags":["General"]},"FeatureUnsupported":{"description":"The back-end responds with this error whenever an endpoint is specified in the openEO API, but is not supported.","message":"Feature not supported.","http":501,"tags":["General"]},"InfrastructureMaintenance":{"description":"Service is currently not available as the infrastructure is currently undergoing maintenance work.","message":"Service is not available at the moment due to maintenance work. Please try again later or contact our support.","http":503,"tags":["General"]},"InfrastructureBusy":{"description":"Service is generally available, but the infrastructure can\'t handle it at the moment as too many requests are processed.","message":"Service is not available at the moment due to overloading. Please try again later or contact our support.","http":503,"tags":["General"]},"UnsupportedApiVersion":{"description":"The service doesn\'t support the openEO API version specified in the request URL. Clients should check well-known document for supported versions.","message":"The requested API version \'{version}\' is not supported.","http":404,"tags":["General"]},"RequestTimeout":{"description":"The request took too long and timed out.","message":"Request timed out.","http":408,"tags":["General","Data Processing"]},"BudgetInvalid":{"description":"The budget is too low as it is either smaller than or equal to 0 or below the costs.","message":"The specified budget is too low.","http":400,"tags":["Batch Jobs","Secondary Services","Data Processing"]},"EstimateComplexity":{"description":"The process is too complex to calculate an estimate, e.g. due to a UDF or other processes that are complex to estimate costs reliably.","message":"The process is too complex to calculate an estimate.","http":500,"tags":["Batch Jobs"]},"NoDataForUpdate":{"description":"For PATCH requests: No valid data specified at all.","message":"No data specified to be updated.","http":400,"tags":["Batch Jobs","Secondary Services"]},"PropertyNotEditable":{"description":"For PATCH requests: The specified parameter can\'t be updated. It is read-only.","message":"The specified property \'{property}\' is read-only.","http":400,"tags":["Batch Jobs","Secondary Services"]},"CollectionNotFound":{"description":"The requested collection does not exist.","message":"Collection \'{identifier}\' does not exist.","http":404,"tags":["EO Data Discovery"]},"StorageFailure":{"description":"Server couldn\'t store file(s) due to server-side reasons.","message":"Unable to store files due to a server error. Please try again later or contact our support.","http":500,"tags":["File Management","Batch Jobs"]},"StorageQuotaExceeded":{"description":"The storage quota has been exceeded by the user.","message":"Your storage quota has been exceeded.","http":400,"tags":["File Management","Batch Jobs"]},"FileNotFound":{"description":"The requested file does not exist.","message":"File \'{file}\' does not exist.","http":404,"tags":["File Management"]},"FilePathInvalid":{"description":"The specified path is invalid or not accessible. Path could contain invalid characters, point to an existing folder or a location outside of the user folder.","message":"File path is invalid: {reason}","http":400,"tags":["File Management"]},"FileOperationUnsupported":{"description":null,"message":"The file operation is not supported for the specified path.","http":400,"tags":["File Management"]},"FolderOperationUnsupported":{"description":"The specified path is a folder and the operation is only supported for files.","message":"Operation is only supported for files, not folders.","http":400,"tags":["File Management"]},"ContentTypeInvalid":{"description":"The specified media (MIME) type used in the Content-Type header is not allowed.","message":"The media type is not supported. Allowed: {types}","http":400,"tags":["File Management","General"]},"FileTypeInvalid":{"description":"File format or file extension is not allowed.","message":"File format {type} not allowed. Allowed file formats: {types}","http":400,"tags":["File Management"]},"FileSizeExceeded":{"description":"File exceeds allowed maximum file size.","message":"File size it too large. Maximum file size: {size}","http":400,"tags":["File Management"]},"FileContentInvalid":{"description":"The content of the file is invalid.","message":"File content is invalid.","http":400,"tags":["File Management"]},"FileLocked":{"description":"The file is locked by a running job or another process.","message":"File \'{file}\' is locked by another process.","http":400,"tags":["File Management"]},"ProcessGraphNotFound":{"description":"The requested user-defined process does not exist. To be used for all endpoints starting with `/process_graphs`.","message":"User-defined process \'{identifier}\' does not exist.","http":404,"tags":["User-Defined Processes"]},"ProcessInvalid":{"description":"The process given is invalid, which ususlly means that the process metadata is invalid.","message":"Invalid process specified.","http":400,"tags":["User-Defined Processes","Batch Jobs","Secondary Services","Data Processing"]},"ProcessGraphMissing":{"description":"The process doesn\'t contain a process graph. For jobs, services, and sync. processing the parameter `process` must contain a `process_graph`.","message":"Invalid process specified. It doesn\'t contain a process graph.","http":400,"tags":["User-Defined Processes","Batch Jobs","Secondary Services","Data Processing"]},"ProcessGraphInvalid":{"description":"The process doesn\'t contain a valid process graph, which means it doesn\'t comply to the general structure / schema.","message":"Invalid process graph specified.","http":400,"tags":["User-Defined Processes","Batch Jobs","Secondary Services","Data Processing"]},"PredefinedProcessExists":{"description":"If a user wants to store a user-defined process with the id of a predefined process.","message":"A predefined process with the given identifier exists.","http":400,"tags":["User-Defined Processes"]},"ProcessGraphComplexity":{"description":"The process graph is too complex for synchronous processing and will likely time out. Please use a batch job instead.","message":"The process is too complex for for synchronous processing. Please use a batch job instead.","http":400,"tags":["Data Processing"]},"ProcessUnsupported":{"description":"A process (predefined or user-defined) with the specified identifier is not available. To be used when validating or executing process graphs.","message":"Process with identifier \'{process}\' is not available in namespace \'{namespace}\'.","http":400,"tags":["Data Processing"]},"ProcessParameterUnsupported":{"description":null,"message":"Process \'{process}\' does not support parameter \'{parameter}\'.","http":400,"tags":["Data Processing"]},"ProcessParameterInvalid":{"description":null,"message":"The value passed for parameter \'{parameter}\' in process \'{process}\' is invalid: {reason}","http":400,"tags":["Data Processing"]},"ProcessParameterRequired":{"description":null,"message":"Process \'{process}\' parameter \'{parameter}\' is required.","http":400,"tags":["Data Processing"]},"JobNotFound":{"description":"The requested job does not exist.","message":"The batch job \'{identifier}\' does not exist.","http":404,"tags":["Batch Jobs"]},"JobLocked":{"description":"The job is currently locked due to a running batch computation and can\'t be modified meanwhile.","message":"Batch job is locked due to a queued or running batch computation.","http":400,"tags":["Batch Jobs"]},"JobNotFinished":{"description":null,"message":"Batch job has not finished computing the results yet. Please try again later or contact our support.","http":400,"tags":["Batch Jobs"]},"JobNotStarted":{"description":"Job has not been queued or started yet or was canceled and not restarted by the user.","message":"Batch job must be started first.","http":400,"tags":["Batch Jobs"]},"ResultLinkExpired":{"description":"The signed URLs for batch job results have expired. Please send a request to `GET /jobs/{job_id}/results` to refresh the links.","message":"The link to the batch job result has expired. Please request the results again.","http":410,"tags":["Batch Jobs"]},"PaymentRequired":{"description":"The budget required to fulfil the request is insufficient.","message":"The budget required to fulfil the request is not sufficient. A payment is required first.","http":402,"tags":["Batch Jobs","Secondary Services"]},"BillingPlanInvalid":{"description":"The billing plan is not on the list of available plans.","message":"The billing plan is invalid.","http":400,"tags":["Batch Jobs","Secondary Services","Data Processing"]},"BillingPlanMissing":{"description":"No billing plan has been specified by the user and the billing plan can\'t be determined unambiguously.","message":"A billing plan must be specified.","http":400,"tags":["Batch Jobs","Secondary Services","Data Processing"]},"AuthenticationRequired":{"description":"The client did not provide any authentication details for a resource requiring authentication or the provided authentication details are not correct.","message":"Unauthorized.","http":401,"tags":["Account Management"]},"AuthenticationSchemeInvalid":{"description":"Invalid authentication scheme (e.g. Bearer).","message":"Authentication method not supported.","http":403,"tags":["Account Management"]},"TokenInvalid":{"description":null,"message":"Authorization token has expired or is invalid. Please authenticate again.","http":403,"tags":["Account Management"]},"CredentialsInvalid":{"description":null,"message":"Credentials are not correct.","http":403,"tags":["Account Management"]},"PermissionsInsufficient":{"description":"Forbidden. The client did provided correct authentication details, but the privileges/permissions of the provided credentials do not allow to request the resource.","message":"Forbidden. The permissions of the authenticated account do not allow to request the requested resource.","http":403,"tags":["Account Management"]},"ServiceNotFound":{"description":"The requested secondary service does not exist.","message":"Service \'{identifier}\' does not exist.","http":404,"tags":["Secondary Services"]},"ServiceUnsupported":{"description":null,"message":"Service type \'{type}\' is not supported.","http":400,"tags":["Secondary Services"]},"ServiceConfigUnsupported":{"description":"Refers to the secondary service `configuration` object.","message":"Service parameter \'{parameter}\' is not supported.","http":400,"tags":["Secondary Services"]},"ServiceConfigInvalid":{"description":"Refers to the secondary service `configuration` object.","message":"The value passed for the service parameter \'{parameter}\' is invalid: {reason}","http":400,"tags":["Secondary Services"]},"ServiceConfigRequired":{"description":"Refers to the secondary service `configuration` object.","message":"Service parameter \'{parameter}\' is required.","http":400,"tags":["Secondary Services"]}}')},481:function(e,t,s){"use strict";s.r(t);var a={name:"ErrorCodes",mixins:[s(164).default],props:["file"],data:()=>({errors:{},tags:[]}),filters:{slugify:e=>e.toLowerCase().replace(" ","_")},created(){var e;try{e=s(340)("./"+this.version.folder+"/developers/api/errors.json")}catch(t){e=s(341)("./"+this.version.folder+"/developers/api/errors.json")}for(var t in e){var a=e[t];for(var i in a.description||(a.description=""),a.message||console.log("No message specified for error: "+t),a.http||console.log("No HTTP status code specified for error: "+t),a.tags&&Array.isArray(a.tags)&&0!==a.tags.length||console.warn("No tags specified for error: "+t),a.tags){var r=a.tags[i];void 0===this.errors[r]&&(this.errors[r]={}),this.errors[r][t]=a}}this.tags=Object.keys(this.errors),this.tags.sort()}},i=s(4),r=Object(i.a)(a,(function(){var e=this,t=e._self._c;return t("div",{staticClass:"error-codes"},[t("p",[e._v("The whole table of error codes is available as "),t("a",{attrs:{href:"/documentation/"+e.version.folder+"/developers/api/errors.json",target:"_blank"}},[e._v("JSON file")]),e._v(", which can be used by implementors to automatically generate error responses.")]),e._v(" "),e._l(e.tags,(function(s){return t("div",[t("a",{attrs:{name:e._f("slugify")(s)}}),e._v(" "),t("h2",[e._v(e._s(s))]),e._v(" "),t("table",[e._m(0,!0),e._v(" "),e._l(e.errors[s],(function(s,a){return t("tr",[t("td",[e._v(e._s(a))]),e._v(" "),t("td",[e._v(e._s(s.description))]),e._v(" "),t("td",[e._v(e._s(s.message))]),e._v(" "),t("td",[e._v(e._s(s.http))])])}))],2)])}))],2)}),[function(){var e=this._self._c;return e("tr",[e("th",{attrs:{width:"20%"}},[this._v("openEO Error Code")]),this._v(" "),e("th",{attrs:{width:"40%"}},[this._v("Description")]),this._v(" "),e("th",{attrs:{width:"35%"}},[this._v("Example Message")]),this._v(" "),e("th",{attrs:{width:"5%"}},[this._v("HTTP Status Code")])])}],!1,null,null,null);t.default=r.exports}}]); \ No newline at end of file diff --git a/assets/js/26.4b52ff84.js b/assets/js/26.774c0d65.js similarity index 100% rename from assets/js/26.4b52ff84.js rename to assets/js/26.774c0d65.js diff --git a/assets/js/27.6947eeb9.js b/assets/js/27.c6745455.js similarity index 97% rename from assets/js/27.6947eeb9.js rename to assets/js/27.c6745455.js index d314312a4..7c5376c04 100644 --- a/assets/js/27.6947eeb9.js +++ b/assets/js/27.c6745455.js @@ -1 +1 @@ -(window.webpackJsonp=window.webpackJsonp||[]).push([[27],{232:function(t,e,s){},343:function(t,e,s){"use strict";s(232)},481:function(t,e,s){"use strict";s.r(e);var a={name:"Channels",props:{contact:{type:Boolean,default:!0},code:{type:Boolean,default:!0},chat:{type:Boolean,default:!0},email:{type:Boolean,default:!0},chat:{type:Boolean,default:!0},youtube:{type:Boolean,default:!0},x:{type:Boolean,default:!0},linkedin:{type:Boolean,default:!0},github:{type:Boolean,default:!0},cran:{type:Boolean,default:!0},pypi:{type:Boolean,default:!0},conda:{type:Boolean,default:!0},npm:{type:Boolean,default:!0},julia:{type:Boolean,default:!0},qgis:{type:Boolean,default:!0}}},n=(s(343),s(4)),i=Object(n.a)(a,(function(){var t=this,e=t._self._c;return e("div",{staticClass:"channels"},[t.contact?e("ul",{staticClass:"contact"},[e("li",[t.email?e("a",{staticClass:"mail",attrs:{href:"mailto:openeo.psc@uni-muenster.de",target:"_blank"}},[e("img",{attrs:{src:"https://cdn.jsdelivr.net/npm/simple-icons@10.1.0/icons/maildotru.svg",alt:"Email the PSC",title:"Email the PSC"}}),t._v(" Email")]):t._e()]),t._v(" "),e("li",[t.chat?e("a",{staticClass:"chat",attrs:{href:"https://gitter.im/Open-EO/community",target:"_blank"}},[e("img",{attrs:{src:"https://cdn.jsdelivr.net/npm/simple-icons@10.1.0/icons/gitter.svg",alt:"Public chat on Gitter",title:"Public chat on Gitter"}}),t._v(" Chat")]):t._e()]),t._v(" "),e("li",[t.github&&!t.code?e("a",{staticClass:"github",attrs:{href:"https://github.com/Open-EO",target:"_blank"}},[e("img",{attrs:{src:"https://cdn.jsdelivr.net/npm/simple-icons@10.1.0/icons/github.svg",alt:"GitHub: Open-EO",title:"GitHub: Open-EO"}}),t._v(" GitHub")]):t._e()]),t._v(" "),e("li",[t.linkedin?e("a",{staticClass:"linkedin",attrs:{href:"https://www.linkedin.com/company/openeospec/",target:"_blank"}},[e("img",{attrs:{src:"https://cdn.jsdelivr.net/npm/simple-icons@10.1.0/icons/linkedin.svg",alt:"LinkedIn",title:"LinkedIn"}}),t._v(" LinkedIn")]):t._e()]),t._v(" "),e("li",[t.x?e("a",{staticClass:"x",attrs:{href:"https://twitter.com/Open_EO",target:"_blank"}},[e("img",{attrs:{src:"https://cdn.jsdelivr.net/npm/simple-icons@10.1.0/icons/x.svg",alt:"X / Twitter: Open_EO",title:"X / Twitter: Open_EO"}}),t._v(" X / Twitter")]):t._e()]),t._v(" "),e("li",[t.youtube?e("a",{staticClass:"youtube",attrs:{href:"https://www.youtube.com/channel/UCMJQil8j9sHBQkcSlSaEsvQ",target:"_blank"}},[e("img",{attrs:{src:"https://cdn.jsdelivr.net/npm/simple-icons@10.1.0/icons/youtube.svg",alt:"YouTube: openEO",title:"YouTube: openEO"}}),t._v(" YouTube")]):t._e()])]):t._e(),t._v(" "),t.code?e("ul",{staticClass:"code"},[e("li",[t.github?e("a",{staticClass:"github",attrs:{href:"https://github.com/Open-EO",target:"_blank"}},[e("img",{attrs:{src:"https://cdn.jsdelivr.net/npm/simple-icons@10.1.0/icons/github.svg",alt:"GitHub: Open-EO",title:"GitHub: Open-EO"}}),t._v(" GitHub")]):t._e()]),t._v(" "),e("li",[t.cran?e("a",{staticClass:"r",attrs:{href:"https://cran.r-project.org/package=openeo",target:"_blank"}},[e("img",{attrs:{src:"https://cdn.jsdelivr.net/npm/simple-icons@10.1.0/icons/r.svg",alt:"CRAN",title:"CRAN"}}),t._v(" CRAN / R")]):t._e()]),t._v(" "),e("li",[t.npm?e("a",{staticClass:"npm",attrs:{href:"https://www.npmjs.com/search?q=%40openeo%2F",target:"_blank"}},[e("img",{attrs:{src:"https://cdn.jsdelivr.net/npm/simple-icons@10.1.0/icons/npm.svg",alt:"npm: @openeo",title:"npm: @openeo"}}),t._v(" npm / JS")]):t._e()]),t._v(" "),e("li",[t.pypi?e("a",{staticClass:"pypi",attrs:{href:"https://pypi.org/project/openeo/",target:"_blank"}},[e("img",{attrs:{src:"https://cdn.jsdelivr.net/npm/simple-icons@10.1.0/icons/pypi.svg",alt:"PyPI",title:"PyPI"}}),t._v(" PyPI / Python")]):t._e()]),t._v(" "),e("li",[t.conda?e("a",{staticClass:"conda",attrs:{href:"https://anaconda.org/conda-forge/openeo",target:"_blank"}},[e("img",{attrs:{src:"https://cdn.jsdelivr.net/npm/simple-icons@10.1.0/icons/anaconda.svg",alt:"Conda Forge",title:"Conda Forge"}}),t._v(" Conda Forge / Python")]):t._e()]),t._v(" "),e("li",[t.julia?e("a",{staticClass:"julia",attrs:{href:"https://github.com/Open-EO/openeo-julia-client",target:"_blank"}},[e("img",{attrs:{src:"https://cdn.jsdelivr.net/npm/simple-icons@10.1.0/icons/julia.svg",alt:"Julia",title:"Julia"}}),t._v(" Julia")]):t._e()]),t._v(" "),e("li",[t.qgis?e("a",{staticClass:"qgis",attrs:{href:"https://plugins.qgis.org/plugins/openeo-qgis-plugin-master/",target:"_blank"}},[e("img",{attrs:{src:"https://cdn.jsdelivr.net/npm/simple-icons@10.1.0/icons/qgis.svg",alt:"QGIS",title:"QGIS"}}),t._v(" QGIS")]):t._e()])]):t._e()])}),[],!1,null,null,null);e.default=i.exports}}]); \ No newline at end of file +(window.webpackJsonp=window.webpackJsonp||[]).push([[27],{232:function(t,e,s){},339:function(t,e,s){"use strict";s(232)},480:function(t,e,s){"use strict";s.r(e);var a={name:"Channels",props:{contact:{type:Boolean,default:!0},code:{type:Boolean,default:!0},chat:{type:Boolean,default:!0},email:{type:Boolean,default:!0},chat:{type:Boolean,default:!0},youtube:{type:Boolean,default:!0},x:{type:Boolean,default:!0},linkedin:{type:Boolean,default:!0},github:{type:Boolean,default:!0},cran:{type:Boolean,default:!0},pypi:{type:Boolean,default:!0},conda:{type:Boolean,default:!0},npm:{type:Boolean,default:!0},julia:{type:Boolean,default:!0},qgis:{type:Boolean,default:!0}}},n=(s(339),s(4)),i=Object(n.a)(a,(function(){var t=this,e=t._self._c;return e("div",{staticClass:"channels"},[t.contact?e("ul",{staticClass:"contact"},[e("li",[t.email?e("a",{staticClass:"mail",attrs:{href:"mailto:openeo.psc@uni-muenster.de",target:"_blank"}},[e("img",{attrs:{src:"https://cdn.jsdelivr.net/npm/simple-icons@10.1.0/icons/maildotru.svg",alt:"Email the PSC",title:"Email the PSC"}}),t._v(" Email")]):t._e()]),t._v(" "),e("li",[t.chat?e("a",{staticClass:"chat",attrs:{href:"https://gitter.im/Open-EO/community",target:"_blank"}},[e("img",{attrs:{src:"https://cdn.jsdelivr.net/npm/simple-icons@10.1.0/icons/gitter.svg",alt:"Public chat on Gitter",title:"Public chat on Gitter"}}),t._v(" Chat")]):t._e()]),t._v(" "),e("li",[t.github&&!t.code?e("a",{staticClass:"github",attrs:{href:"https://github.com/Open-EO",target:"_blank"}},[e("img",{attrs:{src:"https://cdn.jsdelivr.net/npm/simple-icons@10.1.0/icons/github.svg",alt:"GitHub: Open-EO",title:"GitHub: Open-EO"}}),t._v(" GitHub")]):t._e()]),t._v(" "),e("li",[t.linkedin?e("a",{staticClass:"linkedin",attrs:{href:"https://www.linkedin.com/company/openeospec/",target:"_blank"}},[e("img",{attrs:{src:"https://cdn.jsdelivr.net/npm/simple-icons@10.1.0/icons/linkedin.svg",alt:"LinkedIn",title:"LinkedIn"}}),t._v(" LinkedIn")]):t._e()]),t._v(" "),e("li",[t.x?e("a",{staticClass:"x",attrs:{href:"https://twitter.com/Open_EO",target:"_blank"}},[e("img",{attrs:{src:"https://cdn.jsdelivr.net/npm/simple-icons@10.1.0/icons/x.svg",alt:"X / Twitter: Open_EO",title:"X / Twitter: Open_EO"}}),t._v(" X / Twitter")]):t._e()]),t._v(" "),e("li",[t.youtube?e("a",{staticClass:"youtube",attrs:{href:"https://www.youtube.com/channel/UCMJQil8j9sHBQkcSlSaEsvQ",target:"_blank"}},[e("img",{attrs:{src:"https://cdn.jsdelivr.net/npm/simple-icons@10.1.0/icons/youtube.svg",alt:"YouTube: openEO",title:"YouTube: openEO"}}),t._v(" YouTube")]):t._e()])]):t._e(),t._v(" "),t.code?e("ul",{staticClass:"code"},[e("li",[t.github?e("a",{staticClass:"github",attrs:{href:"https://github.com/Open-EO",target:"_blank"}},[e("img",{attrs:{src:"https://cdn.jsdelivr.net/npm/simple-icons@10.1.0/icons/github.svg",alt:"GitHub: Open-EO",title:"GitHub: Open-EO"}}),t._v(" GitHub")]):t._e()]),t._v(" "),e("li",[t.cran?e("a",{staticClass:"r",attrs:{href:"https://cran.r-project.org/package=openeo",target:"_blank"}},[e("img",{attrs:{src:"https://cdn.jsdelivr.net/npm/simple-icons@10.1.0/icons/r.svg",alt:"CRAN",title:"CRAN"}}),t._v(" CRAN / R")]):t._e()]),t._v(" "),e("li",[t.npm?e("a",{staticClass:"npm",attrs:{href:"https://www.npmjs.com/search?q=%40openeo%2F",target:"_blank"}},[e("img",{attrs:{src:"https://cdn.jsdelivr.net/npm/simple-icons@10.1.0/icons/npm.svg",alt:"npm: @openeo",title:"npm: @openeo"}}),t._v(" npm / JS")]):t._e()]),t._v(" "),e("li",[t.pypi?e("a",{staticClass:"pypi",attrs:{href:"https://pypi.org/project/openeo/",target:"_blank"}},[e("img",{attrs:{src:"https://cdn.jsdelivr.net/npm/simple-icons@10.1.0/icons/pypi.svg",alt:"PyPI",title:"PyPI"}}),t._v(" PyPI / Python")]):t._e()]),t._v(" "),e("li",[t.conda?e("a",{staticClass:"conda",attrs:{href:"https://anaconda.org/conda-forge/openeo",target:"_blank"}},[e("img",{attrs:{src:"https://cdn.jsdelivr.net/npm/simple-icons@10.1.0/icons/anaconda.svg",alt:"Conda Forge",title:"Conda Forge"}}),t._v(" Conda Forge / Python")]):t._e()]),t._v(" "),e("li",[t.julia?e("a",{staticClass:"julia",attrs:{href:"https://github.com/Open-EO/openeo-julia-client",target:"_blank"}},[e("img",{attrs:{src:"https://cdn.jsdelivr.net/npm/simple-icons@10.1.0/icons/julia.svg",alt:"Julia",title:"Julia"}}),t._v(" Julia")]):t._e()]),t._v(" "),e("li",[t.qgis?e("a",{staticClass:"qgis",attrs:{href:"https://plugins.qgis.org/plugins/openeo-qgis-plugin-master/",target:"_blank"}},[e("img",{attrs:{src:"https://cdn.jsdelivr.net/npm/simple-icons@10.1.0/icons/qgis.svg",alt:"QGIS",title:"QGIS"}}),t._v(" QGIS")]):t._e()])]):t._e()])}),[],!1,null,null,null);e.default=i.exports}}]); \ No newline at end of file diff --git a/assets/js/42.3d6af854.js b/assets/js/42.9f4c68e6.js similarity index 99% rename from assets/js/42.3d6af854.js rename to assets/js/42.9f4c68e6.js index 41d4236aa..54ec3d5b1 100644 --- a/assets/js/42.3d6af854.js +++ b/assets/js/42.9f4c68e6.js @@ -1 +1 @@ -(window.webpackJsonp=window.webpackJsonp||[]).push([[42],{302:function(e,a,t){e.exports=t.p+"assets/img/datacube-example.bab870f7.png"},507:function(e,a,t){"use strict";t.r(a);var s=t(4),o=Object(s.a)({},(function(){var e=this,a=e._self._c;return a("ContentSlotsDistributor",{attrs:{"slot-key":e.$parent.slotKey}},[a("h1",{attrs:{id:"glossary"}},[a("a",{staticClass:"header-anchor",attrs:{href:"#glossary"}},[e._v("#")]),e._v(" Glossary")]),e._v(" "),a("p",[e._v("This glossary introduces the major technical terms used in the openEO project.")]),e._v(" "),a("h2",{attrs:{id:"general-terms"}},[a("a",{staticClass:"header-anchor",attrs:{href:"#general-terms"}},[e._v("#")]),e._v(" General terms")]),e._v(" "),a("ul",[a("li",[a("strong",[e._v("EO")]),e._v(": Earth observation")]),e._v(" "),a("li",[a("strong",[e._v("API")]),e._v(": application programming interface ("),a("a",{attrs:{href:"https://en.wikipedia.org/wiki/Application_programming_interface",target:"_blank",rel:"noopener noreferrer"}},[e._v("wikipedia"),a("OutboundLink")],1),e._v("); a communication protocol between client and back-end")]),e._v(" "),a("li",[a("strong",[e._v("client")]),e._v(": software tool or environment that end-users directly interact with, e.g. R (RStudio), Python (Jupyter notebook), and JavaScript (web browser); R and Python are two major data science platforms; JavaScript is a major language for web development")]),e._v(" "),a("li",[a("strong",[e._v("(cloud) back-end")]),e._v(": server; computer infrastructure (one or more physical computers or virtual machines) used for storing EO data and processing it")]),e._v(" "),a("li",[a("strong",[e._v("big Earth observation cloud back-end")]),e._v(": server infrastructure where industry and researchers analyse large amounts of EO data")])]),e._v(" "),a("h2",{attrs:{id:"processes-and-process-graphs"}},[a("a",{staticClass:"header-anchor",attrs:{href:"#processes-and-process-graphs"}},[e._v("#")]),e._v(" Processes and process graphs")]),e._v(" "),a("p",[e._v("The terms "),a("em",[e._v("process")]),e._v(" and "),a("em",[e._v("process graph")]),e._v(" have specific meanings in the openEO API specification.")]),e._v(" "),a("p",[e._v("A "),a("strong",[e._v("process")]),e._v(" is an operation provided by the back end that performs a specific task on a set of parameters and returns a result. An example is computing a statistical operation, such as mean or median, on selected EO data. A process is similar to a function or method in programming languages.")]),e._v(" "),a("p",[e._v("A "),a("strong",[e._v("process graph")]),e._v(" chains specific process calls together. Similarly to scripts in the context of programming, process graphs organize and automate the execution of one or more processes that could alternatively be executed individually. In a process graph, processes need to be specific, i.e. concrete values for input parameters need to be specified. These arguments can again be process graphs, scalar values, arrays or objects.")]),e._v(" "),a("h2",{attrs:{id:"eo-data-collections"}},[a("a",{staticClass:"header-anchor",attrs:{href:"#eo-data-collections"}},[e._v("#")]),e._v(" EO data (Collections)")]),e._v(" "),a("p",[e._v("In our domain, different terms are used to describe EO data(sets). Within openEO, a "),a("strong",[e._v("granule")]),e._v(" (sometimes also called "),a("em",[e._v("item")]),e._v(" or "),a("em",[e._v("asset")]),e._v(" in the specification) typically refers to a limited area and a single overpass leading to a very short observation period (seconds) or a temporal aggregation of such data (e.g. for 16-day MODIS composites). A "),a("strong",[e._v("collection")]),e._v(" is a sequence of granules sharing the same product specification. It typically corresponds to the series of products derived from data acquired by a sensor on board a satellite and having the same mode of operation.")]),e._v(" "),a("p",[e._v("The "),a("a",{attrs:{href:"http://ceos.org/ourwork/workinggroups/wgiss/access/opensearch/",target:"_blank",rel:"noopener noreferrer"}},[e._v("CEOS OpenSearch Best Practice Document v1.2"),a("OutboundLink")],1),e._v(" lists the following synonyms used by other organizations:")]),e._v(" "),a("ul",[a("li",[a("strong",[e._v("granule")]),e._v(": dataset (ESA, ISO 19115), granule (NASA), product (ESA, CNES), scene (JAXA)")]),e._v(" "),a("li",[a("strong",[e._v("collection")]),e._v(": dataset series (ESA, ISO 19115), collection (CNES, NASA), dataset (JAXA), product (JAXA)")])]),e._v(" "),a("p",[e._v("In openEO, a back-end offers a set of collections to be processed. All collections can be requested using a client and are described using the "),a("a",{attrs:{href:"https://github.com/radiantearth/stac-spec",target:"_blank",rel:"noopener noreferrer"}},[e._v("STAC (SpatioTemporal Asset Catalog) metadata specification"),a("OutboundLink")],1),e._v(" as STAC collections. A user can load (a subset of) a collection using a special process, which returns a (spatial) data cube. All further processing is then applied to the data cube on the back-end.")]),e._v(" "),a("h2",{attrs:{id:"spatial-data-cubes"}},[a("a",{staticClass:"header-anchor",attrs:{href:"#spatial-data-cubes"}},[e._v("#")]),e._v(" Spatial data cubes")]),e._v(" "),a("p",[e._v("A "),a("em",[e._v("spatiotemporal")]),e._v(" data cube is a multidimensional array with one or more spatial or temporal dimensions.\nIn the EO domain, it is common to be implicit about the temporal dimension and just refer to them as "),a("em",[e._v("spatial")]),e._v(" data cubes in short.\nSpecial cases are raster and vector data cubes.")]),e._v(" "),a("p",[e._v("The figure below shows the data of\na four-dimensional (8 x 8 x 2 x 2) raster data cube, with dimension names\nand values:")]),e._v(" "),a("table",[a("thead",[a("tr",[a("th",[e._v("#")]),e._v(" "),a("th",[e._v("dimension name")]),e._v(" "),a("th",[e._v("dimension values")])])]),e._v(" "),a("tbody",[a("tr",[a("td",[e._v("1")]),e._v(" "),a("td",[e._v("x")]),e._v(" "),a("td",[e._v("288790.5, 288819, 288847.5, 288876, 288904.5, 288933, 288961.5, 288990")])]),e._v(" "),a("tr",[a("td",[e._v("2")]),e._v(" "),a("td",[e._v("y")]),e._v(" "),a("td",[e._v("9120747, 9120718, 9120690, 9120661, 9120633, 9120604, 9120576, 9120547")])]),e._v(" "),a("tr",[a("td",[e._v("3")]),e._v(" "),a("td",[e._v("band")]),e._v(" "),a("td",[a("code",[e._v("red")]),e._v(", "),a("code",[e._v("green")])])]),e._v(" "),a("tr",[a("td",[e._v("4")]),e._v(" "),a("td",[e._v("time")]),e._v(" "),a("td",[a("code",[e._v("2018-02-10")]),e._v(", "),a("code",[e._v("2018-02-17")])])])])]),e._v(" "),a("p",[e._v("dimensions x and time are aligned along the x-axis; y and band are aligned along the y-axis.")]),e._v(" "),a("p",[a("img",{attrs:{src:t(302),alt:"Data cube example"}})]),e._v(" "),a("p",[e._v("Data cubes as defined here have a "),a("em",[e._v("single value")]),e._v(" (scalar) for each\nunique combination of dimension values. The value pointed to by\narrows corresponds to the combination of x=288847.5 (red arrow),\ny=9120661 (yellow arrow), band=red (blue arrow), time=2018-02-17 (green arrow),\nand its value is 84 (brown arrow).")]),e._v(" "),a("p",[e._v("If the data concerns grayscale imagery, we could call this "),a("em",[e._v("single")]),e._v("\nvalue a "),a("em",[e._v("pixel value")]),e._v(". One should keep in mind that it is "),a("em",[e._v("never")]),e._v("\na tuple of, say, "),a("code",[e._v("{red, green, blue}")]),e._v(' values. "Cell value of a\nsingle raster layer" would be a better analogy; '),a("em",[e._v("data cube cell\nvalue")]),e._v(" may be a good compromise.")]),e._v(" "),a("p",[e._v("A data cube stores some additional properties per dimension such as:")]),e._v(" "),a("ul",[a("li",[e._v("name")]),e._v(" "),a("li",[e._v("axis / number")]),e._v(" "),a("li",[e._v("type")]),e._v(" "),a("li",[e._v("extents "),a("em",[e._v("or")]),e._v(" nominal dimension values")]),e._v(" "),a("li",[e._v("reference systems / projections")]),e._v(" "),a("li",[e._v("resolutions")])]),e._v(" "),a("p",[e._v("Having these properties available allows to easily resample from one data cube to another for example.")]),e._v(" "),a("h3",{attrs:{id:"apply-processes-that-do-not-change-dimensions"}},[a("a",{staticClass:"header-anchor",attrs:{href:"#apply-processes-that-do-not-change-dimensions"}},[e._v("#")]),e._v(" "),a("code",[e._v("apply")]),e._v(": processes that do not change dimensions")]),e._v(" "),a("p",[e._v("Math process that does not reduce or change anything to the array\ndimensions. The process "),a("code",[e._v("apply")]),e._v(" can be used to apply unary functions\nsuch as "),a("code",[e._v("abs")]),e._v(" or "),a("code",[e._v("sqrt")]),e._v(" to all values in a data cube.")]),e._v(" "),a("p",[e._v("The process "),a("code",[e._v("apply_dimension")]),e._v(" applies (maps) an n-ary function to a particular\ndimension. An example along the time dimension is to apply a moving\naverage filter to implement temporal smoothing.\nAn example of "),a("code",[e._v("apply_dimension")]),e._v(" to the spatial dimensions\nis to do a historgram stretch for every spatial (grayscale) image\nof an image time series.")]),e._v(" "),a("h3",{attrs:{id:"filter-subsetting-dimensions-by-dimension-value-selection"}},[a("a",{staticClass:"header-anchor",attrs:{href:"#filter-subsetting-dimensions-by-dimension-value-selection"}},[e._v("#")]),e._v(" "),a("code",[e._v("filter")]),e._v(": subsetting dimensions by dimension value selection")]),e._v(" "),a("p",[e._v("The "),a("code",[e._v("filter")]),e._v(" process makes a cube smaller by selecting specific\nvalue ranges for a particular dimension.")]),e._v(" "),a("p",[e._v("Examples:")]),e._v(" "),a("ul",[a("li",[e._v("a band filter that selects the "),a("code",[e._v("red")]),e._v(" band")]),e._v(" "),a("li",[e._v('a bounding box filter "crops" the collection to a spatial extent')])]),e._v(" "),a("h3",{attrs:{id:"reduce-removing-dimensions-entirely-by-computation"}},[a("a",{staticClass:"header-anchor",attrs:{href:"#reduce-removing-dimensions-entirely-by-computation"}},[e._v("#")]),e._v(" "),a("code",[e._v("reduce")]),e._v(": removing dimensions entirely by computation")]),e._v(" "),a("p",[e._v("The "),a("code",[e._v("reduce")]),e._v(' process removes a dimension by "rolling up" or summarizing\nthe values along that dimension to a single value.\nFor example: eliminate the time dimension by taking the '),a("code",[e._v("mean")]),e._v(" along that dimension.\nAnother example is taking the "),a("code",[e._v("sum")]),e._v(" or "),a("code",[e._v("max")]),e._v(" along the band dimension.")]),e._v(" "),a("h3",{attrs:{id:"aggregate-reducing-resolution"}},[a("a",{staticClass:"header-anchor",attrs:{href:"#aggregate-reducing-resolution"}},[e._v("#")]),e._v(" "),a("code",[e._v("aggregate")]),e._v(": reducing resolution")]),e._v(" "),a("p",[e._v("Aggregation computes new values from sets of values that are "),a("em",[e._v("uniquely")]),e._v(" assigned to groups. It involves a grouping predicate (e.g. monthly, 100 m x 100 m grid cells, or a set of non-overlapping spatial polygons), and an reducer (e.g., "),a("code",[e._v("mean")]),e._v(") that computes one or more new values from the original ones.")]),e._v(" "),a("p",[e._v("In effect, "),a("code",[e._v("aggregate")]),e._v(" combines the following three steps:")]),e._v(" "),a("ul",[a("li",[a("em",[e._v("split")]),e._v(" the data cube in groups, based on dimension constraints (time intervals, band groups, spatial polygons)")]),e._v(" "),a("li",[a("em",[e._v("apply")]),e._v(" a reducer to each group (similar to the "),a("code",[e._v("reduce")]),e._v(" process, but reducing a group rather than an entire dimension)")]),e._v(" "),a("li",[a("em",[e._v("combine")]),e._v(" the result to a new data cube, with some dimensions having reduced resolution (or e.g. raster to vector converted)")])]),e._v(" "),a("p",[e._v("Examples:")]),e._v(" "),a("ul",[a("li",[e._v("a weekly time series may be aggregated to monthly values by computing the "),a("code",[e._v("mean")]),e._v(" for all values in a month (grouping predicate: months)")]),e._v(" "),a("li",[a("em",[e._v("spatial")]),e._v(" aggregation involves computing e.g. "),a("em",[e._v("mean")]),e._v(" pixel values on a 100 x 100 m grid, from 10 m x 10 m pixels, where each original pixel is assigned uniquely to a larger pixel (grouping predicate: 100 m x 100 m grid cells)")])]),e._v(" "),a("h3",{attrs:{id:"resample-changing-data-cube-geometry"}},[a("a",{staticClass:"header-anchor",attrs:{href:"#resample-changing-data-cube-geometry"}},[e._v("#")]),e._v(" "),a("code",[e._v("resample")]),e._v(": changing data cube geometry")]),e._v(" "),a("p",[e._v("Resampling considers the case where we have data at one resolution and coordinate reference system, and need values at another. In case we have values at a 100 m x 100 m grid and need values at a 10 m x 10 m grid, the original values will be reused many times, and may be simply assigned to the nearest high resolution grid cells (nearest neighbor method), or may be interpolated using various methods (e.g. by bilinear interpolation). This is often called "),a("em",[e._v("upsampling")]),e._v(" or "),a("em",[e._v("upscaling")]),e._v(".")]),e._v(" "),a("p",[e._v("Resampling from finer to coarser grid is a special case of aggregation often called "),a("em",[e._v("downsampling")]),e._v(" or "),a("em",[e._v("downscaling")]),e._v(".")]),e._v(" "),a("p",[e._v("When the target grid or time series has a lower resolution (larger grid cells) or lower frequency (longer time intervals) than the source grid, aggregation might be used for resampling. For example, if the resolutions are similar, (e.g. the source collection provides 10 day intervals and the target needs values for 16 day intervals), then some form of interpolation may be more appropriate than aggregation as defined here.")]),e._v(" "),a("h2",{attrs:{id:"user-defined-function-udf"}},[a("a",{staticClass:"header-anchor",attrs:{href:"#user-defined-function-udf"}},[e._v("#")]),e._v(" User-defined function (UDF)")]),e._v(" "),a("p",[e._v("The abbreviation "),a("strong",[e._v("UDF")]),e._v(" stands for "),a("strong",[e._v("user-defined function")]),e._v(". With this concept, users are able to upload custom code and have it executed e.g. for every pixel of a scene, or applied to a particular dimension or set of dimensions, allowing custom server-side calculations. See the section on "),a("RouterLink",{attrs:{to:"/documentation/0.4/udfs.html"}},[e._v("UDFs")]),e._v(" for more information.")],1),e._v(" "),a("h2",{attrs:{id:"data-processing-modes"}},[a("a",{staticClass:"header-anchor",attrs:{href:"#data-processing-modes"}},[e._v("#")]),e._v(" Data Processing modes")]),e._v(" "),a("p",[e._v("Process graphs can be processed in three different ways:")]),e._v(" "),a("ol",[a("li",[e._v("Results can be pre-computed by creating a "),a("em",[a("strong",[e._v("batch job")])]),e._v(" using "),a("code",[e._v("POST /jobs")]),e._v(". They are submitted to the back-end's processing system, but will remain inactive until "),a("code",[e._v("POST /jobs/{job_id}/results")]),e._v(" has been called. They will run only once and store results after execution. Results can be downloaded. Batch jobs are typically time consuming and user interaction is not possible. This is the only mode that allows to get an estimate about time, volume and costs beforehand.")]),e._v(" "),a("li",[e._v("A more dynamic way of processing and accessing data is to create a "),a("strong",[e._v("secondary web service")]),e._v(". They allow web-based access using different protocols such as "),a("a",{attrs:{href:"http://www.opengeospatial.org/standards/wms",target:"_blank",rel:"noopener noreferrer"}},[e._v("OGC WMS"),a("OutboundLink")],1),e._v(" (Open Geospatial Consortium Web Map Service), "),a("a",{attrs:{href:"http://www.opengeospatial.org/standards/wcs",target:"_blank",rel:"noopener noreferrer"}},[e._v("OGC WCS"),a("OutboundLink")],1),e._v(" (Web Coverage Service) or "),a("a",{attrs:{href:"https://wiki.openstreetmap.org/wiki/Slippy_map_tilenames",target:"_blank",rel:"noopener noreferrer"}},[e._v("XYZ tiles"),a("OutboundLink")],1),e._v(". These protocols usually allow users to change the viewing extent or level of detail (zoom level). Therefore, computations often run "),a("em",[e._v("on demand")]),e._v(" so that the requested data is calculated during the request. Back-ends should make sure to cache processed data to avoid additional/high costs and reduce waiting times for the user.")]),e._v(" "),a("li",[e._v("Process graphs can also be executed "),a("strong",[e._v("on-demand")]),e._v(" (i.e. synchronously) by sending the process graph to "),a("code",[e._v("POST /result")]),e._v(". Results are delivered with the request itself and no job is created. Only lightweight computations, for example small previews, should be executed using this approach as timeouts are to be expected for "),a("a",{attrs:{href:"https://www.pubnub.com/blog/2014-12-01-http-long-polling/",target:"_blank",rel:"noopener noreferrer"}},[e._v("long-polling HTTP requests"),a("OutboundLink")],1),e._v(".")])])])}),[],!1,null,null,null);a.default=o.exports}}]); \ No newline at end of file +(window.webpackJsonp=window.webpackJsonp||[]).push([[42],{302:function(e,a,t){e.exports=t.p+"assets/img/datacube-example.bab870f7.png"},508:function(e,a,t){"use strict";t.r(a);var s=t(4),o=Object(s.a)({},(function(){var e=this,a=e._self._c;return a("ContentSlotsDistributor",{attrs:{"slot-key":e.$parent.slotKey}},[a("h1",{attrs:{id:"glossary"}},[a("a",{staticClass:"header-anchor",attrs:{href:"#glossary"}},[e._v("#")]),e._v(" Glossary")]),e._v(" "),a("p",[e._v("This glossary introduces the major technical terms used in the openEO project.")]),e._v(" "),a("h2",{attrs:{id:"general-terms"}},[a("a",{staticClass:"header-anchor",attrs:{href:"#general-terms"}},[e._v("#")]),e._v(" General terms")]),e._v(" "),a("ul",[a("li",[a("strong",[e._v("EO")]),e._v(": Earth observation")]),e._v(" "),a("li",[a("strong",[e._v("API")]),e._v(": application programming interface ("),a("a",{attrs:{href:"https://en.wikipedia.org/wiki/Application_programming_interface",target:"_blank",rel:"noopener noreferrer"}},[e._v("wikipedia"),a("OutboundLink")],1),e._v("); a communication protocol between client and back-end")]),e._v(" "),a("li",[a("strong",[e._v("client")]),e._v(": software tool or environment that end-users directly interact with, e.g. R (RStudio), Python (Jupyter notebook), and JavaScript (web browser); R and Python are two major data science platforms; JavaScript is a major language for web development")]),e._v(" "),a("li",[a("strong",[e._v("(cloud) back-end")]),e._v(": server; computer infrastructure (one or more physical computers or virtual machines) used for storing EO data and processing it")]),e._v(" "),a("li",[a("strong",[e._v("big Earth observation cloud back-end")]),e._v(": server infrastructure where industry and researchers analyse large amounts of EO data")])]),e._v(" "),a("h2",{attrs:{id:"processes-and-process-graphs"}},[a("a",{staticClass:"header-anchor",attrs:{href:"#processes-and-process-graphs"}},[e._v("#")]),e._v(" Processes and process graphs")]),e._v(" "),a("p",[e._v("The terms "),a("em",[e._v("process")]),e._v(" and "),a("em",[e._v("process graph")]),e._v(" have specific meanings in the openEO API specification.")]),e._v(" "),a("p",[e._v("A "),a("strong",[e._v("process")]),e._v(" is an operation provided by the back end that performs a specific task on a set of parameters and returns a result. An example is computing a statistical operation, such as mean or median, on selected EO data. A process is similar to a function or method in programming languages.")]),e._v(" "),a("p",[e._v("A "),a("strong",[e._v("process graph")]),e._v(" chains specific process calls together. Similarly to scripts in the context of programming, process graphs organize and automate the execution of one or more processes that could alternatively be executed individually. In a process graph, processes need to be specific, i.e. concrete values for input parameters need to be specified. These arguments can again be process graphs, scalar values, arrays or objects.")]),e._v(" "),a("h2",{attrs:{id:"eo-data-collections"}},[a("a",{staticClass:"header-anchor",attrs:{href:"#eo-data-collections"}},[e._v("#")]),e._v(" EO data (Collections)")]),e._v(" "),a("p",[e._v("In our domain, different terms are used to describe EO data(sets). Within openEO, a "),a("strong",[e._v("granule")]),e._v(" (sometimes also called "),a("em",[e._v("item")]),e._v(" or "),a("em",[e._v("asset")]),e._v(" in the specification) typically refers to a limited area and a single overpass leading to a very short observation period (seconds) or a temporal aggregation of such data (e.g. for 16-day MODIS composites). A "),a("strong",[e._v("collection")]),e._v(" is a sequence of granules sharing the same product specification. It typically corresponds to the series of products derived from data acquired by a sensor on board a satellite and having the same mode of operation.")]),e._v(" "),a("p",[e._v("The "),a("a",{attrs:{href:"http://ceos.org/ourwork/workinggroups/wgiss/access/opensearch/",target:"_blank",rel:"noopener noreferrer"}},[e._v("CEOS OpenSearch Best Practice Document v1.2"),a("OutboundLink")],1),e._v(" lists the following synonyms used by other organizations:")]),e._v(" "),a("ul",[a("li",[a("strong",[e._v("granule")]),e._v(": dataset (ESA, ISO 19115), granule (NASA), product (ESA, CNES), scene (JAXA)")]),e._v(" "),a("li",[a("strong",[e._v("collection")]),e._v(": dataset series (ESA, ISO 19115), collection (CNES, NASA), dataset (JAXA), product (JAXA)")])]),e._v(" "),a("p",[e._v("In openEO, a back-end offers a set of collections to be processed. All collections can be requested using a client and are described using the "),a("a",{attrs:{href:"https://github.com/radiantearth/stac-spec",target:"_blank",rel:"noopener noreferrer"}},[e._v("STAC (SpatioTemporal Asset Catalog) metadata specification"),a("OutboundLink")],1),e._v(" as STAC collections. A user can load (a subset of) a collection using a special process, which returns a (spatial) data cube. All further processing is then applied to the data cube on the back-end.")]),e._v(" "),a("h2",{attrs:{id:"spatial-data-cubes"}},[a("a",{staticClass:"header-anchor",attrs:{href:"#spatial-data-cubes"}},[e._v("#")]),e._v(" Spatial data cubes")]),e._v(" "),a("p",[e._v("A "),a("em",[e._v("spatiotemporal")]),e._v(" data cube is a multidimensional array with one or more spatial or temporal dimensions.\nIn the EO domain, it is common to be implicit about the temporal dimension and just refer to them as "),a("em",[e._v("spatial")]),e._v(" data cubes in short.\nSpecial cases are raster and vector data cubes.")]),e._v(" "),a("p",[e._v("The figure below shows the data of\na four-dimensional (8 x 8 x 2 x 2) raster data cube, with dimension names\nand values:")]),e._v(" "),a("table",[a("thead",[a("tr",[a("th",[e._v("#")]),e._v(" "),a("th",[e._v("dimension name")]),e._v(" "),a("th",[e._v("dimension values")])])]),e._v(" "),a("tbody",[a("tr",[a("td",[e._v("1")]),e._v(" "),a("td",[e._v("x")]),e._v(" "),a("td",[e._v("288790.5, 288819, 288847.5, 288876, 288904.5, 288933, 288961.5, 288990")])]),e._v(" "),a("tr",[a("td",[e._v("2")]),e._v(" "),a("td",[e._v("y")]),e._v(" "),a("td",[e._v("9120747, 9120718, 9120690, 9120661, 9120633, 9120604, 9120576, 9120547")])]),e._v(" "),a("tr",[a("td",[e._v("3")]),e._v(" "),a("td",[e._v("band")]),e._v(" "),a("td",[a("code",[e._v("red")]),e._v(", "),a("code",[e._v("green")])])]),e._v(" "),a("tr",[a("td",[e._v("4")]),e._v(" "),a("td",[e._v("time")]),e._v(" "),a("td",[a("code",[e._v("2018-02-10")]),e._v(", "),a("code",[e._v("2018-02-17")])])])])]),e._v(" "),a("p",[e._v("dimensions x and time are aligned along the x-axis; y and band are aligned along the y-axis.")]),e._v(" "),a("p",[a("img",{attrs:{src:t(302),alt:"Data cube example"}})]),e._v(" "),a("p",[e._v("Data cubes as defined here have a "),a("em",[e._v("single value")]),e._v(" (scalar) for each\nunique combination of dimension values. The value pointed to by\narrows corresponds to the combination of x=288847.5 (red arrow),\ny=9120661 (yellow arrow), band=red (blue arrow), time=2018-02-17 (green arrow),\nand its value is 84 (brown arrow).")]),e._v(" "),a("p",[e._v("If the data concerns grayscale imagery, we could call this "),a("em",[e._v("single")]),e._v("\nvalue a "),a("em",[e._v("pixel value")]),e._v(". One should keep in mind that it is "),a("em",[e._v("never")]),e._v("\na tuple of, say, "),a("code",[e._v("{red, green, blue}")]),e._v(' values. "Cell value of a\nsingle raster layer" would be a better analogy; '),a("em",[e._v("data cube cell\nvalue")]),e._v(" may be a good compromise.")]),e._v(" "),a("p",[e._v("A data cube stores some additional properties per dimension such as:")]),e._v(" "),a("ul",[a("li",[e._v("name")]),e._v(" "),a("li",[e._v("axis / number")]),e._v(" "),a("li",[e._v("type")]),e._v(" "),a("li",[e._v("extents "),a("em",[e._v("or")]),e._v(" nominal dimension values")]),e._v(" "),a("li",[e._v("reference systems / projections")]),e._v(" "),a("li",[e._v("resolutions")])]),e._v(" "),a("p",[e._v("Having these properties available allows to easily resample from one data cube to another for example.")]),e._v(" "),a("h3",{attrs:{id:"apply-processes-that-do-not-change-dimensions"}},[a("a",{staticClass:"header-anchor",attrs:{href:"#apply-processes-that-do-not-change-dimensions"}},[e._v("#")]),e._v(" "),a("code",[e._v("apply")]),e._v(": processes that do not change dimensions")]),e._v(" "),a("p",[e._v("Math process that does not reduce or change anything to the array\ndimensions. The process "),a("code",[e._v("apply")]),e._v(" can be used to apply unary functions\nsuch as "),a("code",[e._v("abs")]),e._v(" or "),a("code",[e._v("sqrt")]),e._v(" to all values in a data cube.")]),e._v(" "),a("p",[e._v("The process "),a("code",[e._v("apply_dimension")]),e._v(" applies (maps) an n-ary function to a particular\ndimension. An example along the time dimension is to apply a moving\naverage filter to implement temporal smoothing.\nAn example of "),a("code",[e._v("apply_dimension")]),e._v(" to the spatial dimensions\nis to do a historgram stretch for every spatial (grayscale) image\nof an image time series.")]),e._v(" "),a("h3",{attrs:{id:"filter-subsetting-dimensions-by-dimension-value-selection"}},[a("a",{staticClass:"header-anchor",attrs:{href:"#filter-subsetting-dimensions-by-dimension-value-selection"}},[e._v("#")]),e._v(" "),a("code",[e._v("filter")]),e._v(": subsetting dimensions by dimension value selection")]),e._v(" "),a("p",[e._v("The "),a("code",[e._v("filter")]),e._v(" process makes a cube smaller by selecting specific\nvalue ranges for a particular dimension.")]),e._v(" "),a("p",[e._v("Examples:")]),e._v(" "),a("ul",[a("li",[e._v("a band filter that selects the "),a("code",[e._v("red")]),e._v(" band")]),e._v(" "),a("li",[e._v('a bounding box filter "crops" the collection to a spatial extent')])]),e._v(" "),a("h3",{attrs:{id:"reduce-removing-dimensions-entirely-by-computation"}},[a("a",{staticClass:"header-anchor",attrs:{href:"#reduce-removing-dimensions-entirely-by-computation"}},[e._v("#")]),e._v(" "),a("code",[e._v("reduce")]),e._v(": removing dimensions entirely by computation")]),e._v(" "),a("p",[e._v("The "),a("code",[e._v("reduce")]),e._v(' process removes a dimension by "rolling up" or summarizing\nthe values along that dimension to a single value.\nFor example: eliminate the time dimension by taking the '),a("code",[e._v("mean")]),e._v(" along that dimension.\nAnother example is taking the "),a("code",[e._v("sum")]),e._v(" or "),a("code",[e._v("max")]),e._v(" along the band dimension.")]),e._v(" "),a("h3",{attrs:{id:"aggregate-reducing-resolution"}},[a("a",{staticClass:"header-anchor",attrs:{href:"#aggregate-reducing-resolution"}},[e._v("#")]),e._v(" "),a("code",[e._v("aggregate")]),e._v(": reducing resolution")]),e._v(" "),a("p",[e._v("Aggregation computes new values from sets of values that are "),a("em",[e._v("uniquely")]),e._v(" assigned to groups. It involves a grouping predicate (e.g. monthly, 100 m x 100 m grid cells, or a set of non-overlapping spatial polygons), and an reducer (e.g., "),a("code",[e._v("mean")]),e._v(") that computes one or more new values from the original ones.")]),e._v(" "),a("p",[e._v("In effect, "),a("code",[e._v("aggregate")]),e._v(" combines the following three steps:")]),e._v(" "),a("ul",[a("li",[a("em",[e._v("split")]),e._v(" the data cube in groups, based on dimension constraints (time intervals, band groups, spatial polygons)")]),e._v(" "),a("li",[a("em",[e._v("apply")]),e._v(" a reducer to each group (similar to the "),a("code",[e._v("reduce")]),e._v(" process, but reducing a group rather than an entire dimension)")]),e._v(" "),a("li",[a("em",[e._v("combine")]),e._v(" the result to a new data cube, with some dimensions having reduced resolution (or e.g. raster to vector converted)")])]),e._v(" "),a("p",[e._v("Examples:")]),e._v(" "),a("ul",[a("li",[e._v("a weekly time series may be aggregated to monthly values by computing the "),a("code",[e._v("mean")]),e._v(" for all values in a month (grouping predicate: months)")]),e._v(" "),a("li",[a("em",[e._v("spatial")]),e._v(" aggregation involves computing e.g. "),a("em",[e._v("mean")]),e._v(" pixel values on a 100 x 100 m grid, from 10 m x 10 m pixels, where each original pixel is assigned uniquely to a larger pixel (grouping predicate: 100 m x 100 m grid cells)")])]),e._v(" "),a("h3",{attrs:{id:"resample-changing-data-cube-geometry"}},[a("a",{staticClass:"header-anchor",attrs:{href:"#resample-changing-data-cube-geometry"}},[e._v("#")]),e._v(" "),a("code",[e._v("resample")]),e._v(": changing data cube geometry")]),e._v(" "),a("p",[e._v("Resampling considers the case where we have data at one resolution and coordinate reference system, and need values at another. In case we have values at a 100 m x 100 m grid and need values at a 10 m x 10 m grid, the original values will be reused many times, and may be simply assigned to the nearest high resolution grid cells (nearest neighbor method), or may be interpolated using various methods (e.g. by bilinear interpolation). This is often called "),a("em",[e._v("upsampling")]),e._v(" or "),a("em",[e._v("upscaling")]),e._v(".")]),e._v(" "),a("p",[e._v("Resampling from finer to coarser grid is a special case of aggregation often called "),a("em",[e._v("downsampling")]),e._v(" or "),a("em",[e._v("downscaling")]),e._v(".")]),e._v(" "),a("p",[e._v("When the target grid or time series has a lower resolution (larger grid cells) or lower frequency (longer time intervals) than the source grid, aggregation might be used for resampling. For example, if the resolutions are similar, (e.g. the source collection provides 10 day intervals and the target needs values for 16 day intervals), then some form of interpolation may be more appropriate than aggregation as defined here.")]),e._v(" "),a("h2",{attrs:{id:"user-defined-function-udf"}},[a("a",{staticClass:"header-anchor",attrs:{href:"#user-defined-function-udf"}},[e._v("#")]),e._v(" User-defined function (UDF)")]),e._v(" "),a("p",[e._v("The abbreviation "),a("strong",[e._v("UDF")]),e._v(" stands for "),a("strong",[e._v("user-defined function")]),e._v(". With this concept, users are able to upload custom code and have it executed e.g. for every pixel of a scene, or applied to a particular dimension or set of dimensions, allowing custom server-side calculations. See the section on "),a("RouterLink",{attrs:{to:"/documentation/0.4/udfs.html"}},[e._v("UDFs")]),e._v(" for more information.")],1),e._v(" "),a("h2",{attrs:{id:"data-processing-modes"}},[a("a",{staticClass:"header-anchor",attrs:{href:"#data-processing-modes"}},[e._v("#")]),e._v(" Data Processing modes")]),e._v(" "),a("p",[e._v("Process graphs can be processed in three different ways:")]),e._v(" "),a("ol",[a("li",[e._v("Results can be pre-computed by creating a "),a("em",[a("strong",[e._v("batch job")])]),e._v(" using "),a("code",[e._v("POST /jobs")]),e._v(". They are submitted to the back-end's processing system, but will remain inactive until "),a("code",[e._v("POST /jobs/{job_id}/results")]),e._v(" has been called. They will run only once and store results after execution. Results can be downloaded. Batch jobs are typically time consuming and user interaction is not possible. This is the only mode that allows to get an estimate about time, volume and costs beforehand.")]),e._v(" "),a("li",[e._v("A more dynamic way of processing and accessing data is to create a "),a("strong",[e._v("secondary web service")]),e._v(". They allow web-based access using different protocols such as "),a("a",{attrs:{href:"http://www.opengeospatial.org/standards/wms",target:"_blank",rel:"noopener noreferrer"}},[e._v("OGC WMS"),a("OutboundLink")],1),e._v(" (Open Geospatial Consortium Web Map Service), "),a("a",{attrs:{href:"http://www.opengeospatial.org/standards/wcs",target:"_blank",rel:"noopener noreferrer"}},[e._v("OGC WCS"),a("OutboundLink")],1),e._v(" (Web Coverage Service) or "),a("a",{attrs:{href:"https://wiki.openstreetmap.org/wiki/Slippy_map_tilenames",target:"_blank",rel:"noopener noreferrer"}},[e._v("XYZ tiles"),a("OutboundLink")],1),e._v(". These protocols usually allow users to change the viewing extent or level of detail (zoom level). Therefore, computations often run "),a("em",[e._v("on demand")]),e._v(" so that the requested data is calculated during the request. Back-ends should make sure to cache processed data to avoid additional/high costs and reduce waiting times for the user.")]),e._v(" "),a("li",[e._v("Process graphs can also be executed "),a("strong",[e._v("on-demand")]),e._v(" (i.e. synchronously) by sending the process graph to "),a("code",[e._v("POST /result")]),e._v(". Results are delivered with the request itself and no job is created. Only lightweight computations, for example small previews, should be executed using this approach as timeouts are to be expected for "),a("a",{attrs:{href:"https://www.pubnub.com/blog/2014-12-01-http-long-polling/",target:"_blank",rel:"noopener noreferrer"}},[e._v("long-polling HTTP requests"),a("OutboundLink")],1),e._v(".")])])])}),[],!1,null,null,null);a.default=o.exports}}]); \ No newline at end of file diff --git a/assets/js/43.4be98c2f.js b/assets/js/43.3e1dcc31.js similarity index 98% rename from assets/js/43.4be98c2f.js rename to assets/js/43.3e1dcc31.js index d66985d3c..430ca3e6d 100644 --- a/assets/js/43.4be98c2f.js +++ b/assets/js/43.3e1dcc31.js @@ -1 +1 @@ -(window.webpackJsonp=window.webpackJsonp||[]).push([[43],{322:function(e,t,a){e.exports=a.p+"assets/img/arch.e75ccb9a.png"},518:function(e,t,a){"use strict";a.r(t);var i=a(4),n=Object(i.a)({},(function(){var e=this,t=e._self._c;return t("ContentSlotsDistributor",{attrs:{"slot-key":e.$parent.slotKey}},[t("h1",{attrs:{id:"architecture"}},[t("a",{staticClass:"header-anchor",attrs:{href:"#architecture"}},[e._v("#")]),e._v(" Architecture")]),e._v(" "),t("p",[e._v("The openEO API defines a language for how clients communicate to back-ends in order to analyze large Earth observation datasets. The API will be implemented by drivers for specific back-ends. Some first architecture considerations are listed below.")]),e._v(" "),t("ol",[t("li",[e._v("The openEO API is a contract between clients and back-ends that describes the communication only")]),e._v(" "),t("li",[e._v("Each back-end runs its own API instance including the specific back-end driver. There is no API instance that runs more than one driver.")]),e._v(" "),t("li",[e._v("Clients in R, Python, and JavaScript connect directly to the back-ends and communicate with the back-ends over "),t("em",[e._v("HTTPS")]),e._v(" according to the openEO API specification.")]),e._v(" "),t("li",[e._v("API instances can run on back-end servers or additional intermediate layers, which then communicate to back-ends in a back-end specific way.")]),e._v(" "),t("li",[e._v("Back-ends may add functionality and extend the API wherever there is need.")]),e._v(" "),t("li",[e._v("There will be a central back-end registry service (openEO Hub), to allow users to search for back-ends with specific functionality and or data.")]),e._v(" "),t("li",[e._v("The openEO API may define "),t("em",[e._v("profiles")]),e._v(" in order to group specific functionality.")])]),e._v(" "),t("p",[t("img",{attrs:{src:a(322),alt:"Architecture - openEO API shown in dark blue"}})]),e._v(" "),t("h1",{attrs:{id:"microservices"}},[t("a",{staticClass:"header-anchor",attrs:{href:"#microservices"}},[e._v("#")]),e._v(" Microservices")]),e._v(" "),t("p",[e._v("To simplify and structure the development, the API is divided into a few microservices.")]),e._v(" "),t("table",[t("thead",[t("tr",[t("th",[e._v("Microservice")]),e._v(" "),t("th",[e._v("Description")])])]),e._v(" "),t("tbody",[t("tr",[t("td",[e._v("Capabilities")]),e._v(" "),t("td",[e._v("This microservice reports on the capabilities of the back-end, i.e. which API endpoints are implemented, which authentication methods are supported, and whether and how UDFs can be executed at the back-end.")])]),e._v(" "),t("tr",[t("td",[e._v("EO Data Discovery")]),e._v(" "),t("td",[e._v("Describes which collections are available at the back-end.")])]),e._v(" "),t("tr",[t("td",[e._v("Process Discovery")]),e._v(" "),t("td",[e._v("Provides services to find out which processes a back-end provides, i.e., what users can do with the available data.")])]),e._v(" "),t("tr",[t("td",[e._v("Data Processing")]),e._v(" "),t("td",[e._v("Organizes and manages data processing on the back-end, either as synchronous on-demand computation or batch jobs.")])]),e._v(" "),t("tr",[t("td",[e._v("File Storage")]),e._v(" "),t("td",[e._v("Organizes and manages user-uploaded files.")])]),e._v(" "),t("tr",[t("td",[e._v("User-Defined Processes")]),e._v(" "),t("td",[e._v("Organizes and manages user-defined processes (process graphs).")])]),e._v(" "),t("tr",[t("td",[e._v("Secondary Services")]),e._v(" "),t("td",[e._v("External web services to access data and job results such as a OGC WMTS service.")])]),e._v(" "),t("tr",[t("td",[e._v("Account Management")]),e._v(" "),t("td",[e._v("User management, accounting and authentication.")])]),e._v(" "),t("tr",[t("td",[e._v("UDF Runtime")]),e._v(" "),t("td",[e._v("Execution of user-defined functions, not part of the Core API. See the "),t("RouterLink",{attrs:{to:"/documentation/1.0/udfs.html"}},[e._v("UDF documentation")]),e._v(" for more information.")],1)])])])])}),[],!1,null,null,null);t.default=n.exports}}]); \ No newline at end of file +(window.webpackJsonp=window.webpackJsonp||[]).push([[43],{322:function(e,t,a){e.exports=a.p+"assets/img/arch.e75ccb9a.png"},517:function(e,t,a){"use strict";a.r(t);var i=a(4),n=Object(i.a)({},(function(){var e=this,t=e._self._c;return t("ContentSlotsDistributor",{attrs:{"slot-key":e.$parent.slotKey}},[t("h1",{attrs:{id:"architecture"}},[t("a",{staticClass:"header-anchor",attrs:{href:"#architecture"}},[e._v("#")]),e._v(" Architecture")]),e._v(" "),t("p",[e._v("The openEO API defines a language for how clients communicate to back-ends in order to analyze large Earth observation datasets. The API will be implemented by drivers for specific back-ends. Some first architecture considerations are listed below.")]),e._v(" "),t("ol",[t("li",[e._v("The openEO API is a contract between clients and back-ends that describes the communication only")]),e._v(" "),t("li",[e._v("Each back-end runs its own API instance including the specific back-end driver. There is no API instance that runs more than one driver.")]),e._v(" "),t("li",[e._v("Clients in R, Python, and JavaScript connect directly to the back-ends and communicate with the back-ends over "),t("em",[e._v("HTTPS")]),e._v(" according to the openEO API specification.")]),e._v(" "),t("li",[e._v("API instances can run on back-end servers or additional intermediate layers, which then communicate to back-ends in a back-end specific way.")]),e._v(" "),t("li",[e._v("Back-ends may add functionality and extend the API wherever there is need.")]),e._v(" "),t("li",[e._v("There will be a central back-end registry service (openEO Hub), to allow users to search for back-ends with specific functionality and or data.")]),e._v(" "),t("li",[e._v("The openEO API may define "),t("em",[e._v("profiles")]),e._v(" in order to group specific functionality.")])]),e._v(" "),t("p",[t("img",{attrs:{src:a(322),alt:"Architecture - openEO API shown in dark blue"}})]),e._v(" "),t("h1",{attrs:{id:"microservices"}},[t("a",{staticClass:"header-anchor",attrs:{href:"#microservices"}},[e._v("#")]),e._v(" Microservices")]),e._v(" "),t("p",[e._v("To simplify and structure the development, the API is divided into a few microservices.")]),e._v(" "),t("table",[t("thead",[t("tr",[t("th",[e._v("Microservice")]),e._v(" "),t("th",[e._v("Description")])])]),e._v(" "),t("tbody",[t("tr",[t("td",[e._v("Capabilities")]),e._v(" "),t("td",[e._v("This microservice reports on the capabilities of the back-end, i.e. which API endpoints are implemented, which authentication methods are supported, and whether and how UDFs can be executed at the back-end.")])]),e._v(" "),t("tr",[t("td",[e._v("EO Data Discovery")]),e._v(" "),t("td",[e._v("Describes which collections are available at the back-end.")])]),e._v(" "),t("tr",[t("td",[e._v("Process Discovery")]),e._v(" "),t("td",[e._v("Provides services to find out which processes a back-end provides, i.e., what users can do with the available data.")])]),e._v(" "),t("tr",[t("td",[e._v("Data Processing")]),e._v(" "),t("td",[e._v("Organizes and manages data processing on the back-end, either as synchronous on-demand computation or batch jobs.")])]),e._v(" "),t("tr",[t("td",[e._v("File Storage")]),e._v(" "),t("td",[e._v("Organizes and manages user-uploaded files.")])]),e._v(" "),t("tr",[t("td",[e._v("User-Defined Processes")]),e._v(" "),t("td",[e._v("Organizes and manages user-defined processes (process graphs).")])]),e._v(" "),t("tr",[t("td",[e._v("Secondary Services")]),e._v(" "),t("td",[e._v("External web services to access data and job results such as a OGC WMTS service.")])]),e._v(" "),t("tr",[t("td",[e._v("Account Management")]),e._v(" "),t("td",[e._v("User management, accounting and authentication.")])]),e._v(" "),t("tr",[t("td",[e._v("UDF Runtime")]),e._v(" "),t("td",[e._v("Execution of user-defined functions, not part of the Core API. See the "),t("RouterLink",{attrs:{to:"/documentation/1.0/udfs.html"}},[e._v("UDF documentation")]),e._v(" for more information.")],1)])])])])}),[],!1,null,null,null);t.default=n.exports}}]); \ No newline at end of file diff --git a/assets/js/45.ad42f7c7.js b/assets/js/45.54547be9.js similarity index 99% rename from assets/js/45.ad42f7c7.js rename to assets/js/45.54547be9.js index b80bbc9c7..fb6deb97e 100644 --- a/assets/js/45.ad42f7c7.js +++ b/assets/js/45.54547be9.js @@ -1 +1 @@ -(window.webpackJsonp=window.webpackJsonp||[]).push([[45],{324:function(e,a,o){e.exports=o.p+"assets/img/processes.9a2105e4.png"},529:function(e,a,o){"use strict";o.r(a);var t=o(4),r=Object(t.a)({},(function(){var e=this,a=e._self._c;return a("ContentSlotsDistributor",{attrs:{"slot-key":e.$parent.slotKey}},[a("h1",{attrs:{id:"process-profiles"}},[a("a",{staticClass:"header-anchor",attrs:{href:"#process-profiles"}},[e._v("#")]),e._v(" Process Profiles")]),e._v(" "),a("p",[e._v('The following image provides an overview of the openEO Processes profiles.\nThe minimal profile that allows an openEO implementation to be called "openEO-compliant" is '),a("em",[e._v("L1 Minimal")]),e._v(".")]),e._v(" "),a("figure",[a("img",{attrs:{src:o(324),alt:"The hierarchy of openEO Processes profiles: L1 Minimal -> L2 Recommended (with sub-profiles) -> L2A/B Raster/Vector -> L3 Advanced (with sub-profiles) -> L4 Above and Beyond"}}),e._v(" "),a("figcaption",[e._v("An overview of the openEO Processes profiles.")])]),e._v(" "),a("ul",[a("li",[a("em",[e._v("L1 Minimal")]),e._v(" ensures that the openEO implementation has a minimal set of functionality which allow users to execute basic use-cases.")]),e._v(" "),a("li",[a("em",[e._v("L2 Recommended")]),e._v(" add functionality that we recommend to be available so that users can more effectively make use of the openEO implementation.")]),e._v(" "),a("li",[a("em",[e._v("L3 Advanced")]),e._v(" allows users to execute more advanced use cases.")]),e._v(" "),a("li",[a("em",[e._v("L4 Above and Beyond")]),e._v(" adds very specific and complex requirements for very specific and highly advanced use cases.")])]),e._v(" "),a("p",[e._v("There are various sub-profiles in L2 (e.g., L2-Date) and L3 (e.g., L3-ML) that add a specific set of functionalities centered around specific needs such as date/time manipulation or execution of machine learning workflows.")]),e._v(" "),a("p",[e._v("In the following chapter you can find a list of requirements per profile.")]),e._v(" "),a("h2",{attrs:{id:"requirements-per-profile"}},[a("a",{staticClass:"header-anchor",attrs:{href:"#requirements-per-profile"}},[e._v("#")]),e._v(" Requirements per Profile")]),e._v(" "),a("div",{staticClass:"custom-block tip"},[a("p",{staticClass:"custom-block-title"},[e._v("Note")]),e._v(" "),a("p",[e._v('Missing experimental processes should (by default) lead to a "warning", but not lead to a rejection of that level in openEO.')])]),e._v(" "),a("h3",{attrs:{id:"l1-minimal"}},[a("a",{staticClass:"header-anchor",attrs:{href:"#l1-minimal"}},[e._v("#")]),e._v(" L1: Minimal")]),e._v(" "),a("ul",[a("li",[a("strong",[a("code",[e._v("absolute")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("add")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("and")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("apply")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("apply_dimension")])]),e._v(" "),a("ul",[a("li",[e._v("All dimensions that your datacubes can include are supported - x and y can usually be excluded")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("arccos")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("arcsin")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("arctan")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("array_concat")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("array_create")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("array_element")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("between")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("ceil")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("clip")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("constant")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("cos")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("divide")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("e")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("eq")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("exp")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("first")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("floor")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("gt")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("gte")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("int")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("last")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("ln")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("load_collection")])]),e._v(" "),a("ul",[a("li",[e._v("Parameter "),a("code",[e._v("temporal_extent")]),e._v(": All temporal formats are supported (date-time and date)")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("log")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("lt")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("lte")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("max")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("mean")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("median")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("min")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("mod")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("multiply")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("neq")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("not")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("or")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("pi")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("power")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("product")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("quantiles")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("reduce_dimension")])]),e._v(" "),a("ul",[a("li",[e._v("Parameter "),a("code",[e._v("reducer")]),e._v(": At least all processes (up to L1) in the category "),a("code",[e._v("reducer")]),e._v(" that accept an array as input and return a single value as output can be used (also in a chain of processes).")]),e._v(" "),a("li",[e._v("Parameter "),a("code",[e._v("dimension")]),e._v(": All dimensions that your datacubes can include are supported - x and y are excluded as they are handled with reduce_spatial")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("round")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("save_result")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("sd")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("sgn")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("sin")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("sqrt")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("subtract")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("sum")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("tan")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("variance")])])])]),e._v(" "),a("h3",{attrs:{id:"l2-recommended"}},[a("a",{staticClass:"header-anchor",attrs:{href:"#l2-recommended"}},[e._v("#")]),e._v(" L2: Recommended")]),e._v(" "),a("ul",[a("li",[a("strong",[a("code",[e._v("add_dimension")])]),e._v(" "),a("ul",[a("li",[e._v("Parameter "),a("code",[e._v("name")]),e._v(": All suitable dimensions are supported")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("aggregate_temporal")])]),e._v(" "),a("ul",[a("li",[e._v("Parameter "),a("code",[e._v("reducer")]),e._v(": At least all processes (up to the level of this requirement) in the category "),a("code",[e._v("reducer")]),e._v(" that accept an array as input and return a single value as output can be used (also in a chain of processes).")]),e._v(" "),a("li",[e._v("Parameter "),a("code",[e._v("reducer")]),e._v(": Supports access to labels in the callback")]),e._v(" "),a("li",[e._v("Parameter "),a("code",[e._v("dimension")]),e._v(": All suitable dimensions are supported")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("aggregate_temporal_period")])]),e._v(" "),a("ul",[a("li",[e._v("Parameter "),a("code",[e._v("reducer")]),e._v(": At least all processes (up to the level of this requirement) in the category "),a("code",[e._v("reducer")]),e._v(" that accept an array as input and return a single value as output can be used (also in a chain of processes).")]),e._v(" "),a("li",[e._v("Parameter "),a("code",[e._v("reducer")]),e._v(": Supports access to labels in the callback")]),e._v(" "),a("li",[e._v("Parameter "),a("code",[e._v("dimension")]),e._v(": All suitable dimensions are supported")]),e._v(" "),a("li",[e._v("Parameter "),a("code",[e._v("period")]),e._v(": "),a("code",[e._v("enum")]),e._v(" reflects implemention (all values are supported)")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("all")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("any")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("apply_dimension")])]),e._v(" "),a("ul",[a("li",[e._v("Parameter "),a("code",[e._v("process")]),e._v(": Supports access to labels in the callback")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("arcosh")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("arctan2")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("array_element")])]),e._v(" "),a("ul",[a("li",[e._v("Supports labeled arrays")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("array_find")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("arsinh")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("artanh")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("cosh")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("count")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("dimension_labels")])]),e._v(" "),a("ul",[a("li",[e._v("Parameter "),a("code",[e._v("dimension")]),e._v(": All suitable dimensions are supported")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("drop_dimension")])]),e._v(" "),a("ul",[a("li",[e._v("Parameter "),a("code",[e._v("name")]),e._v(": All suitable dimensions are supported")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("extrema")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("filter_bbox")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("filter_temporal")])]),e._v(" "),a("ul",[a("li",[e._v("Parameter "),a("code",[e._v("dimension")]),e._v(": All suitable dimensions are supported")]),e._v(" "),a("li",[e._v("All temporal formats are supported (date-time and date)")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("if")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("inspect")])]),e._v(" (experimental)\n"),a("ul",[a("li",[e._v("Parameter "),a("code",[e._v("level")]),e._v(": "),a("code",[e._v("enum")]),e._v(" reflects implemention (all values are supported)")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("is_nan")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("is_nodata")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("is_valid")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("linear_scale_range")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("nan")])]),e._v(" (experimental)")]),e._v(" "),a("li",[a("strong",[a("code",[e._v("normalized_difference")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("reduce_dimension")])]),e._v(" "),a("ul",[a("li",[e._v("Parameter "),a("code",[e._v("reducer")]),e._v(": At least all processes (up to L2) in the category "),a("code",[e._v("reducer")]),e._v(" that accept an array as input and return a single value as output can be used (also in a chain of processes).")]),e._v(" "),a("li",[e._v("Parameter "),a("code",[e._v("reducer")]),e._v(": Supports access to labels in the callback")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("rename_dimension")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("rename_labels")])]),e._v(" "),a("ul",[a("li",[e._v("Parameter "),a("code",[e._v("dimension")]),e._v(": All dimensions that your datacubes can include are supported - x and y can usually be excluded")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("sinh")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("sort")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("tanh")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("xor")])])])]),e._v(" "),a("h3",{attrs:{id:"l2a-recommended-raster"}},[a("a",{staticClass:"header-anchor",attrs:{href:"#l2a-recommended-raster"}},[e._v("#")]),e._v(" L2A: Recommended Raster")]),e._v(" "),a("ul",[a("li",[a("strong",[a("code",[e._v("aggregate_spatial")])]),e._v(" "),a("ul",[a("li",[e._v("Parameter "),a("code",[e._v("reducer")]),e._v(": At least all processes (up to the level of this requirement) in the category "),a("code",[e._v("reducer")]),e._v(" that accept an array as input and return a single value as output can be used (also in a chain of processes).")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("apply_kernel")])]),e._v(" "),a("ul",[a("li",[e._v("Parameter "),a("code",[e._v("border")]),e._v(": "),a("code",[e._v("enum")]),e._v(" reflects implemention (all values are supported)")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("filter_bands")])]),e._v(" "),a("ul",[a("li",[e._v("Supports filtering by band name")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("filter_spatial")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("load_collection")])]),e._v(" "),a("ul",[a("li",[e._v("Parameter "),a("code",[e._v("bands")]),e._v(": Supports filtering by band name and common name")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("mask")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("mask_polygon")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("resample_spatial")])]),e._v(" "),a("ul",[a("li",[e._v("Parameter "),a("code",[e._v("method")]),e._v(": "),a("code",[e._v("enum")]),e._v(" reflects implemention (all values are supported)")])])])]),e._v(" "),a("h3",{attrs:{id:"l2b-recommended-vector"}},[a("a",{staticClass:"header-anchor",attrs:{href:"#l2b-recommended-vector"}},[e._v("#")]),e._v(" L2B: Recommended Vector")]),e._v(" "),a("ul",[a("li",[a("strong",[a("code",[e._v("filter_vector")])]),e._v(" (experimental)")]),e._v(" "),a("li",[a("strong",[a("code",[e._v("vector_buffer")])]),e._v(" (experimental)")]),e._v(" "),a("li",[a("strong",[a("code",[e._v("vector_reproject")])]),e._v(" (experimental)")])]),e._v(" "),a("h3",{attrs:{id:"l2-date-date-time-manipulation"}},[a("a",{staticClass:"header-anchor",attrs:{href:"#l2-date-date-time-manipulation"}},[e._v("#")]),e._v(" L2-Date: Date & Time manipulation")]),e._v(" "),a("ul",[a("li",[a("strong",[a("code",[e._v("date_between")])]),e._v(" (experimental)")]),e._v(" "),a("li",[a("strong",[a("code",[e._v("date_difference")])]),e._v(" (experimental)")]),e._v(" "),a("li",[a("strong",[a("code",[e._v("date_shift")])]),e._v(" (experimental)")])]),e._v(" "),a("h3",{attrs:{id:"l2-text-text-manipulation"}},[a("a",{staticClass:"header-anchor",attrs:{href:"#l2-text-text-manipulation"}},[e._v("#")]),e._v(" L2-Text: Text manipulation")]),e._v(" "),a("ul",[a("li",[a("strong",[a("code",[e._v("text_begins")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("text_concat (text_merge)")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("text_contains")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("text_ends")])])])]),e._v(" "),a("h3",{attrs:{id:"l3-advanced"}},[a("a",{staticClass:"header-anchor",attrs:{href:"#l3-advanced"}},[e._v("#")]),e._v(" L3: Advanced")]),e._v(" "),a("ul",[a("li",[a("strong",[a("code",[e._v("add_dimension")])]),e._v(" "),a("ul",[a("li",[e._v("Parameter "),a("code",[e._v("type")]),e._v(": "),a("code",[e._v("enum")]),e._v(" reflects implemention (all values are supported)")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("aggregate_spatial")])]),e._v(" "),a("ul",[a("li",[e._v("Parameter "),a("code",[e._v("reducer")]),e._v(": Supports access to labels in the callback")]),e._v(" "),a("li",[e._v("Parameter "),a("code",[e._v("context")]),e._v(": is supported and passed to the callback")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("aggregate_spatial_window")])]),e._v(" (experimental)")]),e._v(" "),a("li",[a("strong",[a("code",[e._v("aggregate_temporal")])]),e._v(" "),a("ul",[a("li",[e._v("Parameter "),a("code",[e._v("context")]),e._v(": is supported and passed to the callback")]),e._v(" "),a("li",[e._v("All temporal formats are supported (date-time, date and time)")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("aggregate_temporal_period")])]),e._v(" "),a("ul",[a("li",[e._v("Parameter "),a("code",[e._v("context")]),e._v(": is supported and passed to the callback")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("apply")])]),e._v(" "),a("ul",[a("li",[e._v("Parameter "),a("code",[e._v("process")]),e._v(": At least all processes (up to the level of this requirement) in the categories "),a("code",[e._v("comparison")]),e._v(", "),a("code",[e._v("logic")]),e._v(" and "),a("code",[e._v("math")]),e._v(" can be used (also in a chain of processes).")]),e._v(" "),a("li",[e._v("Parameter "),a("code",[e._v("context")]),e._v(": is supported and passed to the callback")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("apply_dimension")])]),e._v(" "),a("ul",[a("li",[e._v("Parameter "),a("code",[e._v("process")]),e._v(": At least all processes (up to the level of this requirement) in the categories "),a("code",[e._v("array")]),e._v(", "),a("code",[e._v("comparison")]),e._v(", "),a("code",[e._v("logic")]),e._v(" and "),a("code",[e._v("math")]),e._v(" can be used (also in a chain of processes).")]),e._v(" "),a("li",[e._v("Parameter "),a("code",[e._v("context")]),e._v(": is supported and passed to the callback")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("apply_neighborhood")])]),e._v(" "),a("ul",[a("li",[e._v("Parameter "),a("code",[e._v("process")]),e._v(": Supports access to labels in the callback")]),e._v(" "),a("li",[e._v("Parameter "),a("code",[e._v("context")]),e._v(": is supported and passed to the callback")]),e._v(" "),a("li",[e._v("Parameter "),a("code",[e._v("data")]),e._v(": All listed label types supported.")]),e._v(" "),a("li",[e._v("Parameter "),a("code",[e._v("size")]),e._v(" / "),a("code",[e._v("overlap")]),e._v(": Units "),a("code",[e._v("m")]),e._v(", "),a("code",[e._v("px")]),e._v(" and "),a("code",[e._v("null")]),e._v(" are supported")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("array_append")])]),e._v(" "),a("ul",[a("li",[e._v("Supports labeled arrays")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("array_apply")])]),e._v(" "),a("ul",[a("li",[e._v("Parameter "),a("code",[e._v("process")]),e._v(": Supports access to labels in the callback")]),e._v(" "),a("li",[e._v("Parameter "),a("code",[e._v("context")]),e._v(": is supported and passed to the callback")]),e._v(" "),a("li",[e._v("Supports labeled arrays")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("array_concat")])]),e._v(" "),a("ul",[a("li",[e._v("Supports labeled arrays")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("array_contains")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("array_create_labeled")])]),e._v(" (experimental)")]),e._v(" "),a("li",[a("strong",[a("code",[e._v("array_filter")])]),e._v(" "),a("ul",[a("li",[e._v("Parameter "),a("code",[e._v("context")]),e._v(": is supported and passed to the callback")]),e._v(" "),a("li",[e._v("Supports labeled arrays")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("array_find_label")])]),e._v(" (experimental)")]),e._v(" "),a("li",[a("strong",[a("code",[e._v("array_interpolate_linear")])]),e._v(" "),a("ul",[a("li",[e._v("Supports labeled arrays")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("array_labels")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("array_modify")])]),e._v(" (experimental)\n"),a("ul",[a("li",[e._v("Supports labeled arrays")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("cloud_detection")])]),e._v(" (experimental)")]),e._v(" "),a("li",[a("strong",[a("code",[e._v("count")])]),e._v(" "),a("ul",[a("li",[e._v("Parameter "),a("code",[e._v("context")]),e._v(": is supported and passed to the callback")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("create_data_cube (create_raster_cube)")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("cummax")])]),e._v(" (experimental)")]),e._v(" "),a("li",[a("strong",[a("code",[e._v("cummin")])]),e._v(" (experimental)")]),e._v(" "),a("li",[a("strong",[a("code",[e._v("cumproduct")])]),e._v(" (experimental)")]),e._v(" "),a("li",[a("strong",[a("code",[e._v("cumsum")])]),e._v(" (experimental)")]),e._v(" "),a("li",[a("strong",[a("code",[e._v("filter_bands")])]),e._v(" "),a("ul",[a("li",[e._v("Supports filtering by common name")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("filter_labels")])]),e._v(" (experimental)\n"),a("ul",[a("li",[e._v("Parameter "),a("code",[e._v("context")]),e._v(": is supported and passed to the callback")]),e._v(" "),a("li",[e._v("Parameter "),a("code",[e._v("dimension")]),e._v(": All suitable dimensions are supported")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("flatten_dimensions")])]),e._v(" (experimental)")]),e._v(" "),a("li",[a("strong",[a("code",[e._v("is_infinite")])]),e._v(" (experimental)")]),e._v(" "),a("li",[a("strong",[a("code",[e._v("load_collection")])]),e._v(" "),a("ul",[a("li",[e._v("Parameter "),a("code",[e._v("properties")]),e._v(": Supports querying by queryables defined via the API.")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("load_geojson")])]),e._v(" (experimental)")]),e._v(" "),a("li",[a("strong",[a("code",[e._v("load_stac (load_result)")])]),e._v(" (experimental)\n"),a("ul",[a("li",[e._v("Supports loading from STAC API - Features.")]),e._v(" "),a("li",[e._v("Supports loading from STAC API - Item Search.")]),e._v(" "),a("li",[e._v("Supports loading from static STAC.")]),e._v(" "),a("li",[e._v("Parameter "),a("code",[e._v("temporal_extent")]),e._v(": All temporal formats are supported (date-time and date)")]),e._v(" "),a("li",[e._v("Parameter "),a("code",[e._v("bands")]),e._v(": Supports filtering by band name and common name")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("merge_cubes")])]),e._v(" "),a("ul",[a("li",[e._v("Parameter "),a("code",[e._v("context")]),e._v(": is supported and passed to the callback")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("ndvi")])]),e._v(" "),a("ul",[a("li",[e._v("Supports common names as band names")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("order")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("rearrange")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("reduce_dimension")])]),e._v(" "),a("ul",[a("li",[e._v("Parameter "),a("code",[e._v("context")]),e._v(": is supported and passed to the callback")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("reduce_spatial")])]),e._v(" (experimental)\n"),a("ul",[a("li",[e._v("Parameter "),a("code",[e._v("reducer")]),e._v(": At least all processes (up to the level of this requirement) in the category "),a("code",[e._v("reducer")]),e._v(" that accept an array as input and return a single value as output can be used (also in a chain of processes).")]),e._v(" "),a("li",[e._v("Parameter "),a("code",[e._v("reducer")]),e._v(": Supports access to labels in the callback")]),e._v(" "),a("li",[e._v("Parameter "),a("code",[e._v("context")]),e._v(": is supported and passed to the callback")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("resample_cube_spatial")])]),e._v(" "),a("ul",[a("li",[e._v("Parameter "),a("code",[e._v("method")]),e._v(": "),a("code",[e._v("enum")]),e._v(" reflects implemention (all values are supported)")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("resample_cube_temporal")])]),e._v(" "),a("ul",[a("li",[e._v("Parameter "),a("code",[e._v("dimension")]),e._v(": All suitable dimensions are supported")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("resample_spatial")])]),e._v(" "),a("ul",[a("li",[e._v("Parameter "),a("code",[e._v("align")]),e._v(": "),a("code",[e._v("enum")]),e._v(" reflects implemention (all values are supported)")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("trim_cube")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("unflatten_dimensions")])]),e._v(" (experimental)")]),e._v(" "),a("li",[a("strong",[a("code",[e._v("vector_to_random_points")])]),e._v(" (experimental)")]),e._v(" "),a("li",[a("strong",[a("code",[e._v("vector_to_regular_points")])]),e._v(" (experimental)")])]),e._v(" "),a("h3",{attrs:{id:"l3-ml-machine-learning"}},[a("a",{staticClass:"header-anchor",attrs:{href:"#l3-ml-machine-learning"}},[e._v("#")]),e._v(" L3-ML: Machine Learning")]),e._v(" "),a("ul",[a("li",[a("strong",[a("code",[e._v("fit_curve")])]),e._v(" (experimental)")]),e._v(" "),a("li",[a("strong",[a("code",[e._v("fit_regr_random_forest")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("load_ml_model")])]),e._v(" (experimental)")]),e._v(" "),a("li",[a("strong",[a("code",[e._v("predict_curve")])]),e._v(" (experimental)")]),e._v(" "),a("li",[a("strong",[a("code",[e._v("save_ml_model")])]),e._v(" (experimental)")])]),e._v(" "),a("h3",{attrs:{id:"l3-udf-user-defined-functions"}},[a("a",{staticClass:"header-anchor",attrs:{href:"#l3-udf-user-defined-functions"}},[e._v("#")]),e._v(" L3-UDF: User-Defined Functions")]),e._v(" "),a("ul",[a("li",[a("strong",[a("code",[e._v("run_udf")])]),e._v(" "),a("ul",[a("li",[e._v("Parameter "),a("code",[e._v("context")]),e._v(": is supported and passed to the callback")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("run_udf_externally")])]),e._v(" (experimental)")])]),e._v(" "),a("h3",{attrs:{id:"l3-clim-cimatology"}},[a("a",{staticClass:"header-anchor",attrs:{href:"#l3-clim-cimatology"}},[e._v("#")]),e._v(" L3-Clim: Cimatology")]),e._v(" "),a("ul",[a("li",[a("strong",[a("code",[e._v("anomaly")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("climatological_normal")])])])]),e._v(" "),a("h3",{attrs:{id:"l3-ard-analysis-ready-data"}},[a("a",{staticClass:"header-anchor",attrs:{href:"#l3-ard-analysis-ready-data"}},[e._v("#")]),e._v(" L3-ARD: Analysis-Ready Data")]),e._v(" "),a("ul",[a("li",[a("strong",[a("code",[e._v("ard_normalized_radar_backscatter")])]),e._v(" (experimental)\n"),a("ul",[a("li",[e._v("has been tested on > 100x100km at 10m resolution (or equivalent)")]),e._v(" "),a("li",[e._v("Custom parameters are provided via the "),a("code",[e._v("options")]),e._v(" parameter")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("ard_surface_reflectance")])]),e._v(" (experimental)\n"),a("ul",[a("li",[e._v("Parameter "),a("code",[e._v("atmospheric_correction_method")]),e._v(": "),a("code",[e._v("enum")]),e._v(" reflects implemention (all values are supported)")]),e._v(" "),a("li",[e._v("Parameter "),a("code",[e._v("cloud_detection_method")]),e._v(": "),a("code",[e._v("enum")]),e._v(" reflects implemention (all values are supported)")]),e._v(" "),a("li",[e._v("Custom parameters are provided via the "),a("code",[e._v("atmospheric_correction_options")]),e._v(" and/or "),a("code",[e._v("cloud_detection_options")]),e._v(" parameters")])])])]),e._v(" "),a("h3",{attrs:{id:"l4-above-and-beyond"}},[a("a",{staticClass:"header-anchor",attrs:{href:"#l4-above-and-beyond"}},[e._v("#")]),e._v(" L4: Above and Beyond")]),e._v(" "),a("ul",[a("li",[a("strong",[a("code",[e._v("aggregate_spatial")])]),e._v(" "),a("ul",[a("li",[e._v("Parameter "),a("code",[e._v("reducer")]),e._v(": At least all processes (up to the level of this requirement) in the categories "),a("code",[e._v("array")]),e._v(", "),a("code",[e._v("comparison")]),e._v(", "),a("code",[e._v("logic")]),e._v(" and "),a("code",[e._v("math")]),e._v(" can be used (also in a chain of processes).")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("aggregate_temporal")])]),e._v(" "),a("ul",[a("li",[e._v("Parameter "),a("code",[e._v("reducer")]),e._v(": At least all processes (up to the level of this requirement) in the categories "),a("code",[e._v("array")]),e._v(", "),a("code",[e._v("comparison")]),e._v(", "),a("code",[e._v("logic")]),e._v(" and "),a("code",[e._v("math")]),e._v(" can be used (also in a chain of processes).")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("aggregate_temporal_period")])]),e._v(" "),a("ul",[a("li",[e._v("Parameter "),a("code",[e._v("reducer")]),e._v(": At least all processes (up to the level of this requirement) in the categories "),a("code",[e._v("array")]),e._v(", "),a("code",[e._v("comparison")]),e._v(", "),a("code",[e._v("logic")]),e._v(" and "),a("code",[e._v("math")]),e._v(" can be used (also in a chain of processes).")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("apply_neighborhood")])]),e._v(" "),a("ul",[a("li",[e._v("Parameter "),a("code",[e._v("process")]),e._v(": At least all processes (up to the level of this requirement) in the categories "),a("code",[e._v("array")]),e._v(", "),a("code",[e._v("comparison")]),e._v(", "),a("code",[e._v("logic")]),e._v(" and "),a("code",[e._v("math")]),e._v(" can be used (also in a chain of processes).")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("apply_polygon (chunk_polygon)")])]),e._v(" (experimental)")]),e._v(" "),a("li",[a("strong",[a("code",[e._v("array_apply")])]),e._v(" "),a("ul",[a("li",[e._v("Parameter "),a("code",[e._v("process")]),e._v(": At least all processes (up to the level of this requirement) in the categories "),a("code",[e._v("comparison")]),e._v(", "),a("code",[e._v("logic")]),e._v(" and "),a("code",[e._v("math")]),e._v(" can be used (also in a chain of processes).")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("atmospheric_correction")])]),e._v(" (experimental)\n"),a("ul",[a("li",[e._v("Parameter "),a("code",[e._v("method")]),e._v(": "),a("code",[e._v("enum")]),e._v(" reflects implemention (all values are supported)")]),e._v(" "),a("li",[e._v("Custom parameters are provided via the "),a("code",[e._v("options")]),e._v(" parameter")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("filter_bands")])]),e._v(" "),a("ul",[a("li",[e._v("Supports filtering by wavelength")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("filter_bbox")])]),e._v(" "),a("ul",[a("li",[e._v("Parameter "),a("code",[e._v("extent")]),e._v(": Supports filtering by base/height")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("load_collection")])]),e._v(" "),a("ul",[a("li",[e._v("Parameter "),a("code",[e._v("spatial_extent")]),e._v(": Supports filtering by base/height")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("load_stac (load_result)")])]),e._v(" (experimental)\n"),a("ul",[a("li",[e._v("Parameter "),a("code",[e._v("spatial_extent")]),e._v(": Supports filtering by base/height")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("load_uploaded_files")])]),e._v(" (experimental)")]),e._v(" "),a("li",[a("strong",[a("code",[e._v("load_url")])]),e._v(" (experimental)")]),e._v(" "),a("li",[a("strong",[a("code",[e._v("reduce_dimension")])]),e._v(" "),a("ul",[a("li",[e._v("Parameter "),a("code",[e._v("reducer")]),e._v(": At least all processes (up to the level of this requirement) in the categories "),a("code",[e._v("array")]),e._v(", "),a("code",[e._v("comparison")]),e._v(", "),a("code",[e._v("logic")]),e._v(" and "),a("code",[e._v("math")]),e._v(" can be used (also in a chain of processes).")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("reduce_spatial")])]),e._v(" (experimental)\n"),a("ul",[a("li",[e._v("Parameter "),a("code",[e._v("reducer")]),e._v(": At least all processes (up to the level of this requirement) in the categories "),a("code",[e._v("array")]),e._v(", "),a("code",[e._v("comparison")]),e._v(", "),a("code",[e._v("logic")]),e._v(" and "),a("code",[e._v("math")]),e._v(" can be used (also in a chain of processes).")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("sar_backscatter")])]),e._v(" (experimental)\n"),a("ul",[a("li",[e._v("Parameter "),a("code",[e._v("coefficient")]),e._v(": "),a("code",[e._v("enum")]),e._v(" reflects implemention (all values are supported)")]),e._v(" "),a("li",[e._v("Custom parameters are provided via the "),a("code",[e._v("options")]),e._v(" parameter")])])])])])}),[],!1,null,null,null);a.default=r.exports}}]); \ No newline at end of file +(window.webpackJsonp=window.webpackJsonp||[]).push([[45],{324:function(e,a,o){e.exports=o.p+"assets/img/processes.9a2105e4.png"},531:function(e,a,o){"use strict";o.r(a);var t=o(4),r=Object(t.a)({},(function(){var e=this,a=e._self._c;return a("ContentSlotsDistributor",{attrs:{"slot-key":e.$parent.slotKey}},[a("h1",{attrs:{id:"process-profiles"}},[a("a",{staticClass:"header-anchor",attrs:{href:"#process-profiles"}},[e._v("#")]),e._v(" Process Profiles")]),e._v(" "),a("p",[e._v('The following image provides an overview of the openEO Processes profiles.\nThe minimal profile that allows an openEO implementation to be called "openEO-compliant" is '),a("em",[e._v("L1 Minimal")]),e._v(".")]),e._v(" "),a("figure",[a("img",{attrs:{src:o(324),alt:"The hierarchy of openEO Processes profiles: L1 Minimal -> L2 Recommended (with sub-profiles) -> L2A/B Raster/Vector -> L3 Advanced (with sub-profiles) -> L4 Above and Beyond"}}),e._v(" "),a("figcaption",[e._v("An overview of the openEO Processes profiles.")])]),e._v(" "),a("ul",[a("li",[a("em",[e._v("L1 Minimal")]),e._v(" ensures that the openEO implementation has a minimal set of functionality which allow users to execute basic use-cases.")]),e._v(" "),a("li",[a("em",[e._v("L2 Recommended")]),e._v(" add functionality that we recommend to be available so that users can more effectively make use of the openEO implementation.")]),e._v(" "),a("li",[a("em",[e._v("L3 Advanced")]),e._v(" allows users to execute more advanced use cases.")]),e._v(" "),a("li",[a("em",[e._v("L4 Above and Beyond")]),e._v(" adds very specific and complex requirements for very specific and highly advanced use cases.")])]),e._v(" "),a("p",[e._v("There are various sub-profiles in L2 (e.g., L2-Date) and L3 (e.g., L3-ML) that add a specific set of functionalities centered around specific needs such as date/time manipulation or execution of machine learning workflows.")]),e._v(" "),a("p",[e._v("In the following chapter you can find a list of requirements per profile.")]),e._v(" "),a("h2",{attrs:{id:"requirements-per-profile"}},[a("a",{staticClass:"header-anchor",attrs:{href:"#requirements-per-profile"}},[e._v("#")]),e._v(" Requirements per Profile")]),e._v(" "),a("div",{staticClass:"custom-block tip"},[a("p",{staticClass:"custom-block-title"},[e._v("Note")]),e._v(" "),a("p",[e._v('Missing experimental processes should (by default) lead to a "warning", but not lead to a rejection of that level in openEO.')])]),e._v(" "),a("h3",{attrs:{id:"l1-minimal"}},[a("a",{staticClass:"header-anchor",attrs:{href:"#l1-minimal"}},[e._v("#")]),e._v(" L1: Minimal")]),e._v(" "),a("ul",[a("li",[a("strong",[a("code",[e._v("absolute")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("add")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("and")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("apply")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("apply_dimension")])]),e._v(" "),a("ul",[a("li",[e._v("All dimensions that your datacubes can include are supported - x and y can usually be excluded")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("arccos")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("arcsin")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("arctan")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("array_concat")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("array_create")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("array_element")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("between")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("ceil")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("clip")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("constant")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("cos")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("divide")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("e")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("eq")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("exp")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("first")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("floor")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("gt")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("gte")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("int")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("last")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("ln")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("load_collection")])]),e._v(" "),a("ul",[a("li",[e._v("Parameter "),a("code",[e._v("temporal_extent")]),e._v(": All temporal formats are supported (date-time and date)")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("log")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("lt")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("lte")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("max")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("mean")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("median")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("min")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("mod")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("multiply")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("neq")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("not")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("or")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("pi")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("power")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("product")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("quantiles")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("reduce_dimension")])]),e._v(" "),a("ul",[a("li",[e._v("Parameter "),a("code",[e._v("reducer")]),e._v(": At least all processes (up to L1) in the category "),a("code",[e._v("reducer")]),e._v(" that accept an array as input and return a single value as output can be used (also in a chain of processes).")]),e._v(" "),a("li",[e._v("Parameter "),a("code",[e._v("dimension")]),e._v(": All dimensions that your datacubes can include are supported - x and y are excluded as they are handled with reduce_spatial")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("round")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("save_result")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("sd")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("sgn")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("sin")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("sqrt")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("subtract")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("sum")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("tan")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("variance")])])])]),e._v(" "),a("h3",{attrs:{id:"l2-recommended"}},[a("a",{staticClass:"header-anchor",attrs:{href:"#l2-recommended"}},[e._v("#")]),e._v(" L2: Recommended")]),e._v(" "),a("ul",[a("li",[a("strong",[a("code",[e._v("add_dimension")])]),e._v(" "),a("ul",[a("li",[e._v("Parameter "),a("code",[e._v("name")]),e._v(": All suitable dimensions are supported")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("aggregate_temporal")])]),e._v(" "),a("ul",[a("li",[e._v("Parameter "),a("code",[e._v("reducer")]),e._v(": At least all processes (up to the level of this requirement) in the category "),a("code",[e._v("reducer")]),e._v(" that accept an array as input and return a single value as output can be used (also in a chain of processes).")]),e._v(" "),a("li",[e._v("Parameter "),a("code",[e._v("reducer")]),e._v(": Supports access to labels in the callback")]),e._v(" "),a("li",[e._v("Parameter "),a("code",[e._v("dimension")]),e._v(": All suitable dimensions are supported")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("aggregate_temporal_period")])]),e._v(" "),a("ul",[a("li",[e._v("Parameter "),a("code",[e._v("reducer")]),e._v(": At least all processes (up to the level of this requirement) in the category "),a("code",[e._v("reducer")]),e._v(" that accept an array as input and return a single value as output can be used (also in a chain of processes).")]),e._v(" "),a("li",[e._v("Parameter "),a("code",[e._v("reducer")]),e._v(": Supports access to labels in the callback")]),e._v(" "),a("li",[e._v("Parameter "),a("code",[e._v("dimension")]),e._v(": All suitable dimensions are supported")]),e._v(" "),a("li",[e._v("Parameter "),a("code",[e._v("period")]),e._v(": "),a("code",[e._v("enum")]),e._v(" reflects implemention (all values are supported)")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("all")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("any")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("apply_dimension")])]),e._v(" "),a("ul",[a("li",[e._v("Parameter "),a("code",[e._v("process")]),e._v(": Supports access to labels in the callback")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("arcosh")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("arctan2")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("array_element")])]),e._v(" "),a("ul",[a("li",[e._v("Supports labeled arrays")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("array_find")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("arsinh")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("artanh")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("cosh")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("count")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("dimension_labels")])]),e._v(" "),a("ul",[a("li",[e._v("Parameter "),a("code",[e._v("dimension")]),e._v(": All suitable dimensions are supported")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("drop_dimension")])]),e._v(" "),a("ul",[a("li",[e._v("Parameter "),a("code",[e._v("name")]),e._v(": All suitable dimensions are supported")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("extrema")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("filter_bbox")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("filter_temporal")])]),e._v(" "),a("ul",[a("li",[e._v("Parameter "),a("code",[e._v("dimension")]),e._v(": All suitable dimensions are supported")]),e._v(" "),a("li",[e._v("All temporal formats are supported (date-time and date)")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("if")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("inspect")])]),e._v(" (experimental)\n"),a("ul",[a("li",[e._v("Parameter "),a("code",[e._v("level")]),e._v(": "),a("code",[e._v("enum")]),e._v(" reflects implemention (all values are supported)")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("is_nan")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("is_nodata")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("is_valid")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("linear_scale_range")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("nan")])]),e._v(" (experimental)")]),e._v(" "),a("li",[a("strong",[a("code",[e._v("normalized_difference")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("reduce_dimension")])]),e._v(" "),a("ul",[a("li",[e._v("Parameter "),a("code",[e._v("reducer")]),e._v(": At least all processes (up to L2) in the category "),a("code",[e._v("reducer")]),e._v(" that accept an array as input and return a single value as output can be used (also in a chain of processes).")]),e._v(" "),a("li",[e._v("Parameter "),a("code",[e._v("reducer")]),e._v(": Supports access to labels in the callback")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("rename_dimension")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("rename_labels")])]),e._v(" "),a("ul",[a("li",[e._v("Parameter "),a("code",[e._v("dimension")]),e._v(": All dimensions that your datacubes can include are supported - x and y can usually be excluded")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("sinh")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("sort")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("tanh")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("xor")])])])]),e._v(" "),a("h3",{attrs:{id:"l2a-recommended-raster"}},[a("a",{staticClass:"header-anchor",attrs:{href:"#l2a-recommended-raster"}},[e._v("#")]),e._v(" L2A: Recommended Raster")]),e._v(" "),a("ul",[a("li",[a("strong",[a("code",[e._v("aggregate_spatial")])]),e._v(" "),a("ul",[a("li",[e._v("Parameter "),a("code",[e._v("reducer")]),e._v(": At least all processes (up to the level of this requirement) in the category "),a("code",[e._v("reducer")]),e._v(" that accept an array as input and return a single value as output can be used (also in a chain of processes).")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("apply_kernel")])]),e._v(" "),a("ul",[a("li",[e._v("Parameter "),a("code",[e._v("border")]),e._v(": "),a("code",[e._v("enum")]),e._v(" reflects implemention (all values are supported)")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("filter_bands")])]),e._v(" "),a("ul",[a("li",[e._v("Supports filtering by band name")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("filter_spatial")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("load_collection")])]),e._v(" "),a("ul",[a("li",[e._v("Parameter "),a("code",[e._v("bands")]),e._v(": Supports filtering by band name and common name")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("mask")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("mask_polygon")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("resample_spatial")])]),e._v(" "),a("ul",[a("li",[e._v("Parameter "),a("code",[e._v("method")]),e._v(": "),a("code",[e._v("enum")]),e._v(" reflects implemention (all values are supported)")])])])]),e._v(" "),a("h3",{attrs:{id:"l2b-recommended-vector"}},[a("a",{staticClass:"header-anchor",attrs:{href:"#l2b-recommended-vector"}},[e._v("#")]),e._v(" L2B: Recommended Vector")]),e._v(" "),a("ul",[a("li",[a("strong",[a("code",[e._v("filter_vector")])]),e._v(" (experimental)")]),e._v(" "),a("li",[a("strong",[a("code",[e._v("vector_buffer")])]),e._v(" (experimental)")]),e._v(" "),a("li",[a("strong",[a("code",[e._v("vector_reproject")])]),e._v(" (experimental)")])]),e._v(" "),a("h3",{attrs:{id:"l2-date-date-time-manipulation"}},[a("a",{staticClass:"header-anchor",attrs:{href:"#l2-date-date-time-manipulation"}},[e._v("#")]),e._v(" L2-Date: Date & Time manipulation")]),e._v(" "),a("ul",[a("li",[a("strong",[a("code",[e._v("date_between")])]),e._v(" (experimental)")]),e._v(" "),a("li",[a("strong",[a("code",[e._v("date_difference")])]),e._v(" (experimental)")]),e._v(" "),a("li",[a("strong",[a("code",[e._v("date_shift")])]),e._v(" (experimental)")])]),e._v(" "),a("h3",{attrs:{id:"l2-text-text-manipulation"}},[a("a",{staticClass:"header-anchor",attrs:{href:"#l2-text-text-manipulation"}},[e._v("#")]),e._v(" L2-Text: Text manipulation")]),e._v(" "),a("ul",[a("li",[a("strong",[a("code",[e._v("text_begins")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("text_concat (text_merge)")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("text_contains")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("text_ends")])])])]),e._v(" "),a("h3",{attrs:{id:"l3-advanced"}},[a("a",{staticClass:"header-anchor",attrs:{href:"#l3-advanced"}},[e._v("#")]),e._v(" L3: Advanced")]),e._v(" "),a("ul",[a("li",[a("strong",[a("code",[e._v("add_dimension")])]),e._v(" "),a("ul",[a("li",[e._v("Parameter "),a("code",[e._v("type")]),e._v(": "),a("code",[e._v("enum")]),e._v(" reflects implemention (all values are supported)")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("aggregate_spatial")])]),e._v(" "),a("ul",[a("li",[e._v("Parameter "),a("code",[e._v("reducer")]),e._v(": Supports access to labels in the callback")]),e._v(" "),a("li",[e._v("Parameter "),a("code",[e._v("context")]),e._v(": is supported and passed to the callback")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("aggregate_spatial_window")])]),e._v(" (experimental)")]),e._v(" "),a("li",[a("strong",[a("code",[e._v("aggregate_temporal")])]),e._v(" "),a("ul",[a("li",[e._v("Parameter "),a("code",[e._v("context")]),e._v(": is supported and passed to the callback")]),e._v(" "),a("li",[e._v("All temporal formats are supported (date-time, date and time)")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("aggregate_temporal_period")])]),e._v(" "),a("ul",[a("li",[e._v("Parameter "),a("code",[e._v("context")]),e._v(": is supported and passed to the callback")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("apply")])]),e._v(" "),a("ul",[a("li",[e._v("Parameter "),a("code",[e._v("process")]),e._v(": At least all processes (up to the level of this requirement) in the categories "),a("code",[e._v("comparison")]),e._v(", "),a("code",[e._v("logic")]),e._v(" and "),a("code",[e._v("math")]),e._v(" can be used (also in a chain of processes).")]),e._v(" "),a("li",[e._v("Parameter "),a("code",[e._v("context")]),e._v(": is supported and passed to the callback")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("apply_dimension")])]),e._v(" "),a("ul",[a("li",[e._v("Parameter "),a("code",[e._v("process")]),e._v(": At least all processes (up to the level of this requirement) in the categories "),a("code",[e._v("array")]),e._v(", "),a("code",[e._v("comparison")]),e._v(", "),a("code",[e._v("logic")]),e._v(" and "),a("code",[e._v("math")]),e._v(" can be used (also in a chain of processes).")]),e._v(" "),a("li",[e._v("Parameter "),a("code",[e._v("context")]),e._v(": is supported and passed to the callback")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("apply_neighborhood")])]),e._v(" "),a("ul",[a("li",[e._v("Parameter "),a("code",[e._v("process")]),e._v(": Supports access to labels in the callback")]),e._v(" "),a("li",[e._v("Parameter "),a("code",[e._v("context")]),e._v(": is supported and passed to the callback")]),e._v(" "),a("li",[e._v("Parameter "),a("code",[e._v("data")]),e._v(": All listed label types supported.")]),e._v(" "),a("li",[e._v("Parameter "),a("code",[e._v("size")]),e._v(" / "),a("code",[e._v("overlap")]),e._v(": Units "),a("code",[e._v("m")]),e._v(", "),a("code",[e._v("px")]),e._v(" and "),a("code",[e._v("null")]),e._v(" are supported")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("array_append")])]),e._v(" "),a("ul",[a("li",[e._v("Supports labeled arrays")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("array_apply")])]),e._v(" "),a("ul",[a("li",[e._v("Parameter "),a("code",[e._v("process")]),e._v(": Supports access to labels in the callback")]),e._v(" "),a("li",[e._v("Parameter "),a("code",[e._v("context")]),e._v(": is supported and passed to the callback")]),e._v(" "),a("li",[e._v("Supports labeled arrays")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("array_concat")])]),e._v(" "),a("ul",[a("li",[e._v("Supports labeled arrays")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("array_contains")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("array_create_labeled")])]),e._v(" (experimental)")]),e._v(" "),a("li",[a("strong",[a("code",[e._v("array_filter")])]),e._v(" "),a("ul",[a("li",[e._v("Parameter "),a("code",[e._v("context")]),e._v(": is supported and passed to the callback")]),e._v(" "),a("li",[e._v("Supports labeled arrays")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("array_find_label")])]),e._v(" (experimental)")]),e._v(" "),a("li",[a("strong",[a("code",[e._v("array_interpolate_linear")])]),e._v(" "),a("ul",[a("li",[e._v("Supports labeled arrays")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("array_labels")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("array_modify")])]),e._v(" (experimental)\n"),a("ul",[a("li",[e._v("Supports labeled arrays")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("cloud_detection")])]),e._v(" (experimental)")]),e._v(" "),a("li",[a("strong",[a("code",[e._v("count")])]),e._v(" "),a("ul",[a("li",[e._v("Parameter "),a("code",[e._v("context")]),e._v(": is supported and passed to the callback")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("create_data_cube (create_raster_cube)")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("cummax")])]),e._v(" (experimental)")]),e._v(" "),a("li",[a("strong",[a("code",[e._v("cummin")])]),e._v(" (experimental)")]),e._v(" "),a("li",[a("strong",[a("code",[e._v("cumproduct")])]),e._v(" (experimental)")]),e._v(" "),a("li",[a("strong",[a("code",[e._v("cumsum")])]),e._v(" (experimental)")]),e._v(" "),a("li",[a("strong",[a("code",[e._v("filter_bands")])]),e._v(" "),a("ul",[a("li",[e._v("Supports filtering by common name")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("filter_labels")])]),e._v(" (experimental)\n"),a("ul",[a("li",[e._v("Parameter "),a("code",[e._v("context")]),e._v(": is supported and passed to the callback")]),e._v(" "),a("li",[e._v("Parameter "),a("code",[e._v("dimension")]),e._v(": All suitable dimensions are supported")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("flatten_dimensions")])]),e._v(" (experimental)")]),e._v(" "),a("li",[a("strong",[a("code",[e._v("is_infinite")])]),e._v(" (experimental)")]),e._v(" "),a("li",[a("strong",[a("code",[e._v("load_collection")])]),e._v(" "),a("ul",[a("li",[e._v("Parameter "),a("code",[e._v("properties")]),e._v(": Supports querying by queryables defined via the API.")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("load_geojson")])]),e._v(" (experimental)")]),e._v(" "),a("li",[a("strong",[a("code",[e._v("load_stac (load_result)")])]),e._v(" (experimental)\n"),a("ul",[a("li",[e._v("Supports loading from STAC API - Features.")]),e._v(" "),a("li",[e._v("Supports loading from STAC API - Item Search.")]),e._v(" "),a("li",[e._v("Supports loading from static STAC.")]),e._v(" "),a("li",[e._v("Parameter "),a("code",[e._v("temporal_extent")]),e._v(": All temporal formats are supported (date-time and date)")]),e._v(" "),a("li",[e._v("Parameter "),a("code",[e._v("bands")]),e._v(": Supports filtering by band name and common name")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("merge_cubes")])]),e._v(" "),a("ul",[a("li",[e._v("Parameter "),a("code",[e._v("context")]),e._v(": is supported and passed to the callback")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("ndvi")])]),e._v(" "),a("ul",[a("li",[e._v("Supports common names as band names")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("order")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("rearrange")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("reduce_dimension")])]),e._v(" "),a("ul",[a("li",[e._v("Parameter "),a("code",[e._v("context")]),e._v(": is supported and passed to the callback")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("reduce_spatial")])]),e._v(" (experimental)\n"),a("ul",[a("li",[e._v("Parameter "),a("code",[e._v("reducer")]),e._v(": At least all processes (up to the level of this requirement) in the category "),a("code",[e._v("reducer")]),e._v(" that accept an array as input and return a single value as output can be used (also in a chain of processes).")]),e._v(" "),a("li",[e._v("Parameter "),a("code",[e._v("reducer")]),e._v(": Supports access to labels in the callback")]),e._v(" "),a("li",[e._v("Parameter "),a("code",[e._v("context")]),e._v(": is supported and passed to the callback")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("resample_cube_spatial")])]),e._v(" "),a("ul",[a("li",[e._v("Parameter "),a("code",[e._v("method")]),e._v(": "),a("code",[e._v("enum")]),e._v(" reflects implemention (all values are supported)")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("resample_cube_temporal")])]),e._v(" "),a("ul",[a("li",[e._v("Parameter "),a("code",[e._v("dimension")]),e._v(": All suitable dimensions are supported")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("resample_spatial")])]),e._v(" "),a("ul",[a("li",[e._v("Parameter "),a("code",[e._v("align")]),e._v(": "),a("code",[e._v("enum")]),e._v(" reflects implemention (all values are supported)")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("trim_cube")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("unflatten_dimensions")])]),e._v(" (experimental)")]),e._v(" "),a("li",[a("strong",[a("code",[e._v("vector_to_random_points")])]),e._v(" (experimental)")]),e._v(" "),a("li",[a("strong",[a("code",[e._v("vector_to_regular_points")])]),e._v(" (experimental)")])]),e._v(" "),a("h3",{attrs:{id:"l3-ml-machine-learning"}},[a("a",{staticClass:"header-anchor",attrs:{href:"#l3-ml-machine-learning"}},[e._v("#")]),e._v(" L3-ML: Machine Learning")]),e._v(" "),a("ul",[a("li",[a("strong",[a("code",[e._v("fit_curve")])]),e._v(" (experimental)")]),e._v(" "),a("li",[a("strong",[a("code",[e._v("fit_regr_random_forest")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("load_ml_model")])]),e._v(" (experimental)")]),e._v(" "),a("li",[a("strong",[a("code",[e._v("predict_curve")])]),e._v(" (experimental)")]),e._v(" "),a("li",[a("strong",[a("code",[e._v("save_ml_model")])]),e._v(" (experimental)")])]),e._v(" "),a("h3",{attrs:{id:"l3-udf-user-defined-functions"}},[a("a",{staticClass:"header-anchor",attrs:{href:"#l3-udf-user-defined-functions"}},[e._v("#")]),e._v(" L3-UDF: User-Defined Functions")]),e._v(" "),a("ul",[a("li",[a("strong",[a("code",[e._v("run_udf")])]),e._v(" "),a("ul",[a("li",[e._v("Parameter "),a("code",[e._v("context")]),e._v(": is supported and passed to the callback")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("run_udf_externally")])]),e._v(" (experimental)")])]),e._v(" "),a("h3",{attrs:{id:"l3-clim-cimatology"}},[a("a",{staticClass:"header-anchor",attrs:{href:"#l3-clim-cimatology"}},[e._v("#")]),e._v(" L3-Clim: Cimatology")]),e._v(" "),a("ul",[a("li",[a("strong",[a("code",[e._v("anomaly")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("climatological_normal")])])])]),e._v(" "),a("h3",{attrs:{id:"l3-ard-analysis-ready-data"}},[a("a",{staticClass:"header-anchor",attrs:{href:"#l3-ard-analysis-ready-data"}},[e._v("#")]),e._v(" L3-ARD: Analysis-Ready Data")]),e._v(" "),a("ul",[a("li",[a("strong",[a("code",[e._v("ard_normalized_radar_backscatter")])]),e._v(" (experimental)\n"),a("ul",[a("li",[e._v("has been tested on > 100x100km at 10m resolution (or equivalent)")]),e._v(" "),a("li",[e._v("Custom parameters are provided via the "),a("code",[e._v("options")]),e._v(" parameter")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("ard_surface_reflectance")])]),e._v(" (experimental)\n"),a("ul",[a("li",[e._v("Parameter "),a("code",[e._v("atmospheric_correction_method")]),e._v(": "),a("code",[e._v("enum")]),e._v(" reflects implemention (all values are supported)")]),e._v(" "),a("li",[e._v("Parameter "),a("code",[e._v("cloud_detection_method")]),e._v(": "),a("code",[e._v("enum")]),e._v(" reflects implemention (all values are supported)")]),e._v(" "),a("li",[e._v("Custom parameters are provided via the "),a("code",[e._v("atmospheric_correction_options")]),e._v(" and/or "),a("code",[e._v("cloud_detection_options")]),e._v(" parameters")])])])]),e._v(" "),a("h3",{attrs:{id:"l4-above-and-beyond"}},[a("a",{staticClass:"header-anchor",attrs:{href:"#l4-above-and-beyond"}},[e._v("#")]),e._v(" L4: Above and Beyond")]),e._v(" "),a("ul",[a("li",[a("strong",[a("code",[e._v("aggregate_spatial")])]),e._v(" "),a("ul",[a("li",[e._v("Parameter "),a("code",[e._v("reducer")]),e._v(": At least all processes (up to the level of this requirement) in the categories "),a("code",[e._v("array")]),e._v(", "),a("code",[e._v("comparison")]),e._v(", "),a("code",[e._v("logic")]),e._v(" and "),a("code",[e._v("math")]),e._v(" can be used (also in a chain of processes).")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("aggregate_temporal")])]),e._v(" "),a("ul",[a("li",[e._v("Parameter "),a("code",[e._v("reducer")]),e._v(": At least all processes (up to the level of this requirement) in the categories "),a("code",[e._v("array")]),e._v(", "),a("code",[e._v("comparison")]),e._v(", "),a("code",[e._v("logic")]),e._v(" and "),a("code",[e._v("math")]),e._v(" can be used (also in a chain of processes).")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("aggregate_temporal_period")])]),e._v(" "),a("ul",[a("li",[e._v("Parameter "),a("code",[e._v("reducer")]),e._v(": At least all processes (up to the level of this requirement) in the categories "),a("code",[e._v("array")]),e._v(", "),a("code",[e._v("comparison")]),e._v(", "),a("code",[e._v("logic")]),e._v(" and "),a("code",[e._v("math")]),e._v(" can be used (also in a chain of processes).")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("apply_neighborhood")])]),e._v(" "),a("ul",[a("li",[e._v("Parameter "),a("code",[e._v("process")]),e._v(": At least all processes (up to the level of this requirement) in the categories "),a("code",[e._v("array")]),e._v(", "),a("code",[e._v("comparison")]),e._v(", "),a("code",[e._v("logic")]),e._v(" and "),a("code",[e._v("math")]),e._v(" can be used (also in a chain of processes).")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("apply_polygon (chunk_polygon)")])]),e._v(" (experimental)")]),e._v(" "),a("li",[a("strong",[a("code",[e._v("array_apply")])]),e._v(" "),a("ul",[a("li",[e._v("Parameter "),a("code",[e._v("process")]),e._v(": At least all processes (up to the level of this requirement) in the categories "),a("code",[e._v("comparison")]),e._v(", "),a("code",[e._v("logic")]),e._v(" and "),a("code",[e._v("math")]),e._v(" can be used (also in a chain of processes).")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("atmospheric_correction")])]),e._v(" (experimental)\n"),a("ul",[a("li",[e._v("Parameter "),a("code",[e._v("method")]),e._v(": "),a("code",[e._v("enum")]),e._v(" reflects implemention (all values are supported)")]),e._v(" "),a("li",[e._v("Custom parameters are provided via the "),a("code",[e._v("options")]),e._v(" parameter")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("filter_bands")])]),e._v(" "),a("ul",[a("li",[e._v("Supports filtering by wavelength")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("filter_bbox")])]),e._v(" "),a("ul",[a("li",[e._v("Parameter "),a("code",[e._v("extent")]),e._v(": Supports filtering by base/height")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("load_collection")])]),e._v(" "),a("ul",[a("li",[e._v("Parameter "),a("code",[e._v("spatial_extent")]),e._v(": Supports filtering by base/height")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("load_stac (load_result)")])]),e._v(" (experimental)\n"),a("ul",[a("li",[e._v("Parameter "),a("code",[e._v("spatial_extent")]),e._v(": Supports filtering by base/height")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("load_uploaded_files")])]),e._v(" (experimental)")]),e._v(" "),a("li",[a("strong",[a("code",[e._v("load_url")])]),e._v(" (experimental)")]),e._v(" "),a("li",[a("strong",[a("code",[e._v("reduce_dimension")])]),e._v(" "),a("ul",[a("li",[e._v("Parameter "),a("code",[e._v("reducer")]),e._v(": At least all processes (up to the level of this requirement) in the categories "),a("code",[e._v("array")]),e._v(", "),a("code",[e._v("comparison")]),e._v(", "),a("code",[e._v("logic")]),e._v(" and "),a("code",[e._v("math")]),e._v(" can be used (also in a chain of processes).")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("reduce_spatial")])]),e._v(" (experimental)\n"),a("ul",[a("li",[e._v("Parameter "),a("code",[e._v("reducer")]),e._v(": At least all processes (up to the level of this requirement) in the categories "),a("code",[e._v("array")]),e._v(", "),a("code",[e._v("comparison")]),e._v(", "),a("code",[e._v("logic")]),e._v(" and "),a("code",[e._v("math")]),e._v(" can be used (also in a chain of processes).")])])]),e._v(" "),a("li",[a("strong",[a("code",[e._v("sar_backscatter")])]),e._v(" (experimental)\n"),a("ul",[a("li",[e._v("Parameter "),a("code",[e._v("coefficient")]),e._v(": "),a("code",[e._v("enum")]),e._v(" reflects implemention (all values are supported)")]),e._v(" "),a("li",[e._v("Custom parameters are provided via the "),a("code",[e._v("options")]),e._v(" parameter")])])])])])}),[],!1,null,null,null);a.default=r.exports}}]); \ No newline at end of file diff --git a/assets/js/46.980033df.js b/assets/js/46.8dfafee3.js similarity index 99% rename from assets/js/46.980033df.js rename to assets/js/46.8dfafee3.js index f3dcffafe..8c460cf1d 100644 --- a/assets/js/46.980033df.js +++ b/assets/js/46.8dfafee3.js @@ -1 +1 @@ -(window.webpackJsonp=window.webpackJsonp||[]).push([[46],{193:function(t,s,a){t.exports=a.p+"assets/img/getting-started-result-example.7820ee84.jpg"},528:function(t,s,a){"use strict";a.r(s);var n=a(4),e=Object(n.a)({},(function(){var t=this,s=t._self._c;return s("ContentSlotsDistributor",{attrs:{"slot-key":t.$parent.slotKey}},[s("h1",{attrs:{id:"javascript-client"}},[s("a",{staticClass:"header-anchor",attrs:{href:"#javascript-client"}},[t._v("#")]),t._v(" JavaScript Client")]),t._v(" "),s("h2",{attrs:{id:"installation"}},[s("a",{staticClass:"header-anchor",attrs:{href:"#installation"}},[t._v("#")]),t._v(" Installation")]),t._v(" "),s("p",[t._v("The openEO JavaScript Client can be used in all modern browsers (excludes Internet Explorer) and all maintained Node.js versions (>= 10.x).\nIt can also been used for mobile app development with the "),s("a",{attrs:{href:"https://ionicframework.com/",target:"_blank",rel:"noopener noreferrer"}},[t._v("Ionic Framework"),s("OutboundLink")],1),t._v(", for example.")]),t._v(" "),s("p",[t._v("The easiest way to try out the client is using one of the "),s("a",{attrs:{href:"https://github.com/Open-EO/openeo-js-client/tree/v2.0.0/examples",target:"_blank",rel:"noopener noreferrer"}},[t._v("examples"),s("OutboundLink")],1),t._v(".\nAlternatively, you can create an HTML file and include the client with the following HTML "),s("code",[t._v("script")]),t._v(" tags:")]),t._v(" "),s("div",{staticClass:"language-html extra-class"},[s("pre",{pre:!0,attrs:{class:"language-html"}},[s("code",[s("span",{pre:!0,attrs:{class:"token tag"}},[s("span",{pre:!0,attrs:{class:"token tag"}},[s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("<")]),t._v("script")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token attr-name"}},[t._v("src")]),s("span",{pre:!0,attrs:{class:"token attr-value"}},[s("span",{pre:!0,attrs:{class:"token punctuation attr-equals"}},[t._v("=")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v('"')]),t._v("https://cdn.jsdelivr.net/npm/axios@0.21/dist/axios.min.js"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v('"')])]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(">")])]),s("span",{pre:!0,attrs:{class:"token script"}}),s("span",{pre:!0,attrs:{class:"token tag"}},[s("span",{pre:!0,attrs:{class:"token tag"}},[s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("")])]),t._v("\n"),s("span",{pre:!0,attrs:{class:"token tag"}},[s("span",{pre:!0,attrs:{class:"token tag"}},[s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("<")]),t._v("script")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token attr-name"}},[t._v("src")]),s("span",{pre:!0,attrs:{class:"token attr-value"}},[s("span",{pre:!0,attrs:{class:"token punctuation attr-equals"}},[t._v("=")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v('"')]),t._v("https://cdn.jsdelivr.net/npm/@openeo/js-client@2/openeo.min.js"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v('"')])]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(">")])]),s("span",{pre:!0,attrs:{class:"token script"}}),s("span",{pre:!0,attrs:{class:"token tag"}},[s("span",{pre:!0,attrs:{class:"token tag"}},[s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("")])]),t._v("\n")])])]),s("p",[t._v("This gives you a minified version for production environments. If you'd like a better development experience, use the following code:")]),t._v(" "),s("div",{staticClass:"language-html extra-class"},[s("pre",{pre:!0,attrs:{class:"language-html"}},[s("code",[s("span",{pre:!0,attrs:{class:"token tag"}},[s("span",{pre:!0,attrs:{class:"token tag"}},[s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("<")]),t._v("script")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token attr-name"}},[t._v("src")]),s("span",{pre:!0,attrs:{class:"token attr-value"}},[s("span",{pre:!0,attrs:{class:"token punctuation attr-equals"}},[t._v("=")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v('"')]),t._v("https://cdn.jsdelivr.net/npm/axios@0.21/dist/axios.js"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v('"')])]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(">")])]),s("span",{pre:!0,attrs:{class:"token script"}}),s("span",{pre:!0,attrs:{class:"token tag"}},[s("span",{pre:!0,attrs:{class:"token tag"}},[s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("")])]),t._v("\n"),s("span",{pre:!0,attrs:{class:"token tag"}},[s("span",{pre:!0,attrs:{class:"token tag"}},[s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("<")]),t._v("script")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token attr-name"}},[t._v("src")]),s("span",{pre:!0,attrs:{class:"token attr-value"}},[s("span",{pre:!0,attrs:{class:"token punctuation attr-equals"}},[t._v("=")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v('"')]),t._v("https://cdn.jsdelivr.net/npm/@openeo/js-client@2/openeo.js"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v('"')])]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(">")])]),s("span",{pre:!0,attrs:{class:"token script"}}),s("span",{pre:!0,attrs:{class:"token tag"}},[s("span",{pre:!0,attrs:{class:"token tag"}},[s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("")])]),t._v("\n")])])]),s("p",[t._v("If you are working on a Node.js application or you are using a Node.js-based build tool for web development (e.g. Webpack), you can install the client via "),s("a",{attrs:{href:"https://npmjs.org/",target:"_blank",rel:"noopener noreferrer"}},[t._v("npm"),s("OutboundLink")],1),t._v(" by using the following command:")]),t._v(" "),s("div",{staticClass:"language-shell script extra-class"},[s("pre",{pre:!0,attrs:{class:"language-shell"}},[s("code",[s("span",{pre:!0,attrs:{class:"token function"}},[t._v("npm")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("install")]),t._v(" @openeo/js-client\n")])])]),s("p",[t._v("Afterwards you can load the library. Depending on whether you are directly working in Node.js or are just using a Node.js build tool, the import can be different. Please inform yourself which import is suited for your project.")]),t._v(" "),s("p",[t._v("This is usually used directly in Node.js:")]),t._v(" "),s("div",{staticClass:"language-js extra-class"},[s("pre",{pre:!0,attrs:{class:"language-js"}},[s("code",[s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("const")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("{")]),t._v(" OpenEO "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("}")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("require")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token string"}},[t._v("'@openeo/js-client'")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(";")]),t._v("\n")])])]),s("p",[t._v("This may be used in build tools such as Webpack:")]),t._v(" "),s("div",{staticClass:"language-js extra-class"},[s("pre",{pre:!0,attrs:{class:"language-js"}},[s("code",[s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("import")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("{")]),t._v(" OpenEO "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("}")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("from")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v("'@openeo/js-client'")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(";")]),t._v("\n")])])]),s("p",[t._v("Now that the installation was successfully finished, we can now connect to openEO compliant back-ends.\nIn the following chapters we quickly walk through the main features of the JavaScript client.")]),t._v(" "),s("p",[t._v("If you have trouble installing the client, feel free to "),s("RouterLink",{attrs:{to:"/contact.html"}},[t._v("contact us")]),t._v(" or leave an issue at the "),s("a",{attrs:{href:"https://github.com/Open-EO/openeo-js-client/issues",target:"_blank",rel:"noopener noreferrer"}},[t._v("GitHub project"),s("OutboundLink")],1),t._v(".")],1),t._v(" "),s("h2",{attrs:{id:"exploring-a-back-end"}},[s("a",{staticClass:"header-anchor",attrs:{href:"#exploring-a-back-end"}},[t._v("#")]),t._v(" Exploring a back-end")]),t._v(" "),s("p",[t._v("If you do not know an openEO back-end that you want to connect to yet, you can have a look at the "),s("a",{attrs:{href:"https://hub.openeo.org/",target:"_blank",rel:"noopener noreferrer"}},[t._v("openEO Hub"),s("OutboundLink")],1),t._v(", to find all known back-ends with information on their capabilities.")]),t._v(" "),s("p",[t._v("For this tutorial we will use the openEO instance of Google Earth Engine, which is available at "),s("code",[t._v("https://earthengine.openeo.org")]),t._v(".\nNote that the code snippets in this guide works the same way for the other back-ends listed in the openEO Hub. Just the collection identifier and band names might differ.")]),t._v(" "),s("p",[t._v("First we need to establish a connection to the back-end.")]),t._v(" "),s("div",{staticClass:"language-js extra-class"},[s("pre",{pre:!0,attrs:{class:"language-js"}},[s("code",[s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("var")]),t._v(" con "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("await")]),t._v(" OpenEO"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("connect")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"https://earthengine.openeo.org"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(";")]),t._v("\n")])])]),s("div",{staticClass:"custom-block tip"},[s("p",{staticClass:"custom-block-title"},[t._v("Note")]),t._v(" "),s("p",[t._v("The JavaScript client uses "),s("a",{attrs:{href:"https://medium.com/jspoint/javascript-promises-and-async-await-as-fast-as-possible-d7c8c8ff0abc",target:"_blank",rel:"noopener noreferrer"}},[t._v("Promises (async/await)"),s("OutboundLink")],1),t._v(". So there are two ways to express the code above:")]),t._v(" "),s("p",[t._v("Promises:")]),t._v(" "),s("div",{staticClass:"language-js extra-class"},[s("pre",{pre:!0,attrs:{class:"language-js"}},[s("code",[t._v("OpenEO"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("connect")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"https://earthengine.openeo.org"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("then")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("function")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token parameter"}},[t._v("con")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("{")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("// Success")]),t._v("\n"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("}")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("catch")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("function")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token parameter"}},[t._v("error")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("{")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("// Error")]),t._v("\n"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("}")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(";")]),t._v("\n")])])]),s("p",[t._v("async/await:")]),t._v(" "),s("div",{staticClass:"language-js extra-class"},[s("pre",{pre:!0,attrs:{class:"language-js"}},[s("code",[s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("try")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("{")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("var")]),t._v(" con "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("await")]),t._v(" OpenEO"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("connect")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"https://earthengine.openeo.org"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(";")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("// Success")]),t._v("\n"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("}")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("catch")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("error"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("{")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("// Error")]),t._v("\n"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("}")]),t._v("\n")])])]),s("p",[t._v("To simplify the code here, we use async/await in all examples and don't catch errors. So we assume you run the code in an async function and also in a try/catch block.")])]),t._v(" "),s("p",[t._v("After establishing the connection to the back-end, it can be explored using the "),s("a",{attrs:{href:"https://open-eo.github.io/openeo-js-client/latest/Connection.html",target:"_blank",rel:"noopener noreferrer"}},[t._v("Connection object"),s("OutboundLink")],1),t._v(" returned. The basic service's metadata (capabilities) can be accessed via")]),t._v(" "),s("div",{staticClass:"language-js extra-class"},[s("pre",{pre:!0,attrs:{class:"language-js"}},[s("code",[s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("var")]),t._v(" info "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" con"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("capabilities")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(";")]),t._v("\n")])])]),s("p",[t._v("This allows to request a couple of "),s("a",{attrs:{href:"https://open-eo.github.io/openeo-js-client/latest/Capabilities.html",target:"_blank",rel:"noopener noreferrer"}},[t._v("different information"),s("OutboundLink")],1),t._v(", like API version, description, related links or the billing plans. You can print some of these information to the console as follows:")]),t._v(" "),s("div",{staticClass:"language-js extra-class"},[s("pre",{pre:!0,attrs:{class:"language-js"}},[s("code",[t._v("console"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("log")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"API Version: "')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" info"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("apiVersion")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(";")]),t._v("\nconsole"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("log")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"Description: "')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" info"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("description")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(";")]),t._v("\n\nconsole"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("log")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"Billing plans:"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(";")]),t._v("\ninfo"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("listPlans")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("forEach")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token parameter"}},[t._v("plan")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=>")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("{")]),t._v("\n console"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("log")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token template-string"}},[s("span",{pre:!0,attrs:{class:"token template-punctuation string"}},[t._v("`")]),s("span",{pre:!0,attrs:{class:"token interpolation"}},[s("span",{pre:!0,attrs:{class:"token interpolation-punctuation punctuation"}},[t._v("${")]),t._v("plan"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),t._v("name"),s("span",{pre:!0,attrs:{class:"token interpolation-punctuation punctuation"}},[t._v("}")])]),s("span",{pre:!0,attrs:{class:"token string"}},[t._v(": ")]),s("span",{pre:!0,attrs:{class:"token interpolation"}},[s("span",{pre:!0,attrs:{class:"token interpolation-punctuation punctuation"}},[t._v("${")]),t._v("plan"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),t._v("url"),s("span",{pre:!0,attrs:{class:"token interpolation-punctuation punctuation"}},[t._v("}")])]),s("span",{pre:!0,attrs:{class:"token template-punctuation string"}},[t._v("`")])]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(";")]),t._v("\n"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("}")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(";")]),t._v("\n\nconsole"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("log")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"Related links:"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(";")]),t._v("\ninfo"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("links")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("forEach")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token parameter"}},[t._v("link")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=>")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("{")]),t._v("\n console"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("log")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token template-string"}},[s("span",{pre:!0,attrs:{class:"token template-punctuation string"}},[t._v("`")]),s("span",{pre:!0,attrs:{class:"token interpolation"}},[s("span",{pre:!0,attrs:{class:"token interpolation-punctuation punctuation"}},[t._v("${")]),t._v("link"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),t._v("title"),s("span",{pre:!0,attrs:{class:"token interpolation-punctuation punctuation"}},[t._v("}")])]),s("span",{pre:!0,attrs:{class:"token string"}},[t._v(": ")]),s("span",{pre:!0,attrs:{class:"token interpolation"}},[s("span",{pre:!0,attrs:{class:"token interpolation-punctuation punctuation"}},[t._v("${")]),t._v("link"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),t._v("href"),s("span",{pre:!0,attrs:{class:"token interpolation-punctuation punctuation"}},[t._v("}")])]),s("span",{pre:!0,attrs:{class:"token template-punctuation string"}},[t._v("`")])]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(";")]),t._v("\n"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("}")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(";")]),t._v("\n")])])]),s("h3",{attrs:{id:"collections"}},[s("a",{staticClass:"header-anchor",attrs:{href:"#collections"}},[t._v("#")]),t._v(" Collections")]),t._v(" "),s("p",[t._v("Collections represent the basic data the back-end provides (e.g. Sentinel 2 collection).\nCollections are used as input data for job executions ("),s("RouterLink",{attrs:{to:"/documentation/1.0/glossary.html#eo-data-collections"}},[t._v("more info on collections")]),t._v(").\nWith the following code snippet you can print all 400+ available collection names and their summary.")],1),t._v(" "),s("div",{staticClass:"language-js extra-class"},[s("pre",{pre:!0,attrs:{class:"language-js"}},[s("code",[t._v("console"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("log")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"Available Collections:"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(";")]),t._v("\n"),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("var")]),t._v(" response "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("await")]),t._v(" con"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("listCollections")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(";")]),t._v("\nresponse"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),t._v("collections"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("forEach")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token parameter"}},[t._v("collection")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=>")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("{")]),t._v("\n console"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("log")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token template-string"}},[s("span",{pre:!0,attrs:{class:"token template-punctuation string"}},[t._v("`")]),s("span",{pre:!0,attrs:{class:"token interpolation"}},[s("span",{pre:!0,attrs:{class:"token interpolation-punctuation punctuation"}},[t._v("${")]),t._v("collection"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),t._v("id"),s("span",{pre:!0,attrs:{class:"token interpolation-punctuation punctuation"}},[t._v("}")])]),s("span",{pre:!0,attrs:{class:"token string"}},[t._v(": ")]),s("span",{pre:!0,attrs:{class:"token interpolation"}},[s("span",{pre:!0,attrs:{class:"token interpolation-punctuation punctuation"}},[t._v("${")]),t._v("collection"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),t._v("summary"),s("span",{pre:!0,attrs:{class:"token interpolation-punctuation punctuation"}},[t._v("}")])]),s("span",{pre:!0,attrs:{class:"token template-punctuation string"}},[t._v("`")])]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(";")]),t._v("\n"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("}")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(";")]),t._v("\n")])])]),s("p",[t._v("To get detailed information about a single collection, you can pass any of the collection IDs requested earlier to "),s("code",[t._v("describeCollection")]),t._v(" and get a full object of "),s("a",{attrs:{href:"https://github.com/radiantearth/stac-spec/tree/v1.0.0/collection-spec/collection-spec.md",target:"_blank",rel:"noopener noreferrer"}},[t._v("STAC compliant Collection metadata"),s("OutboundLink")],1),t._v(" back.\nIn this example we request information about the Sentinel-2 Level 1C data from Google:")]),t._v(" "),s("div",{staticClass:"language-js extra-class"},[s("pre",{pre:!0,attrs:{class:"language-js"}},[s("code",[t._v("console"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("log")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("await")]),t._v(" con"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("describeCollection")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"COPERNICUS/S2"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(";")]),t._v("\n")])])]),s("p",[t._v("The collections descriptions returned by "),s("code",[t._v("listCollections")]),t._v(" are usually not complete. To get the full set of metadata you should always use "),s("code",[t._v("describeCollection")]),t._v(".")]),t._v(" "),s("h3",{attrs:{id:"processes"}},[s("a",{staticClass:"header-anchor",attrs:{href:"#processes"}},[t._v("#")]),t._v(" Processes")]),t._v(" "),s("p",[t._v("Processes in openEO are small tasks that can be applied on (EO) data.\nThe input of a process might be the output of another process, so that several connected processes form a new (user-defined) process itself.\nTherefore, a process resembles the smallest unit of task descriptions in openEO ("),s("RouterLink",{attrs:{to:"/documentation/1.0/glossary.html#processes"}},[t._v("more details on processes")]),t._v(").\nWith the following code snippet you can print all available process IDs and their summaries.")],1),t._v(" "),s("div",{staticClass:"language-js extra-class"},[s("pre",{pre:!0,attrs:{class:"language-js"}},[s("code",[t._v("console"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("log")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"Available Collections:"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(";")]),t._v("\n"),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("var")]),t._v(" response "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("await")]),t._v(" con"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("listProcesses")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(";")]),t._v("\nresponse"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),t._v("processes"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("forEach")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token parameter"}},[t._v("process")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=>")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("{")]),t._v("\n console"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("log")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token template-string"}},[s("span",{pre:!0,attrs:{class:"token template-punctuation string"}},[t._v("`")]),s("span",{pre:!0,attrs:{class:"token interpolation"}},[s("span",{pre:!0,attrs:{class:"token interpolation-punctuation punctuation"}},[t._v("${")]),t._v("process"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),t._v("id"),s("span",{pre:!0,attrs:{class:"token interpolation-punctuation punctuation"}},[t._v("}")])]),s("span",{pre:!0,attrs:{class:"token string"}},[t._v(": ")]),s("span",{pre:!0,attrs:{class:"token interpolation"}},[s("span",{pre:!0,attrs:{class:"token interpolation-punctuation punctuation"}},[t._v("${")]),t._v("process"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),t._v("summary"),s("span",{pre:!0,attrs:{class:"token interpolation-punctuation punctuation"}},[t._v("}")])]),s("span",{pre:!0,attrs:{class:"token template-punctuation string"}},[t._v("`")])]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(";")]),t._v("\n"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("}")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(";")]),t._v("\n")])])]),s("p",[t._v("In contrast to the collections, the process descriptions returned by "),s("code",[t._v("listProcesses")]),t._v(" are complete.\nThere's no need to call "),s("code",[t._v("describeProcess")]),t._v(" to get the full set of metadata.\n"),s("code",[t._v("describeProcess")]),t._v(" is just a convenience function to get a single process from "),s("code",[t._v("listProcesses")]),t._v(".\nIn this example we request the process specification for the "),s("code",[t._v("apply")]),t._v(" process:")]),t._v(" "),s("div",{staticClass:"language-js extra-class"},[s("pre",{pre:!0,attrs:{class:"language-js"}},[s("code",[t._v("console"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("log")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("await")]),t._v(" con"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("describeProcess")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"apply"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(";")]),t._v("\n")])])]),s("p",[t._v("For a graphical overview of the openEO processes, there is an "),s("RouterLink",{attrs:{to:"/documentation/1.0/processes.html"}},[t._v("online documentation")]),t._v(" for general process descriptions and the "),s("a",{attrs:{href:"https://hub.openeo.org/",target:"_blank",rel:"noopener noreferrer"}},[t._v("openEO Hub"),s("OutboundLink")],1),t._v(" for back-end specific process descriptions.")],1),t._v(" "),s("h2",{attrs:{id:"authentication"}},[s("a",{staticClass:"header-anchor",attrs:{href:"#authentication"}},[t._v("#")]),t._v(" Authentication")]),t._v(" "),s("p",[t._v("In the code snippets above, authentication is usually not necessary, since we only fetch general information about the back-end.\nTo run your own jobs at the back-end or to access job results, you need to authenticate at the back-end.")]),t._v(" "),s("p",[t._v("Depending on the back-end, there might be two different approaches to authenticate.\nYou need to inform yourself at your back-end provider of choice, which authentication approach you have to carry out.\nYou can also have a look at the "),s("a",{attrs:{href:"https://hub.openeo.org/",target:"_blank",rel:"noopener noreferrer"}},[t._v("openEO Hub"),s("OutboundLink")],1),t._v(" to see the available authentication types of the back-ends.")]),t._v(" "),s("div",{staticClass:"custom-block tip"},[s("p",{staticClass:"custom-block-title"},[t._v("Recommendation")]),t._v(" "),s("p",[t._v("The Google Earth Engine implementation for openEO only supports Basic authentication, but generally the preferred authentication method is "),s("a",{attrs:{href:"#openid-connect-authentication"}},[t._v("OpenID Connect")]),t._v(" due to better security mechanisms implemented in the OpenID Connect protocol.")])]),t._v(" "),s("h3",{attrs:{id:"basic-authentication"}},[s("a",{staticClass:"header-anchor",attrs:{href:"#basic-authentication"}},[t._v("#")]),t._v(" Basic Authentication")]),t._v(" "),s("p",[t._v("The Basic authentication method is a common way of authenticate HTTP requests given username and password.")]),t._v(" "),s("p",[t._v("The following code snippet shows how to log in via Basic authentication:")]),t._v(" "),s("div",{staticClass:"language-js extra-class"},[s("pre",{pre:!0,attrs:{class:"language-js"}},[s("code",[s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("await")]),t._v(" con"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("authenticateBasic")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"username"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"password"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(";")]),t._v("\n")])])]),s("div",{staticClass:"custom-block tip"},[s("p",{staticClass:"custom-block-title"},[t._v("TIP")]),t._v(" "),s("p",[t._v("You can get username and password here: "),s("a",{attrs:{href:"https://github.com/Open-EO/openeo-earthengine-driver#demo",target:"_blank",rel:"noopener noreferrer"}},[t._v("https://github.com/Open-EO/openeo-earthengine-driver#demo"),s("OutboundLink")],1)])]),t._v(" "),s("p",[t._v("After successfully calling the "),s("code",[t._v("authenticateBasic")]),t._v(" method, you are logged into the back-end with your account.\nThis means, that every call that comes after that via the "),s("code",[t._v("con")]),t._v(" variable is executed by your user account.")]),t._v(" "),s("h3",{attrs:{id:"openid-connect-authentication"}},[s("a",{staticClass:"header-anchor",attrs:{href:"#openid-connect-authentication"}},[t._v("#")]),t._v(" OpenID Connect Authentication")]),t._v(" "),s("div",{staticClass:"custom-block warning"},[s("p",{staticClass:"custom-block-title"},[t._v("WARNING")]),t._v(" "),s("p",[t._v("For Google Earth Engine, only "),s("a",{attrs:{href:"#basic-authentication"}},[t._v("Basic Authentication")]),t._v(" is supported at the moment.")])]),t._v(" "),s("p",[t._v("The OIDC ("),s("a",{attrs:{href:"https://openid.net/connect/",target:"_blank",rel:"noopener noreferrer"}},[t._v("OpenID Connect"),s("OutboundLink")],1),t._v(") authentication can be used to authenticate via an external service given a client ID.")]),t._v(" "),s("div",{staticClass:"custom-block warning"},[s("p",{staticClass:"custom-block-title"},[t._v("Important")]),t._v(" "),s("p",[t._v("If you have included the library using HTML "),s("code",[t._v("script")]),t._v(" tags, then you need to include the following OIDC client before the openEO client:")]),t._v(" "),s("div",{staticClass:"language-html extra-class"},[s("pre",{pre:!0,attrs:{class:"language-html"}},[s("code",[s("span",{pre:!0,attrs:{class:"token tag"}},[s("span",{pre:!0,attrs:{class:"token tag"}},[s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("<")]),t._v("script")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token attr-name"}},[t._v("src")]),s("span",{pre:!0,attrs:{class:"token attr-value"}},[s("span",{pre:!0,attrs:{class:"token punctuation attr-equals"}},[t._v("=")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v('"')]),t._v("https://cdn.jsdelivr.net/npm/oidc-client@1/lib/oidc-client.min.js"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v('"')])]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(">")])]),s("span",{pre:!0,attrs:{class:"token script"}}),s("span",{pre:!0,attrs:{class:"token tag"}},[s("span",{pre:!0,attrs:{class:"token tag"}},[s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("")])]),t._v("\n")])])]),s("p",[t._v("No further action is required, if you have installed the client via npm.")])]),t._v(" "),s("p",[t._v("As OpenID Connect authentication is a bit more complex and depends on the environment your are using it in, please refer to the "),s("a",{attrs:{href:"https://open-eo.github.io/openeo-js-client/latest/OidcProvider.html",target:"_blank",rel:"noopener noreferrer"}},[t._v("JavaScript client documentation"),s("OutboundLink")],1),t._v(" for more information.")]),t._v(" "),s("h2",{attrs:{id:"creating-a-user-defined-process"}},[s("a",{staticClass:"header-anchor",attrs:{href:"#creating-a-user-defined-process"}},[t._v("#")]),t._v(" Creating a (user-defined) process")]),t._v(" "),s("p",[t._v("Now that we know how to discover the back-end and how to authenticate, lets continue by creating a new batch job to process some data.\nFirst we need to create a user-defined process and for that a process builder is the easiest method.")]),t._v(" "),s("div",{staticClass:"language-js extra-class"},[s("pre",{pre:!0,attrs:{class:"language-js"}},[s("code",[s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("var")]),t._v(" builder "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("await")]),t._v(" con"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("buildProcess")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(";")]),t._v("\n")])])]),s("p",[t._v("With the builder, a "),s("RouterLink",{attrs:{to:"/documentation/1.0/glossary.html#spatial-datacubes"}},[t._v("datacube")]),t._v(" can be initialized by selecting a collection from the back-end with the process "),s("code",[t._v("load_collection")]),t._v(":")],1),t._v(" "),s("div",{staticClass:"language-js extra-class"},[s("pre",{pre:!0,attrs:{class:"language-js"}},[s("code",[s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("var")]),t._v(" datacube "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" builder"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("load_collection")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"COPERNICUS/S1_GRD"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("{")]),s("span",{pre:!0,attrs:{class:"token literal-property property"}},[t._v("west")]),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v(":")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("16.06")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token literal-property property"}},[t._v("south")]),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v(":")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("48.06")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token literal-property property"}},[t._v("east")]),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v(":")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("16.65")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token literal-property property"}},[t._v("north")]),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v(":")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("48.35")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("}")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"2017-03-01"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"2017-04-01"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"VV"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"VH"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),t._v("\n"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(";")]),t._v("\n")])])]),s("p",[t._v('This results in a datacube containing the "COPERNICUS/S1_GRD" data restricted to the given spatial extent, the given temporal extend and the given bands .')]),t._v(" "),s("div",{staticClass:"custom-block tip"},[s("p",{staticClass:"custom-block-title"},[t._v("TIP")]),t._v(" "),s("p",[t._v("You can also filter the datacube at a later stage by using the following filter methods:")]),t._v(" "),s("div",{staticClass:"language-js extra-class"},[s("pre",{pre:!0,attrs:{class:"language-js"}},[s("code",[t._v("datacube "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" builder"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("filter_bbox")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("datacube"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("{")]),s("span",{pre:!0,attrs:{class:"token literal-property property"}},[t._v("west")]),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v(":")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("16.06")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token literal-property property"}},[t._v("south")]),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v(":")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("48.06")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token literal-property property"}},[t._v("east")]),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v(":")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("16.65")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token literal-property property"}},[t._v("north")]),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v(":")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("48.35")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("}")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(";")]),t._v("\ndatacube "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" builder"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("filter_temporal")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("datacube"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"2017-03-01"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"2017-04-01"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(";")]),t._v("\ndatacube "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" builder"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("filter_bands")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("datacube"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"VV"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"VH"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(";")]),t._v("\n")])])]),s("p",[t._v("Still, it is recommended to always use the filters in "),s("code",[t._v("load_collection")]),t._v(" to avoid loading too much data upfront.")])]),t._v(" "),s("p",[t._v("Having the input data ready, we want to apply a process on the datacube, which returns a datacube with the process applied:")]),t._v(" "),s("div",{staticClass:"language-js extra-class"},[s("pre",{pre:!0,attrs:{class:"language-js"}},[s("code",[s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("var")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token function-variable function"}},[t._v("min")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("function")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token parameter"}},[t._v("data")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("{")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("return")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("this")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("min")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("data"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(";")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("}")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(";")]),t._v("\ndatacube "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" builder"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("reduce_dimension")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("datacube"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" min"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"t"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(";")]),t._v("\n")])])]),s("p",[t._v("The datacube is now reduced by the time dimension named "),s("code",[t._v("t")]),t._v(', by taking the minimum value of the timeseries values.\nNow the datacube has no time dimension left.\nOther so called "reducer" processes exist, e.g. for computing maximum and mean values.')]),t._v(" "),s("div",{staticClass:"custom-block tip"},[s("p",{staticClass:"custom-block-title"},[t._v("Note")]),t._v(" "),s("p",[t._v("Everything applied to the datacube at this point is neither executed locally on your machine nor executed on the back-end.\nIt just defines the input data and process chain the back-end needs to apply when it sends the datacube to the back-end and executes it there.\nHow this can be done is the topic of the next chapter.")])]),t._v(" "),s("p",[t._v("After applying all processes you want to execute, we need to tell the back-end to export the datacube, for example as GeoTiff:")]),t._v(" "),s("div",{staticClass:"language-js extra-class"},[s("pre",{pre:!0,attrs:{class:"language-js"}},[s("code",[s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("var")]),t._v(" result "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" builder"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("save_result")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("datacube"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"GTiff"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(";")]),t._v("\n")])])]),s("h2",{attrs:{id:"batch-job-management"}},[s("a",{staticClass:"header-anchor",attrs:{href:"#batch-job-management"}},[t._v("#")]),t._v(" Batch Job Management")]),t._v(" "),s("p",[t._v("After you finished working on your (user-defined) process, we can now send it to the back-end and start the execution.\nIn openEO, an execution of a (user-defined) process (here defined using the process builder) is called a "),s("RouterLink",{attrs:{to:"/documentation/1.0/glossary.html#data-processing-modes"}},[t._v("(batch) job")]),t._v(".\nTherefore, we need to create a job at the back-end using our datacube, giving it the title "),s("code",[t._v("Example Title")]),t._v(".")],1),t._v(" "),s("div",{staticClass:"language-js extra-class"},[s("pre",{pre:!0,attrs:{class:"language-js"}},[s("code",[s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("var")]),t._v(" job "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("await")]),t._v(" con"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("createJob")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("result"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"Example Title"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(";")]),t._v("\n")])])]),s("p",[t._v("The "),s("code",[t._v("createJob")]),t._v(" method sends all necessary information to the back-end and creates a new job, which gets returned.\nAfter this, the job is just created, but has not started the execution at the back-end yet.\nIt needs to be queued for processing explicitly:")]),t._v(" "),s("div",{staticClass:"language-js extra-class"},[s("pre",{pre:!0,attrs:{class:"language-js"}},[s("code",[s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("await")]),t._v(" job"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("startJob")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(";")]),t._v("\n")])])]),s("p",[t._v("Now the execution of the job can be monitored by requesting the job status and the log files every once in a while (30 seconds in this example):")]),t._v(" "),s("div",{staticClass:"language-js extra-class"},[s("pre",{pre:!0,attrs:{class:"language-js"}},[s("code",[s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("let")]),t._v(" stopFn "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" job"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("monitorJob")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token parameter"}},[t._v("job"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" logs")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=>")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("{")]),t._v("\n console"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("log")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("job"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),t._v("status"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(";")]),t._v("\n logs"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("forEach")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token parameter"}},[t._v("log")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=>")]),t._v(" console"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("log")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token template-string"}},[s("span",{pre:!0,attrs:{class:"token template-punctuation string"}},[t._v("`")]),s("span",{pre:!0,attrs:{class:"token interpolation"}},[s("span",{pre:!0,attrs:{class:"token interpolation-punctuation punctuation"}},[t._v("${")]),t._v("log"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),t._v("level"),s("span",{pre:!0,attrs:{class:"token interpolation-punctuation punctuation"}},[t._v("}")])]),s("span",{pre:!0,attrs:{class:"token string"}},[t._v(": ")]),s("span",{pre:!0,attrs:{class:"token interpolation"}},[s("span",{pre:!0,attrs:{class:"token interpolation-punctuation punctuation"}},[t._v("${")]),t._v("log"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),t._v("message"),s("span",{pre:!0,attrs:{class:"token interpolation-punctuation punctuation"}},[t._v("}")])]),s("span",{pre:!0,attrs:{class:"token template-punctuation string"}},[t._v("`")])]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(";")]),t._v("\n"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("}")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("30")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(";")]),t._v("\n")])])]),s("p",[t._v("The monitoring stops automatically once the job has finished, was canceled or errored out.\nBut with the return value of the "),s("code",[t._v("monitorJob")]),t._v(" function, you can also stop monitoring the job manually:")]),t._v(" "),s("div",{staticClass:"language-js extra-class"},[s("pre",{pre:!0,attrs:{class:"language-js"}},[s("code",[s("span",{pre:!0,attrs:{class:"token function"}},[t._v("stopFn")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(";")]),t._v("\n")])])]),s("p",[t._v("When the job is finished, calling "),s("code",[t._v("listResults")]),t._v(" gets you the URLs to the results.")]),t._v(" "),s("div",{staticClass:"language-js extra-class"},[s("pre",{pre:!0,attrs:{class:"language-js"}},[s("code",[s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("var")]),t._v(" urls "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("await")]),t._v(" job"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("listResults")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(";")]),t._v("\n")])])]),s("div",{staticClass:"custom-block tip"},[s("p",{staticClass:"custom-block-title"},[t._v("TIP")]),t._v(" "),s("p",[t._v("This only works if the job execution has finished.\nWe recommend to use "),s("code",[t._v("listResults")]),t._v(" in combination with "),s("code",[t._v("monitorJob")]),t._v(", for example as follows:")]),t._v(" "),s("div",{staticClass:"language-js extra-class"},[s("pre",{pre:!0,attrs:{class:"language-js"}},[s("code",[s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("let")]),t._v(" stopFn "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" job"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("monitorJob")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("async")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token parameter"}},[t._v("job"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" logs")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=>")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("{")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("if")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("job"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),t._v("status "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("===")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"finished"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("{")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("var")]),t._v(" urls "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("await")]),t._v(" job"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("listResults")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(";")]),t._v("\n urls"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("forEach")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token parameter"}},[t._v("url")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=>")]),t._v(" console"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("log")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token template-string"}},[s("span",{pre:!0,attrs:{class:"token template-punctuation string"}},[t._v("`")]),s("span",{pre:!0,attrs:{class:"token string"}},[t._v("Download result from: ")]),s("span",{pre:!0,attrs:{class:"token interpolation"}},[s("span",{pre:!0,attrs:{class:"token interpolation-punctuation punctuation"}},[t._v("${")]),t._v("url"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),t._v("href"),s("span",{pre:!0,attrs:{class:"token interpolation-punctuation punctuation"}},[t._v("}")])]),s("span",{pre:!0,attrs:{class:"token template-punctuation string"}},[t._v("`")])]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(";")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("}")]),t._v("\n"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("}")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(";")]),t._v("\n")])])])]),t._v(" "),s("div",{staticClass:"custom-block tip"},[s("p",{staticClass:"custom-block-title"},[t._v("Note")]),t._v(" "),s("p",[t._v("There's also the method "),s("code",[t._v("downloadResults")]),t._v(" to download the results directly.\nUnfortunately, you can only download files from a Node.js environment where file access to your local drive is possible.\nIn a Browser environment, it is also an option to download the STAC Item or Collection for the results using the "),s("code",[t._v("getResultsAsStac")]),t._v(" method and point a "),s("a",{attrs:{href:"https://stacindex.org/ecosystem?category=Client",target:"_blank",rel:"noopener noreferrer"}},[t._v("STAC client"),s("OutboundLink")],1),t._v(" to it for downloading.")])]),t._v(" "),s("p",[t._v("Now you know the general workflow of job executions.")]),t._v(" "),s("h2",{attrs:{id:"full-example"}},[s("a",{staticClass:"header-anchor",attrs:{href:"#full-example"}},[t._v("#")]),t._v(" Full Example")]),t._v(" "),s("p",[t._v("In this chapter we will show a full example of an earth observation use case using the JavaScript client in a Node.js environment and the Google Earth Engine back-end.\nInstead of batch job processing, we compute the image synchronously. Synchronous processing means the result is directly returned in the response, which usually works only for smaller amounts of data.")]),t._v(" "),s("div",{staticClass:"custom-block tip"},[s("p",{staticClass:"custom-block-title"},[t._v("Use Case")]),t._v(" "),s("p",[t._v("We want to produce a monthly RGB composite of Sentinel 1 backscatter data over the area of Vienna, Austria for three\nmonths in 2017. This can be used for classification and crop monitoring.")])]),t._v(" "),s("p",[t._v("In the following code example, we use inline code comments to describe what we are doing.")]),t._v(" "),s("div",{staticClass:"custom-block warning"},[s("p",{staticClass:"custom-block-title"},[t._v("WARNING")]),t._v(" "),s("p",[t._v("The username and password in the example above work at the time of writing, but may be invalid at the time you read this. Please "),s("RouterLink",{attrs:{to:"/contact.html"}},[t._v("contact us")]),t._v(" for credentials.")],1)]),t._v(" "),s("div",{staticClass:"language-js extra-class"},[s("pre",{pre:!0,attrs:{class:"language-js"}},[s("code",[s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("// Make the client available to the Node.js script")]),t._v("\n"),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("// Also include the Formula library for simple math expressions")]),t._v("\n"),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("const")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("{")]),t._v(" OpenEO"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" Formula "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("}")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("require")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token string"}},[t._v("'@openeo/js-client'")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(";")]),t._v("\n\n"),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("async")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("function")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("example")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("{")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("// Connect to the back-end")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("var")]),t._v(" con "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("await")]),t._v(" OpenEO"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("connect")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"https://earthengine.openeo.org"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(";")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("// Authenticate ourselves via Basic authentication")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("await")]),t._v(" con"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("authenticateBasic")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"group11"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"test123"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(";")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("// Create a process builder")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("var")]),t._v(" builder "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("await")]),t._v(" con"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("buildProcess")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(";")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("// We are now loading the Sentinel-1 data over the Area of Interest")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("var")]),t._v(" datacube "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" builder"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("load_collection")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"COPERNICUS/S1_GRD"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("{")]),s("span",{pre:!0,attrs:{class:"token literal-property property"}},[t._v("west")]),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v(":")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("16.06")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token literal-property property"}},[t._v("south")]),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v(":")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("48.06")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token literal-property property"}},[t._v("east")]),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v(":")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("16.65")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token literal-property property"}},[t._v("north")]),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v(":")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("48.35")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("}")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"2017-03-01"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"2017-06-01"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"VV"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(";")]),t._v("\n\n "),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("// Since we are creating a monthly RGB composite, we need three separated time ranges (March aas R, April as G and May as G).")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("// Therefore, we split the datacube into three datacubes using a temporal filter.")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("var")]),t._v(" march "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" builder"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("filter_temporal")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("datacube"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"2017-03-01"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"2017-04-01"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(";")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("var")]),t._v(" april "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" builder"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("filter_temporal")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("datacube"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"2017-04-01"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"2017-05-01"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(";")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("var")]),t._v(" may "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" builder"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("filter_temporal")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("datacube"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"2017-05-01"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"2017-06-01"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(";")]),t._v("\n\n "),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("// We aggregate the timeseries values into a single image by reducing the time dimension using a mean reducer.")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("var")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token function-variable function"}},[t._v("mean")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("function")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token parameter"}},[t._v("data")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("{")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("return")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("this")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("mean")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("data"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(";")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("}")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(";")]),t._v("\n march "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" builder"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("reduce_dimension")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("march"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" mean"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"t"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(";")]),t._v("\n april "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" builder"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("reduce_dimension")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("april"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" mean"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"t"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(";")]),t._v("\n may "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" builder"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("reduce_dimension")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("may"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" mean"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"t"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(";")]),t._v("\n\n "),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("// Now the three images will be combined into the temporal composite.")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("// We rename the bands to R, G and B as otherwise the bands are overlapping and the merge process would fail.")]),t._v("\n march "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" builder"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("rename_labels")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("march"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"bands"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"R"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"VV"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(";")]),t._v("\n april "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" builder"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("rename_labels")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("april"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"bands"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"G"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"VV"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(";")]),t._v("\n may "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" builder"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("rename_labels")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("may"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"bands"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"B"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"VV"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(";")]),t._v("\n\n datacube "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" builder"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("merge_cubes")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("march"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" april"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(";")]),t._v("\n datacube "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" builder"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("merge_cubes")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("datacube"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" may"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(";")]),t._v("\n\n "),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("// To make the values match the RGB values from 0 to 255 in a PNG file, we need to scale them.")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("// We can simplify expressing math formulas using the openEO Formula parser.")]),t._v("\n datacube "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("builder")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("apply")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("datacube"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("new")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token class-name"}},[t._v("Formula")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"linear_scale_range(x, -20, -5, 0, 255)"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(";")]),t._v("\n\n "),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("// Finally, save the result as PNG file.")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v('// In the options we specify which band should be used for "red", "green" and "blue" color.')]),t._v("\n datacube "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" builder"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("save_result")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("datacube"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"PNG"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("{")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token literal-property property"}},[t._v("red")]),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v(":")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"R"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token literal-property property"}},[t._v("green")]),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v(":")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"G"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token literal-property property"}},[t._v("blue")]),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v(":")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"B"')]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("}")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(";")]),t._v("\n\n "),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("// Now send the processing instructions to the back-end for (synchronous) execution and save the file as result.png")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("await")]),t._v(" con"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("downloadResult")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("datacube"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"result.png"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(";")]),t._v("\n"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("}")]),t._v("\n\n"),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("// Run the example, write errors to the console.")]),t._v("\n"),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("example")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("catch")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token parameter"}},[t._v("error")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=>")]),t._v(" console"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("error")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("error"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(";")]),t._v("\n")])])]),s("p",[t._v("Now the resulting PNG file of the RGB backscatter composite is stored as "),s("code",[t._v("result.png")]),t._v(" in the node.JS working directory and should look as follows:")]),t._v(" "),s("p",[s("img",{attrs:{src:a(193),alt:"RGB composite"}})]),t._v(" "),s("h2",{attrs:{id:"user-defined-functions"}},[s("a",{staticClass:"header-anchor",attrs:{href:"#user-defined-functions"}},[t._v("#")]),t._v(" User Defined Functions")]),t._v(" "),s("p",[t._v("If your use case can not be accomplished with the "),s("RouterLink",{attrs:{to:"/documentation/1.0/processes.html"}},[t._v("default processes")]),t._v(" of openEO, you can define a "),s("RouterLink",{attrs:{to:"/documentation/1.0/glossary.html#user-defined-function-udf"}},[t._v("user defined function")]),t._v(".\nUnfortunately, you can only create Python and R functions at the moment.\nTherefore, this guide doesn't get into detail.\nFor more information check out the Python or R tutorials on UDFs.")],1),t._v(" "),s("h2",{attrs:{id:"additional-information"}},[s("a",{staticClass:"header-anchor",attrs:{href:"#additional-information"}},[t._v("#")]),t._v(" Additional Information")]),t._v(" "),s("ul",[s("li",[s("a",{attrs:{href:"https://github.com/Open-EO/openeo-js-client/tree/master/examples",target:"_blank",rel:"noopener noreferrer"}},[t._v("Examples"),s("OutboundLink")],1)]),t._v(" "),s("li",[s("a",{attrs:{href:"https://open-eo.github.io/openeo-js-client/latest/",target:"_blank",rel:"noopener noreferrer"}},[t._v("Documentation"),s("OutboundLink")],1)]),t._v(" "),s("li",[s("a",{attrs:{href:"https://github.com/Open-EO/openeo-js-client",target:"_blank",rel:"noopener noreferrer"}},[t._v("Repository"),s("OutboundLink")],1)])])])}),[],!1,null,null,null);s.default=e.exports}}]); \ No newline at end of file +(window.webpackJsonp=window.webpackJsonp||[]).push([[46],{193:function(t,s,a){t.exports=a.p+"assets/img/getting-started-result-example.7820ee84.jpg"},527:function(t,s,a){"use strict";a.r(s);var n=a(4),e=Object(n.a)({},(function(){var t=this,s=t._self._c;return s("ContentSlotsDistributor",{attrs:{"slot-key":t.$parent.slotKey}},[s("h1",{attrs:{id:"javascript-client"}},[s("a",{staticClass:"header-anchor",attrs:{href:"#javascript-client"}},[t._v("#")]),t._v(" JavaScript Client")]),t._v(" "),s("h2",{attrs:{id:"installation"}},[s("a",{staticClass:"header-anchor",attrs:{href:"#installation"}},[t._v("#")]),t._v(" Installation")]),t._v(" "),s("p",[t._v("The openEO JavaScript Client can be used in all modern browsers (excludes Internet Explorer) and all maintained Node.js versions (>= 10.x).\nIt can also been used for mobile app development with the "),s("a",{attrs:{href:"https://ionicframework.com/",target:"_blank",rel:"noopener noreferrer"}},[t._v("Ionic Framework"),s("OutboundLink")],1),t._v(", for example.")]),t._v(" "),s("p",[t._v("The easiest way to try out the client is using one of the "),s("a",{attrs:{href:"https://github.com/Open-EO/openeo-js-client/tree/v2.0.0/examples",target:"_blank",rel:"noopener noreferrer"}},[t._v("examples"),s("OutboundLink")],1),t._v(".\nAlternatively, you can create an HTML file and include the client with the following HTML "),s("code",[t._v("script")]),t._v(" tags:")]),t._v(" "),s("div",{staticClass:"language-html extra-class"},[s("pre",{pre:!0,attrs:{class:"language-html"}},[s("code",[s("span",{pre:!0,attrs:{class:"token tag"}},[s("span",{pre:!0,attrs:{class:"token tag"}},[s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("<")]),t._v("script")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token attr-name"}},[t._v("src")]),s("span",{pre:!0,attrs:{class:"token attr-value"}},[s("span",{pre:!0,attrs:{class:"token punctuation attr-equals"}},[t._v("=")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v('"')]),t._v("https://cdn.jsdelivr.net/npm/axios@0.21/dist/axios.min.js"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v('"')])]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(">")])]),s("span",{pre:!0,attrs:{class:"token script"}}),s("span",{pre:!0,attrs:{class:"token tag"}},[s("span",{pre:!0,attrs:{class:"token tag"}},[s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("")])]),t._v("\n"),s("span",{pre:!0,attrs:{class:"token tag"}},[s("span",{pre:!0,attrs:{class:"token tag"}},[s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("<")]),t._v("script")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token attr-name"}},[t._v("src")]),s("span",{pre:!0,attrs:{class:"token attr-value"}},[s("span",{pre:!0,attrs:{class:"token punctuation attr-equals"}},[t._v("=")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v('"')]),t._v("https://cdn.jsdelivr.net/npm/@openeo/js-client@2/openeo.min.js"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v('"')])]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(">")])]),s("span",{pre:!0,attrs:{class:"token script"}}),s("span",{pre:!0,attrs:{class:"token tag"}},[s("span",{pre:!0,attrs:{class:"token tag"}},[s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("")])]),t._v("\n")])])]),s("p",[t._v("This gives you a minified version for production environments. If you'd like a better development experience, use the following code:")]),t._v(" "),s("div",{staticClass:"language-html extra-class"},[s("pre",{pre:!0,attrs:{class:"language-html"}},[s("code",[s("span",{pre:!0,attrs:{class:"token tag"}},[s("span",{pre:!0,attrs:{class:"token tag"}},[s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("<")]),t._v("script")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token attr-name"}},[t._v("src")]),s("span",{pre:!0,attrs:{class:"token attr-value"}},[s("span",{pre:!0,attrs:{class:"token punctuation attr-equals"}},[t._v("=")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v('"')]),t._v("https://cdn.jsdelivr.net/npm/axios@0.21/dist/axios.js"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v('"')])]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(">")])]),s("span",{pre:!0,attrs:{class:"token script"}}),s("span",{pre:!0,attrs:{class:"token tag"}},[s("span",{pre:!0,attrs:{class:"token tag"}},[s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("")])]),t._v("\n"),s("span",{pre:!0,attrs:{class:"token tag"}},[s("span",{pre:!0,attrs:{class:"token tag"}},[s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("<")]),t._v("script")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token attr-name"}},[t._v("src")]),s("span",{pre:!0,attrs:{class:"token attr-value"}},[s("span",{pre:!0,attrs:{class:"token punctuation attr-equals"}},[t._v("=")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v('"')]),t._v("https://cdn.jsdelivr.net/npm/@openeo/js-client@2/openeo.js"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v('"')])]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(">")])]),s("span",{pre:!0,attrs:{class:"token script"}}),s("span",{pre:!0,attrs:{class:"token tag"}},[s("span",{pre:!0,attrs:{class:"token tag"}},[s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("")])]),t._v("\n")])])]),s("p",[t._v("If you are working on a Node.js application or you are using a Node.js-based build tool for web development (e.g. Webpack), you can install the client via "),s("a",{attrs:{href:"https://npmjs.org/",target:"_blank",rel:"noopener noreferrer"}},[t._v("npm"),s("OutboundLink")],1),t._v(" by using the following command:")]),t._v(" "),s("div",{staticClass:"language-shell script extra-class"},[s("pre",{pre:!0,attrs:{class:"language-shell"}},[s("code",[s("span",{pre:!0,attrs:{class:"token function"}},[t._v("npm")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("install")]),t._v(" @openeo/js-client\n")])])]),s("p",[t._v("Afterwards you can load the library. Depending on whether you are directly working in Node.js or are just using a Node.js build tool, the import can be different. Please inform yourself which import is suited for your project.")]),t._v(" "),s("p",[t._v("This is usually used directly in Node.js:")]),t._v(" "),s("div",{staticClass:"language-js extra-class"},[s("pre",{pre:!0,attrs:{class:"language-js"}},[s("code",[s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("const")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("{")]),t._v(" OpenEO "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("}")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("require")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token string"}},[t._v("'@openeo/js-client'")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(";")]),t._v("\n")])])]),s("p",[t._v("This may be used in build tools such as Webpack:")]),t._v(" "),s("div",{staticClass:"language-js extra-class"},[s("pre",{pre:!0,attrs:{class:"language-js"}},[s("code",[s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("import")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("{")]),t._v(" OpenEO "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("}")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("from")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v("'@openeo/js-client'")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(";")]),t._v("\n")])])]),s("p",[t._v("Now that the installation was successfully finished, we can now connect to openEO compliant back-ends.\nIn the following chapters we quickly walk through the main features of the JavaScript client.")]),t._v(" "),s("p",[t._v("If you have trouble installing the client, feel free to "),s("RouterLink",{attrs:{to:"/contact.html"}},[t._v("contact us")]),t._v(" or leave an issue at the "),s("a",{attrs:{href:"https://github.com/Open-EO/openeo-js-client/issues",target:"_blank",rel:"noopener noreferrer"}},[t._v("GitHub project"),s("OutboundLink")],1),t._v(".")],1),t._v(" "),s("h2",{attrs:{id:"exploring-a-back-end"}},[s("a",{staticClass:"header-anchor",attrs:{href:"#exploring-a-back-end"}},[t._v("#")]),t._v(" Exploring a back-end")]),t._v(" "),s("p",[t._v("If you do not know an openEO back-end that you want to connect to yet, you can have a look at the "),s("a",{attrs:{href:"https://hub.openeo.org/",target:"_blank",rel:"noopener noreferrer"}},[t._v("openEO Hub"),s("OutboundLink")],1),t._v(", to find all known back-ends with information on their capabilities.")]),t._v(" "),s("p",[t._v("For this tutorial we will use the openEO instance of Google Earth Engine, which is available at "),s("code",[t._v("https://earthengine.openeo.org")]),t._v(".\nNote that the code snippets in this guide works the same way for the other back-ends listed in the openEO Hub. Just the collection identifier and band names might differ.")]),t._v(" "),s("p",[t._v("First we need to establish a connection to the back-end.")]),t._v(" "),s("div",{staticClass:"language-js extra-class"},[s("pre",{pre:!0,attrs:{class:"language-js"}},[s("code",[s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("var")]),t._v(" con "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("await")]),t._v(" OpenEO"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("connect")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"https://earthengine.openeo.org"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(";")]),t._v("\n")])])]),s("div",{staticClass:"custom-block tip"},[s("p",{staticClass:"custom-block-title"},[t._v("Note")]),t._v(" "),s("p",[t._v("The JavaScript client uses "),s("a",{attrs:{href:"https://medium.com/jspoint/javascript-promises-and-async-await-as-fast-as-possible-d7c8c8ff0abc",target:"_blank",rel:"noopener noreferrer"}},[t._v("Promises (async/await)"),s("OutboundLink")],1),t._v(". So there are two ways to express the code above:")]),t._v(" "),s("p",[t._v("Promises:")]),t._v(" "),s("div",{staticClass:"language-js extra-class"},[s("pre",{pre:!0,attrs:{class:"language-js"}},[s("code",[t._v("OpenEO"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("connect")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"https://earthengine.openeo.org"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("then")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("function")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token parameter"}},[t._v("con")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("{")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("// Success")]),t._v("\n"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("}")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("catch")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("function")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token parameter"}},[t._v("error")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("{")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("// Error")]),t._v("\n"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("}")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(";")]),t._v("\n")])])]),s("p",[t._v("async/await:")]),t._v(" "),s("div",{staticClass:"language-js extra-class"},[s("pre",{pre:!0,attrs:{class:"language-js"}},[s("code",[s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("try")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("{")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("var")]),t._v(" con "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("await")]),t._v(" OpenEO"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("connect")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"https://earthengine.openeo.org"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(";")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("// Success")]),t._v("\n"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("}")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("catch")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("error"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("{")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("// Error")]),t._v("\n"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("}")]),t._v("\n")])])]),s("p",[t._v("To simplify the code here, we use async/await in all examples and don't catch errors. So we assume you run the code in an async function and also in a try/catch block.")])]),t._v(" "),s("p",[t._v("After establishing the connection to the back-end, it can be explored using the "),s("a",{attrs:{href:"https://open-eo.github.io/openeo-js-client/latest/Connection.html",target:"_blank",rel:"noopener noreferrer"}},[t._v("Connection object"),s("OutboundLink")],1),t._v(" returned. The basic service's metadata (capabilities) can be accessed via")]),t._v(" "),s("div",{staticClass:"language-js extra-class"},[s("pre",{pre:!0,attrs:{class:"language-js"}},[s("code",[s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("var")]),t._v(" info "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" con"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("capabilities")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(";")]),t._v("\n")])])]),s("p",[t._v("This allows to request a couple of "),s("a",{attrs:{href:"https://open-eo.github.io/openeo-js-client/latest/Capabilities.html",target:"_blank",rel:"noopener noreferrer"}},[t._v("different information"),s("OutboundLink")],1),t._v(", like API version, description, related links or the billing plans. You can print some of these information to the console as follows:")]),t._v(" "),s("div",{staticClass:"language-js extra-class"},[s("pre",{pre:!0,attrs:{class:"language-js"}},[s("code",[t._v("console"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("log")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"API Version: "')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" info"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("apiVersion")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(";")]),t._v("\nconsole"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("log")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"Description: "')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" info"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("description")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(";")]),t._v("\n\nconsole"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("log")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"Billing plans:"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(";")]),t._v("\ninfo"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("listPlans")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("forEach")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token parameter"}},[t._v("plan")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=>")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("{")]),t._v("\n console"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("log")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token template-string"}},[s("span",{pre:!0,attrs:{class:"token template-punctuation string"}},[t._v("`")]),s("span",{pre:!0,attrs:{class:"token interpolation"}},[s("span",{pre:!0,attrs:{class:"token interpolation-punctuation punctuation"}},[t._v("${")]),t._v("plan"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),t._v("name"),s("span",{pre:!0,attrs:{class:"token interpolation-punctuation punctuation"}},[t._v("}")])]),s("span",{pre:!0,attrs:{class:"token string"}},[t._v(": ")]),s("span",{pre:!0,attrs:{class:"token interpolation"}},[s("span",{pre:!0,attrs:{class:"token interpolation-punctuation punctuation"}},[t._v("${")]),t._v("plan"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),t._v("url"),s("span",{pre:!0,attrs:{class:"token interpolation-punctuation punctuation"}},[t._v("}")])]),s("span",{pre:!0,attrs:{class:"token template-punctuation string"}},[t._v("`")])]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(";")]),t._v("\n"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("}")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(";")]),t._v("\n\nconsole"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("log")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"Related links:"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(";")]),t._v("\ninfo"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("links")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("forEach")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token parameter"}},[t._v("link")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=>")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("{")]),t._v("\n console"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("log")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token template-string"}},[s("span",{pre:!0,attrs:{class:"token template-punctuation string"}},[t._v("`")]),s("span",{pre:!0,attrs:{class:"token interpolation"}},[s("span",{pre:!0,attrs:{class:"token interpolation-punctuation punctuation"}},[t._v("${")]),t._v("link"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),t._v("title"),s("span",{pre:!0,attrs:{class:"token interpolation-punctuation punctuation"}},[t._v("}")])]),s("span",{pre:!0,attrs:{class:"token string"}},[t._v(": ")]),s("span",{pre:!0,attrs:{class:"token interpolation"}},[s("span",{pre:!0,attrs:{class:"token interpolation-punctuation punctuation"}},[t._v("${")]),t._v("link"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),t._v("href"),s("span",{pre:!0,attrs:{class:"token interpolation-punctuation punctuation"}},[t._v("}")])]),s("span",{pre:!0,attrs:{class:"token template-punctuation string"}},[t._v("`")])]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(";")]),t._v("\n"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("}")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(";")]),t._v("\n")])])]),s("h3",{attrs:{id:"collections"}},[s("a",{staticClass:"header-anchor",attrs:{href:"#collections"}},[t._v("#")]),t._v(" Collections")]),t._v(" "),s("p",[t._v("Collections represent the basic data the back-end provides (e.g. Sentinel 2 collection).\nCollections are used as input data for job executions ("),s("RouterLink",{attrs:{to:"/documentation/1.0/glossary.html#eo-data-collections"}},[t._v("more info on collections")]),t._v(").\nWith the following code snippet you can print all 400+ available collection names and their summary.")],1),t._v(" "),s("div",{staticClass:"language-js extra-class"},[s("pre",{pre:!0,attrs:{class:"language-js"}},[s("code",[t._v("console"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("log")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"Available Collections:"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(";")]),t._v("\n"),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("var")]),t._v(" response "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("await")]),t._v(" con"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("listCollections")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(";")]),t._v("\nresponse"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),t._v("collections"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("forEach")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token parameter"}},[t._v("collection")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=>")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("{")]),t._v("\n console"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("log")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token template-string"}},[s("span",{pre:!0,attrs:{class:"token template-punctuation string"}},[t._v("`")]),s("span",{pre:!0,attrs:{class:"token interpolation"}},[s("span",{pre:!0,attrs:{class:"token interpolation-punctuation punctuation"}},[t._v("${")]),t._v("collection"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),t._v("id"),s("span",{pre:!0,attrs:{class:"token interpolation-punctuation punctuation"}},[t._v("}")])]),s("span",{pre:!0,attrs:{class:"token string"}},[t._v(": ")]),s("span",{pre:!0,attrs:{class:"token interpolation"}},[s("span",{pre:!0,attrs:{class:"token interpolation-punctuation punctuation"}},[t._v("${")]),t._v("collection"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),t._v("summary"),s("span",{pre:!0,attrs:{class:"token interpolation-punctuation punctuation"}},[t._v("}")])]),s("span",{pre:!0,attrs:{class:"token template-punctuation string"}},[t._v("`")])]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(";")]),t._v("\n"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("}")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(";")]),t._v("\n")])])]),s("p",[t._v("To get detailed information about a single collection, you can pass any of the collection IDs requested earlier to "),s("code",[t._v("describeCollection")]),t._v(" and get a full object of "),s("a",{attrs:{href:"https://github.com/radiantearth/stac-spec/tree/v1.0.0/collection-spec/collection-spec.md",target:"_blank",rel:"noopener noreferrer"}},[t._v("STAC compliant Collection metadata"),s("OutboundLink")],1),t._v(" back.\nIn this example we request information about the Sentinel-2 Level 1C data from Google:")]),t._v(" "),s("div",{staticClass:"language-js extra-class"},[s("pre",{pre:!0,attrs:{class:"language-js"}},[s("code",[t._v("console"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("log")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("await")]),t._v(" con"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("describeCollection")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"COPERNICUS/S2"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(";")]),t._v("\n")])])]),s("p",[t._v("The collections descriptions returned by "),s("code",[t._v("listCollections")]),t._v(" are usually not complete. To get the full set of metadata you should always use "),s("code",[t._v("describeCollection")]),t._v(".")]),t._v(" "),s("h3",{attrs:{id:"processes"}},[s("a",{staticClass:"header-anchor",attrs:{href:"#processes"}},[t._v("#")]),t._v(" Processes")]),t._v(" "),s("p",[t._v("Processes in openEO are small tasks that can be applied on (EO) data.\nThe input of a process might be the output of another process, so that several connected processes form a new (user-defined) process itself.\nTherefore, a process resembles the smallest unit of task descriptions in openEO ("),s("RouterLink",{attrs:{to:"/documentation/1.0/glossary.html#processes"}},[t._v("more details on processes")]),t._v(").\nWith the following code snippet you can print all available process IDs and their summaries.")],1),t._v(" "),s("div",{staticClass:"language-js extra-class"},[s("pre",{pre:!0,attrs:{class:"language-js"}},[s("code",[t._v("console"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("log")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"Available Collections:"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(";")]),t._v("\n"),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("var")]),t._v(" response "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("await")]),t._v(" con"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("listProcesses")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(";")]),t._v("\nresponse"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),t._v("processes"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("forEach")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token parameter"}},[t._v("process")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=>")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("{")]),t._v("\n console"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("log")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token template-string"}},[s("span",{pre:!0,attrs:{class:"token template-punctuation string"}},[t._v("`")]),s("span",{pre:!0,attrs:{class:"token interpolation"}},[s("span",{pre:!0,attrs:{class:"token interpolation-punctuation punctuation"}},[t._v("${")]),t._v("process"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),t._v("id"),s("span",{pre:!0,attrs:{class:"token interpolation-punctuation punctuation"}},[t._v("}")])]),s("span",{pre:!0,attrs:{class:"token string"}},[t._v(": ")]),s("span",{pre:!0,attrs:{class:"token interpolation"}},[s("span",{pre:!0,attrs:{class:"token interpolation-punctuation punctuation"}},[t._v("${")]),t._v("process"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),t._v("summary"),s("span",{pre:!0,attrs:{class:"token interpolation-punctuation punctuation"}},[t._v("}")])]),s("span",{pre:!0,attrs:{class:"token template-punctuation string"}},[t._v("`")])]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(";")]),t._v("\n"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("}")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(";")]),t._v("\n")])])]),s("p",[t._v("In contrast to the collections, the process descriptions returned by "),s("code",[t._v("listProcesses")]),t._v(" are complete.\nThere's no need to call "),s("code",[t._v("describeProcess")]),t._v(" to get the full set of metadata.\n"),s("code",[t._v("describeProcess")]),t._v(" is just a convenience function to get a single process from "),s("code",[t._v("listProcesses")]),t._v(".\nIn this example we request the process specification for the "),s("code",[t._v("apply")]),t._v(" process:")]),t._v(" "),s("div",{staticClass:"language-js extra-class"},[s("pre",{pre:!0,attrs:{class:"language-js"}},[s("code",[t._v("console"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("log")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("await")]),t._v(" con"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("describeProcess")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"apply"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(";")]),t._v("\n")])])]),s("p",[t._v("For a graphical overview of the openEO processes, there is an "),s("RouterLink",{attrs:{to:"/documentation/1.0/processes.html"}},[t._v("online documentation")]),t._v(" for general process descriptions and the "),s("a",{attrs:{href:"https://hub.openeo.org/",target:"_blank",rel:"noopener noreferrer"}},[t._v("openEO Hub"),s("OutboundLink")],1),t._v(" for back-end specific process descriptions.")],1),t._v(" "),s("h2",{attrs:{id:"authentication"}},[s("a",{staticClass:"header-anchor",attrs:{href:"#authentication"}},[t._v("#")]),t._v(" Authentication")]),t._v(" "),s("p",[t._v("In the code snippets above, authentication is usually not necessary, since we only fetch general information about the back-end.\nTo run your own jobs at the back-end or to access job results, you need to authenticate at the back-end.")]),t._v(" "),s("p",[t._v("Depending on the back-end, there might be two different approaches to authenticate.\nYou need to inform yourself at your back-end provider of choice, which authentication approach you have to carry out.\nYou can also have a look at the "),s("a",{attrs:{href:"https://hub.openeo.org/",target:"_blank",rel:"noopener noreferrer"}},[t._v("openEO Hub"),s("OutboundLink")],1),t._v(" to see the available authentication types of the back-ends.")]),t._v(" "),s("div",{staticClass:"custom-block tip"},[s("p",{staticClass:"custom-block-title"},[t._v("Recommendation")]),t._v(" "),s("p",[t._v("The Google Earth Engine implementation for openEO only supports Basic authentication, but generally the preferred authentication method is "),s("a",{attrs:{href:"#openid-connect-authentication"}},[t._v("OpenID Connect")]),t._v(" due to better security mechanisms implemented in the OpenID Connect protocol.")])]),t._v(" "),s("h3",{attrs:{id:"basic-authentication"}},[s("a",{staticClass:"header-anchor",attrs:{href:"#basic-authentication"}},[t._v("#")]),t._v(" Basic Authentication")]),t._v(" "),s("p",[t._v("The Basic authentication method is a common way of authenticate HTTP requests given username and password.")]),t._v(" "),s("p",[t._v("The following code snippet shows how to log in via Basic authentication:")]),t._v(" "),s("div",{staticClass:"language-js extra-class"},[s("pre",{pre:!0,attrs:{class:"language-js"}},[s("code",[s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("await")]),t._v(" con"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("authenticateBasic")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"username"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"password"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(";")]),t._v("\n")])])]),s("div",{staticClass:"custom-block tip"},[s("p",{staticClass:"custom-block-title"},[t._v("TIP")]),t._v(" "),s("p",[t._v("You can get username and password here: "),s("a",{attrs:{href:"https://github.com/Open-EO/openeo-earthengine-driver#demo",target:"_blank",rel:"noopener noreferrer"}},[t._v("https://github.com/Open-EO/openeo-earthengine-driver#demo"),s("OutboundLink")],1)])]),t._v(" "),s("p",[t._v("After successfully calling the "),s("code",[t._v("authenticateBasic")]),t._v(" method, you are logged into the back-end with your account.\nThis means, that every call that comes after that via the "),s("code",[t._v("con")]),t._v(" variable is executed by your user account.")]),t._v(" "),s("h3",{attrs:{id:"openid-connect-authentication"}},[s("a",{staticClass:"header-anchor",attrs:{href:"#openid-connect-authentication"}},[t._v("#")]),t._v(" OpenID Connect Authentication")]),t._v(" "),s("div",{staticClass:"custom-block warning"},[s("p",{staticClass:"custom-block-title"},[t._v("WARNING")]),t._v(" "),s("p",[t._v("For Google Earth Engine, only "),s("a",{attrs:{href:"#basic-authentication"}},[t._v("Basic Authentication")]),t._v(" is supported at the moment.")])]),t._v(" "),s("p",[t._v("The OIDC ("),s("a",{attrs:{href:"https://openid.net/connect/",target:"_blank",rel:"noopener noreferrer"}},[t._v("OpenID Connect"),s("OutboundLink")],1),t._v(") authentication can be used to authenticate via an external service given a client ID.")]),t._v(" "),s("div",{staticClass:"custom-block warning"},[s("p",{staticClass:"custom-block-title"},[t._v("Important")]),t._v(" "),s("p",[t._v("If you have included the library using HTML "),s("code",[t._v("script")]),t._v(" tags, then you need to include the following OIDC client before the openEO client:")]),t._v(" "),s("div",{staticClass:"language-html extra-class"},[s("pre",{pre:!0,attrs:{class:"language-html"}},[s("code",[s("span",{pre:!0,attrs:{class:"token tag"}},[s("span",{pre:!0,attrs:{class:"token tag"}},[s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("<")]),t._v("script")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token attr-name"}},[t._v("src")]),s("span",{pre:!0,attrs:{class:"token attr-value"}},[s("span",{pre:!0,attrs:{class:"token punctuation attr-equals"}},[t._v("=")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v('"')]),t._v("https://cdn.jsdelivr.net/npm/oidc-client@1/lib/oidc-client.min.js"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v('"')])]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(">")])]),s("span",{pre:!0,attrs:{class:"token script"}}),s("span",{pre:!0,attrs:{class:"token tag"}},[s("span",{pre:!0,attrs:{class:"token tag"}},[s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("")])]),t._v("\n")])])]),s("p",[t._v("No further action is required, if you have installed the client via npm.")])]),t._v(" "),s("p",[t._v("As OpenID Connect authentication is a bit more complex and depends on the environment your are using it in, please refer to the "),s("a",{attrs:{href:"https://open-eo.github.io/openeo-js-client/latest/OidcProvider.html",target:"_blank",rel:"noopener noreferrer"}},[t._v("JavaScript client documentation"),s("OutboundLink")],1),t._v(" for more information.")]),t._v(" "),s("h2",{attrs:{id:"creating-a-user-defined-process"}},[s("a",{staticClass:"header-anchor",attrs:{href:"#creating-a-user-defined-process"}},[t._v("#")]),t._v(" Creating a (user-defined) process")]),t._v(" "),s("p",[t._v("Now that we know how to discover the back-end and how to authenticate, lets continue by creating a new batch job to process some data.\nFirst we need to create a user-defined process and for that a process builder is the easiest method.")]),t._v(" "),s("div",{staticClass:"language-js extra-class"},[s("pre",{pre:!0,attrs:{class:"language-js"}},[s("code",[s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("var")]),t._v(" builder "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("await")]),t._v(" con"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("buildProcess")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(";")]),t._v("\n")])])]),s("p",[t._v("With the builder, a "),s("RouterLink",{attrs:{to:"/documentation/1.0/glossary.html#spatial-datacubes"}},[t._v("datacube")]),t._v(" can be initialized by selecting a collection from the back-end with the process "),s("code",[t._v("load_collection")]),t._v(":")],1),t._v(" "),s("div",{staticClass:"language-js extra-class"},[s("pre",{pre:!0,attrs:{class:"language-js"}},[s("code",[s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("var")]),t._v(" datacube "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" builder"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("load_collection")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"COPERNICUS/S1_GRD"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("{")]),s("span",{pre:!0,attrs:{class:"token literal-property property"}},[t._v("west")]),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v(":")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("16.06")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token literal-property property"}},[t._v("south")]),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v(":")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("48.06")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token literal-property property"}},[t._v("east")]),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v(":")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("16.65")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token literal-property property"}},[t._v("north")]),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v(":")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("48.35")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("}")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"2017-03-01"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"2017-04-01"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"VV"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"VH"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),t._v("\n"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(";")]),t._v("\n")])])]),s("p",[t._v('This results in a datacube containing the "COPERNICUS/S1_GRD" data restricted to the given spatial extent, the given temporal extend and the given bands .')]),t._v(" "),s("div",{staticClass:"custom-block tip"},[s("p",{staticClass:"custom-block-title"},[t._v("TIP")]),t._v(" "),s("p",[t._v("You can also filter the datacube at a later stage by using the following filter methods:")]),t._v(" "),s("div",{staticClass:"language-js extra-class"},[s("pre",{pre:!0,attrs:{class:"language-js"}},[s("code",[t._v("datacube "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" builder"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("filter_bbox")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("datacube"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("{")]),s("span",{pre:!0,attrs:{class:"token literal-property property"}},[t._v("west")]),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v(":")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("16.06")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token literal-property property"}},[t._v("south")]),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v(":")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("48.06")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token literal-property property"}},[t._v("east")]),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v(":")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("16.65")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token literal-property property"}},[t._v("north")]),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v(":")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("48.35")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("}")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(";")]),t._v("\ndatacube "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" builder"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("filter_temporal")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("datacube"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"2017-03-01"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"2017-04-01"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(";")]),t._v("\ndatacube "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" builder"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("filter_bands")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("datacube"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"VV"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"VH"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(";")]),t._v("\n")])])]),s("p",[t._v("Still, it is recommended to always use the filters in "),s("code",[t._v("load_collection")]),t._v(" to avoid loading too much data upfront.")])]),t._v(" "),s("p",[t._v("Having the input data ready, we want to apply a process on the datacube, which returns a datacube with the process applied:")]),t._v(" "),s("div",{staticClass:"language-js extra-class"},[s("pre",{pre:!0,attrs:{class:"language-js"}},[s("code",[s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("var")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token function-variable function"}},[t._v("min")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("function")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token parameter"}},[t._v("data")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("{")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("return")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("this")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("min")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("data"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(";")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("}")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(";")]),t._v("\ndatacube "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" builder"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("reduce_dimension")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("datacube"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" min"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"t"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(";")]),t._v("\n")])])]),s("p",[t._v("The datacube is now reduced by the time dimension named "),s("code",[t._v("t")]),t._v(', by taking the minimum value of the timeseries values.\nNow the datacube has no time dimension left.\nOther so called "reducer" processes exist, e.g. for computing maximum and mean values.')]),t._v(" "),s("div",{staticClass:"custom-block tip"},[s("p",{staticClass:"custom-block-title"},[t._v("Note")]),t._v(" "),s("p",[t._v("Everything applied to the datacube at this point is neither executed locally on your machine nor executed on the back-end.\nIt just defines the input data and process chain the back-end needs to apply when it sends the datacube to the back-end and executes it there.\nHow this can be done is the topic of the next chapter.")])]),t._v(" "),s("p",[t._v("After applying all processes you want to execute, we need to tell the back-end to export the datacube, for example as GeoTiff:")]),t._v(" "),s("div",{staticClass:"language-js extra-class"},[s("pre",{pre:!0,attrs:{class:"language-js"}},[s("code",[s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("var")]),t._v(" result "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" builder"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("save_result")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("datacube"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"GTiff"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(";")]),t._v("\n")])])]),s("h2",{attrs:{id:"batch-job-management"}},[s("a",{staticClass:"header-anchor",attrs:{href:"#batch-job-management"}},[t._v("#")]),t._v(" Batch Job Management")]),t._v(" "),s("p",[t._v("After you finished working on your (user-defined) process, we can now send it to the back-end and start the execution.\nIn openEO, an execution of a (user-defined) process (here defined using the process builder) is called a "),s("RouterLink",{attrs:{to:"/documentation/1.0/glossary.html#data-processing-modes"}},[t._v("(batch) job")]),t._v(".\nTherefore, we need to create a job at the back-end using our datacube, giving it the title "),s("code",[t._v("Example Title")]),t._v(".")],1),t._v(" "),s("div",{staticClass:"language-js extra-class"},[s("pre",{pre:!0,attrs:{class:"language-js"}},[s("code",[s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("var")]),t._v(" job "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("await")]),t._v(" con"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("createJob")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("result"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"Example Title"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(";")]),t._v("\n")])])]),s("p",[t._v("The "),s("code",[t._v("createJob")]),t._v(" method sends all necessary information to the back-end and creates a new job, which gets returned.\nAfter this, the job is just created, but has not started the execution at the back-end yet.\nIt needs to be queued for processing explicitly:")]),t._v(" "),s("div",{staticClass:"language-js extra-class"},[s("pre",{pre:!0,attrs:{class:"language-js"}},[s("code",[s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("await")]),t._v(" job"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("startJob")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(";")]),t._v("\n")])])]),s("p",[t._v("Now the execution of the job can be monitored by requesting the job status and the log files every once in a while (30 seconds in this example):")]),t._v(" "),s("div",{staticClass:"language-js extra-class"},[s("pre",{pre:!0,attrs:{class:"language-js"}},[s("code",[s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("let")]),t._v(" stopFn "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" job"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("monitorJob")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token parameter"}},[t._v("job"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" logs")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=>")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("{")]),t._v("\n console"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("log")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("job"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),t._v("status"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(";")]),t._v("\n logs"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("forEach")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token parameter"}},[t._v("log")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=>")]),t._v(" console"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("log")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token template-string"}},[s("span",{pre:!0,attrs:{class:"token template-punctuation string"}},[t._v("`")]),s("span",{pre:!0,attrs:{class:"token interpolation"}},[s("span",{pre:!0,attrs:{class:"token interpolation-punctuation punctuation"}},[t._v("${")]),t._v("log"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),t._v("level"),s("span",{pre:!0,attrs:{class:"token interpolation-punctuation punctuation"}},[t._v("}")])]),s("span",{pre:!0,attrs:{class:"token string"}},[t._v(": ")]),s("span",{pre:!0,attrs:{class:"token interpolation"}},[s("span",{pre:!0,attrs:{class:"token interpolation-punctuation punctuation"}},[t._v("${")]),t._v("log"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),t._v("message"),s("span",{pre:!0,attrs:{class:"token interpolation-punctuation punctuation"}},[t._v("}")])]),s("span",{pre:!0,attrs:{class:"token template-punctuation string"}},[t._v("`")])]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(";")]),t._v("\n"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("}")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("30")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(";")]),t._v("\n")])])]),s("p",[t._v("The monitoring stops automatically once the job has finished, was canceled or errored out.\nBut with the return value of the "),s("code",[t._v("monitorJob")]),t._v(" function, you can also stop monitoring the job manually:")]),t._v(" "),s("div",{staticClass:"language-js extra-class"},[s("pre",{pre:!0,attrs:{class:"language-js"}},[s("code",[s("span",{pre:!0,attrs:{class:"token function"}},[t._v("stopFn")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(";")]),t._v("\n")])])]),s("p",[t._v("When the job is finished, calling "),s("code",[t._v("listResults")]),t._v(" gets you the URLs to the results.")]),t._v(" "),s("div",{staticClass:"language-js extra-class"},[s("pre",{pre:!0,attrs:{class:"language-js"}},[s("code",[s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("var")]),t._v(" urls "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("await")]),t._v(" job"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("listResults")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(";")]),t._v("\n")])])]),s("div",{staticClass:"custom-block tip"},[s("p",{staticClass:"custom-block-title"},[t._v("TIP")]),t._v(" "),s("p",[t._v("This only works if the job execution has finished.\nWe recommend to use "),s("code",[t._v("listResults")]),t._v(" in combination with "),s("code",[t._v("monitorJob")]),t._v(", for example as follows:")]),t._v(" "),s("div",{staticClass:"language-js extra-class"},[s("pre",{pre:!0,attrs:{class:"language-js"}},[s("code",[s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("let")]),t._v(" stopFn "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" job"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("monitorJob")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("async")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token parameter"}},[t._v("job"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" logs")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=>")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("{")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("if")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("job"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),t._v("status "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("===")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"finished"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("{")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("var")]),t._v(" urls "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("await")]),t._v(" job"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("listResults")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(";")]),t._v("\n urls"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("forEach")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token parameter"}},[t._v("url")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=>")]),t._v(" console"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("log")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token template-string"}},[s("span",{pre:!0,attrs:{class:"token template-punctuation string"}},[t._v("`")]),s("span",{pre:!0,attrs:{class:"token string"}},[t._v("Download result from: ")]),s("span",{pre:!0,attrs:{class:"token interpolation"}},[s("span",{pre:!0,attrs:{class:"token interpolation-punctuation punctuation"}},[t._v("${")]),t._v("url"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),t._v("href"),s("span",{pre:!0,attrs:{class:"token interpolation-punctuation punctuation"}},[t._v("}")])]),s("span",{pre:!0,attrs:{class:"token template-punctuation string"}},[t._v("`")])]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(";")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("}")]),t._v("\n"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("}")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(";")]),t._v("\n")])])])]),t._v(" "),s("div",{staticClass:"custom-block tip"},[s("p",{staticClass:"custom-block-title"},[t._v("Note")]),t._v(" "),s("p",[t._v("There's also the method "),s("code",[t._v("downloadResults")]),t._v(" to download the results directly.\nUnfortunately, you can only download files from a Node.js environment where file access to your local drive is possible.\nIn a Browser environment, it is also an option to download the STAC Item or Collection for the results using the "),s("code",[t._v("getResultsAsStac")]),t._v(" method and point a "),s("a",{attrs:{href:"https://stacindex.org/ecosystem?category=Client",target:"_blank",rel:"noopener noreferrer"}},[t._v("STAC client"),s("OutboundLink")],1),t._v(" to it for downloading.")])]),t._v(" "),s("p",[t._v("Now you know the general workflow of job executions.")]),t._v(" "),s("h2",{attrs:{id:"full-example"}},[s("a",{staticClass:"header-anchor",attrs:{href:"#full-example"}},[t._v("#")]),t._v(" Full Example")]),t._v(" "),s("p",[t._v("In this chapter we will show a full example of an earth observation use case using the JavaScript client in a Node.js environment and the Google Earth Engine back-end.\nInstead of batch job processing, we compute the image synchronously. Synchronous processing means the result is directly returned in the response, which usually works only for smaller amounts of data.")]),t._v(" "),s("div",{staticClass:"custom-block tip"},[s("p",{staticClass:"custom-block-title"},[t._v("Use Case")]),t._v(" "),s("p",[t._v("We want to produce a monthly RGB composite of Sentinel 1 backscatter data over the area of Vienna, Austria for three\nmonths in 2017. This can be used for classification and crop monitoring.")])]),t._v(" "),s("p",[t._v("In the following code example, we use inline code comments to describe what we are doing.")]),t._v(" "),s("div",{staticClass:"custom-block warning"},[s("p",{staticClass:"custom-block-title"},[t._v("WARNING")]),t._v(" "),s("p",[t._v("The username and password in the example above work at the time of writing, but may be invalid at the time you read this. Please "),s("RouterLink",{attrs:{to:"/contact.html"}},[t._v("contact us")]),t._v(" for credentials.")],1)]),t._v(" "),s("div",{staticClass:"language-js extra-class"},[s("pre",{pre:!0,attrs:{class:"language-js"}},[s("code",[s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("// Make the client available to the Node.js script")]),t._v("\n"),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("// Also include the Formula library for simple math expressions")]),t._v("\n"),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("const")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("{")]),t._v(" OpenEO"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" Formula "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("}")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("require")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token string"}},[t._v("'@openeo/js-client'")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(";")]),t._v("\n\n"),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("async")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("function")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("example")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("{")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("// Connect to the back-end")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("var")]),t._v(" con "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("await")]),t._v(" OpenEO"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("connect")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"https://earthengine.openeo.org"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(";")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("// Authenticate ourselves via Basic authentication")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("await")]),t._v(" con"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("authenticateBasic")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"group11"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"test123"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(";")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("// Create a process builder")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("var")]),t._v(" builder "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("await")]),t._v(" con"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("buildProcess")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(";")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("// We are now loading the Sentinel-1 data over the Area of Interest")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("var")]),t._v(" datacube "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" builder"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("load_collection")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"COPERNICUS/S1_GRD"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("{")]),s("span",{pre:!0,attrs:{class:"token literal-property property"}},[t._v("west")]),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v(":")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("16.06")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token literal-property property"}},[t._v("south")]),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v(":")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("48.06")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token literal-property property"}},[t._v("east")]),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v(":")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("16.65")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token literal-property property"}},[t._v("north")]),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v(":")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("48.35")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("}")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"2017-03-01"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"2017-06-01"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"VV"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(";")]),t._v("\n\n "),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("// Since we are creating a monthly RGB composite, we need three separated time ranges (March aas R, April as G and May as G).")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("// Therefore, we split the datacube into three datacubes using a temporal filter.")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("var")]),t._v(" march "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" builder"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("filter_temporal")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("datacube"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"2017-03-01"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"2017-04-01"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(";")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("var")]),t._v(" april "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" builder"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("filter_temporal")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("datacube"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"2017-04-01"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"2017-05-01"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(";")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("var")]),t._v(" may "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" builder"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("filter_temporal")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("datacube"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"2017-05-01"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"2017-06-01"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(";")]),t._v("\n\n "),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("// We aggregate the timeseries values into a single image by reducing the time dimension using a mean reducer.")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("var")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token function-variable function"}},[t._v("mean")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("function")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token parameter"}},[t._v("data")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("{")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("return")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("this")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("mean")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("data"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(";")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("}")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(";")]),t._v("\n march "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" builder"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("reduce_dimension")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("march"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" mean"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"t"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(";")]),t._v("\n april "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" builder"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("reduce_dimension")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("april"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" mean"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"t"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(";")]),t._v("\n may "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" builder"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("reduce_dimension")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("may"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" mean"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"t"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(";")]),t._v("\n\n "),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("// Now the three images will be combined into the temporal composite.")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("// We rename the bands to R, G and B as otherwise the bands are overlapping and the merge process would fail.")]),t._v("\n march "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" builder"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("rename_labels")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("march"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"bands"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"R"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"VV"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(";")]),t._v("\n april "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" builder"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("rename_labels")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("april"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"bands"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"G"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"VV"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(";")]),t._v("\n may "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" builder"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("rename_labels")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("may"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"bands"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"B"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"VV"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(";")]),t._v("\n\n datacube "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" builder"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("merge_cubes")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("march"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" april"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(";")]),t._v("\n datacube "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" builder"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("merge_cubes")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("datacube"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" may"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(";")]),t._v("\n\n "),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("// To make the values match the RGB values from 0 to 255 in a PNG file, we need to scale them.")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("// We can simplify expressing math formulas using the openEO Formula parser.")]),t._v("\n datacube "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("builder")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("apply")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("datacube"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("new")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token class-name"}},[t._v("Formula")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"linear_scale_range(x, -20, -5, 0, 255)"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(";")]),t._v("\n\n "),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("// Finally, save the result as PNG file.")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v('// In the options we specify which band should be used for "red", "green" and "blue" color.')]),t._v("\n datacube "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" builder"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("save_result")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("datacube"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"PNG"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("{")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token literal-property property"}},[t._v("red")]),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v(":")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"R"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token literal-property property"}},[t._v("green")]),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v(":")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"G"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token literal-property property"}},[t._v("blue")]),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v(":")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"B"')]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("}")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(";")]),t._v("\n\n "),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("// Now send the processing instructions to the back-end for (synchronous) execution and save the file as result.png")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("await")]),t._v(" con"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("downloadResult")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("datacube"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"result.png"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(";")]),t._v("\n"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("}")]),t._v("\n\n"),s("span",{pre:!0,attrs:{class:"token comment"}},[t._v("// Run the example, write errors to the console.")]),t._v("\n"),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("example")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("catch")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token parameter"}},[t._v("error")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=>")]),t._v(" console"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("error")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("error"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(";")]),t._v("\n")])])]),s("p",[t._v("Now the resulting PNG file of the RGB backscatter composite is stored as "),s("code",[t._v("result.png")]),t._v(" in the node.JS working directory and should look as follows:")]),t._v(" "),s("p",[s("img",{attrs:{src:a(193),alt:"RGB composite"}})]),t._v(" "),s("h2",{attrs:{id:"user-defined-functions"}},[s("a",{staticClass:"header-anchor",attrs:{href:"#user-defined-functions"}},[t._v("#")]),t._v(" User Defined Functions")]),t._v(" "),s("p",[t._v("If your use case can not be accomplished with the "),s("RouterLink",{attrs:{to:"/documentation/1.0/processes.html"}},[t._v("default processes")]),t._v(" of openEO, you can define a "),s("RouterLink",{attrs:{to:"/documentation/1.0/glossary.html#user-defined-function-udf"}},[t._v("user defined function")]),t._v(".\nUnfortunately, you can only create Python and R functions at the moment.\nTherefore, this guide doesn't get into detail.\nFor more information check out the Python or R tutorials on UDFs.")],1),t._v(" "),s("h2",{attrs:{id:"additional-information"}},[s("a",{staticClass:"header-anchor",attrs:{href:"#additional-information"}},[t._v("#")]),t._v(" Additional Information")]),t._v(" "),s("ul",[s("li",[s("a",{attrs:{href:"https://github.com/Open-EO/openeo-js-client/tree/master/examples",target:"_blank",rel:"noopener noreferrer"}},[t._v("Examples"),s("OutboundLink")],1)]),t._v(" "),s("li",[s("a",{attrs:{href:"https://open-eo.github.io/openeo-js-client/latest/",target:"_blank",rel:"noopener noreferrer"}},[t._v("Documentation"),s("OutboundLink")],1)]),t._v(" "),s("li",[s("a",{attrs:{href:"https://github.com/Open-EO/openeo-js-client",target:"_blank",rel:"noopener noreferrer"}},[t._v("Repository"),s("OutboundLink")],1)])])])}),[],!1,null,null,null);s.default=e.exports}}]); \ No newline at end of file diff --git a/assets/js/47.2743281b.js b/assets/js/47.1ef9a29e.js similarity index 99% rename from assets/js/47.2743281b.js rename to assets/js/47.1ef9a29e.js index ccf0e5704..16e1bfa2d 100644 --- a/assets/js/47.2743281b.js +++ b/assets/js/47.1ef9a29e.js @@ -1 +1 @@ -(window.webpackJsonp=window.webpackJsonp||[]).push([[47],{193:function(t,e,a){t.exports=a.p+"assets/img/getting-started-result-example.7820ee84.jpg"},532:function(t,e,a){"use strict";a.r(e);var n=a(4),s=Object(n.a)({},(function(){var t=this,e=t._self._c;return e("ContentSlotsDistributor",{attrs:{"slot-key":t.$parent.slotKey}},[e("h1",{attrs:{id:"python-client"}},[e("a",{staticClass:"header-anchor",attrs:{href:"#python-client"}},[t._v("#")]),t._v(" Python Client")]),t._v(" "),e("p",[t._v("This Getting Started guide will give you just a simple overview of the capabilities of the openEO Python client library.\nMore in-depth information can be found in its "),e("a",{attrs:{href:"https://open-eo.github.io/openeo-python-client/",target:"_blank",rel:"noopener noreferrer"}},[t._v("official documentation"),e("OutboundLink")],1),t._v(".")]),t._v(" "),e("h2",{attrs:{id:"installation"}},[e("a",{staticClass:"header-anchor",attrs:{href:"#installation"}},[t._v("#")]),t._v(" Installation")]),t._v(" "),e("p",[t._v("The openEO Python client library is available on "),e("a",{attrs:{href:"https://pypi.org/project/openeo/",target:"_blank",rel:"noopener noreferrer"}},[t._v("PyPI"),e("OutboundLink")],1),t._v("\nand can easily be installed with a tool like "),e("code",[t._v("pip")]),t._v(", for example:")]),t._v(" "),e("div",{staticClass:"language-shell script extra-class"},[e("pre",{pre:!0,attrs:{class:"language-shell"}},[e("code",[t._v("pip "),e("span",{pre:!0,attrs:{class:"token function"}},[t._v("install")]),t._v(" openeo\n")])])]),e("p",[t._v("The client library is also available on "),e("a",{attrs:{href:"https://anaconda.org/conda-forge/openeo",target:"_blank",rel:"noopener noreferrer"}},[t._v("Conda Forge"),e("OutboundLink")],1),t._v(".")]),t._v(" "),e("p",[t._v("It's recommended to work in a virtual environment of some kind ("),e("code",[t._v("venv")]),t._v(", "),e("code",[t._v("conda")]),t._v(", ...),\ncontaining Python 3.6 or higher.")]),t._v(" "),e("div",{staticClass:"custom-block tip"},[e("p",{staticClass:"custom-block-title"},[t._v("TIP")]),t._v(" "),e("p",[t._v("For more details, alternative installation procedures or troubleshooting tips:\nsee the "),e("a",{attrs:{href:"https://open-eo.github.io/openeo-python-client/installation.html",target:"_blank",rel:"noopener noreferrer"}},[t._v("official "),e("code",[t._v("openeo")]),t._v(" package installation documentation"),e("OutboundLink")],1),t._v(".")])]),t._v(" "),e("h2",{attrs:{id:"exploring-a-back-end"}},[e("a",{staticClass:"header-anchor",attrs:{href:"#exploring-a-back-end"}},[t._v("#")]),t._v(" Exploring a back-end")]),t._v(" "),e("p",[t._v("If you do not know an openEO back-end that you want to connect to yet, you can have a look at the "),e("a",{attrs:{href:"https://hub.openeo.org/",target:"_blank",rel:"noopener noreferrer"}},[t._v("openEO Hub"),e("OutboundLink")],1),t._v(", to find all known back-ends with information on their capabilities.")]),t._v(" "),e("p",[t._v("For this tutorial we will use the openEO instance of Google Earth Engine, which is available at "),e("code",[t._v("https://earthengine.openeo.org")]),t._v(".\nNote that the code snippets in this guide work the same way for the other back-ends listed in the openEO Hub. Just the collection identifier and band names might differ.")]),t._v(" "),e("p",[t._v("First we need to establish a connection to the back-end.")]),t._v(" "),e("div",{staticClass:"language-python extra-class"},[e("pre",{pre:!0,attrs:{class:"language-python"}},[e("code",[e("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("import")]),t._v(" openeo\n\nconnection "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" openeo"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),t._v("connect"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),e("span",{pre:!0,attrs:{class:"token string"}},[t._v('"https://earthengine.openeo.org"')]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n")])])]),e("p",[t._v("The "),e("a",{attrs:{href:"https://open-eo.github.io/openeo-python-client/api.html#module-openeo.rest.connection",target:"_blank",rel:"noopener noreferrer"}},[e("code",[t._v("Connection")]),t._v(" object"),e("OutboundLink")],1),t._v("\nis your central gateway to")]),t._v(" "),e("ul",[e("li",[t._v("list data collections, available processes, file formats and other capabilities of the back-end")]),t._v(" "),e("li",[t._v("start building your openEO algorithm from the desired data on the back-end")]),t._v(" "),e("li",[t._v("execute and monitor (batch) jobs on the back-end")]),t._v(" "),e("li",[t._v("etc.")])]),t._v(" "),e("h3",{attrs:{id:"collections"}},[e("a",{staticClass:"header-anchor",attrs:{href:"#collections"}},[t._v("#")]),t._v(" Collections")]),t._v(" "),e("p",[t._v('The EO data available at a back-end is organised in so-called collections.\nFor example, a back-end might provide fundamental satellite collections like "Sentinel 1" or "Sentinel 2",\nor preprocessed collections like "NDVI".\nCollections are used as input data for your openEO jobs.')]),t._v(" "),e("div",{staticClass:"custom-block tip"},[e("p",{staticClass:"custom-block-title"},[t._v("Note")]),t._v(" "),e("p",[t._v('More information on how openEO "collections" relate to terminology used in other systems can be found in\n('),e("RouterLink",{attrs:{to:"/documentation/1.0/glossary.html#eo-data-collections"}},[t._v("the openEO glossary")]),t._v(").")],1)]),t._v(" "),e("p",[t._v("Let's list all available collections on the back-end,\nusing "),e("a",{attrs:{href:"https://open-eo.github.io/openeo-python-client/api.html#openeo.rest.connection.Connection.list_collections",target:"_blank",rel:"noopener noreferrer"}},[e("code",[t._v("list_collections")]),e("OutboundLink")],1),t._v(":")]),t._v(" "),e("div",{staticClass:"language-python extra-class"},[e("pre",{pre:!0,attrs:{class:"language-python"}},[e("code",[e("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("print")]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("connection"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),t._v("list_collections"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n")])])]),e("p",[t._v("which returns list of collection metadata dictionaries, e.g. something like:")]),t._v(" "),e("div",{staticClass:"language- extra-class"},[e("pre",{pre:!0,attrs:{class:"language-text"}},[e("code",[t._v("[{'id': 'AGERA5', 'title': 'ECMWF AGERA5 meteo dataset', 'description': 'Daily surface meteorolociga datal ...', ...},\n {'id': 'SENTINEL2_L2A_SENTINELHUB', 'title': 'Sentinel-2 top of canopy', ...},\n {'id': 'SENTINEL1_GRD', ...},\n ...]\n")])])]),e("p",[t._v("This listing includes basic metadata for each collection.\nIf necessary, a more detailed metadata listing for a given collection can be obtained with\n"),e("a",{attrs:{href:"https://open-eo.github.io/openeo-python-client/api.html#openeo.rest.connection.Connection.describe_collection",target:"_blank",rel:"noopener noreferrer"}},[e("code",[t._v("describe_collection")]),e("OutboundLink")],1),t._v(".")]),t._v(" "),e("div",{staticClass:"custom-block tip"},[e("p",{staticClass:"custom-block-title"},[t._v("TIP")]),t._v(" "),e("p",[t._v("Programmatically listing collections is just a very simple usage example of the Python client.\nIn reality, you probably want to look up or inspect available collections in a web based overview such as the "),e("a",{attrs:{href:"https://hub.openeo.org/",target:"_blank",rel:"noopener noreferrer"}},[t._v("openEO Hub"),e("OutboundLink")],1),t._v(".")])]),t._v(" "),e("h3",{attrs:{id:"processes"}},[e("a",{staticClass:"header-anchor",attrs:{href:"#processes"}},[t._v("#")]),t._v(" Processes")]),t._v(" "),e("p",[t._v('Processes in openEO are operations that can be applied on (EO) data\n(e.g. calculate the mean of an array, or mask out observations outside a given polygon).\nThe output of one process can be used as the input of another process,\nand by doing so, multiple processes can be connected that way in a larger "process graph":\na new (user-defined) processes that implements a certain algorithm.')]),t._v(" "),e("div",{staticClass:"custom-block tip"},[e("p",{staticClass:"custom-block-title"},[t._v("Note")]),t._v(" "),e("p",[t._v("Check "),e("RouterLink",{attrs:{to:"/documentation/1.0/glossary.html#processes"}},[t._v("the openEO glossary")]),t._v("\nfor more details on pre-defined, user-defined processes and process graphs.")],1)]),t._v(" "),e("p",[t._v("Let's list the (pre-defined) processes available on the back-end\nwith "),e("a",{attrs:{href:"https://open-eo.github.io/openeo-python-client/api.html#openeo.rest.connection.Connection.list_processes",target:"_blank",rel:"noopener noreferrer"}},[e("code",[t._v("list_processes")]),e("OutboundLink")],1),t._v(":")]),t._v(" "),e("div",{staticClass:"language-python extra-class"},[e("pre",{pre:!0,attrs:{class:"language-python"}},[e("code",[e("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("print")]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("connection"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),t._v("list_processes"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n")])])]),e("p",[t._v("which returns a list of dictionaries describing the process (including expected arguments and return type), e.g.:")]),t._v(" "),e("div",{staticClass:"language- extra-class"},[e("pre",{pre:!0,attrs:{class:"language-text"}},[e("code",[t._v("[{'id': 'absolute', 'summary': 'Absolute value', 'description': 'Computes the absolute value of a real number `x`, which is th...', \n {'id': 'mean', 'summary': 'Arithmetic mean(average)', ...}\n ...]\n")])])]),e("p",[t._v("Like with collections, instead of programmatic exploration you'll probably prefer a web-based overview such as the "),e("a",{attrs:{href:"https://hub.openeo.org/",target:"_blank",rel:"noopener noreferrer"}},[t._v("openEO Hub"),e("OutboundLink")],1),t._v(" for back-end specific process descriptions\nor browse the "),e("a",{attrs:{href:"https://processes.openeo.org/",target:"_blank",rel:"noopener noreferrer"}},[t._v("reference specifications of openEO processes"),e("OutboundLink")],1),t._v(".")]),t._v(" "),e("h2",{attrs:{id:"authentication"}},[e("a",{staticClass:"header-anchor",attrs:{href:"#authentication"}},[t._v("#")]),t._v(" Authentication")]),t._v(" "),e("p",[t._v("In the code snippets above we did not need to log in\nsince we just queried publicly available back-end information.\nHowever, to run non-trivial processing queries one has to authenticate\nso that permissions, resource usage, etc. can be managed properly.")]),t._v(" "),e("p",[t._v("Depending on the back-end, there might be two different approaches to authenticate.\nYou need to inform yourself at your back-end provider of choice, which authentication approach you have to carry out.\nYou can also have a look at the "),e("a",{attrs:{href:"https://hub.openeo.org/",target:"_blank",rel:"noopener noreferrer"}},[t._v("openEO Hub"),e("OutboundLink")],1),t._v(" to see the available authentication types of the back-ends.")]),t._v(" "),e("p",[t._v("A detailed description of why and how to use the authentication methods is on the "),e("a",{attrs:{href:"https://open-eo.github.io/openeo-python-client/auth.html#authentication-and-account-management",target:"_blank",rel:"noopener noreferrer"}},[t._v("official documentation"),e("OutboundLink")],1),t._v(".")]),t._v(" "),e("div",{staticClass:"custom-block tip"},[e("p",{staticClass:"custom-block-title"},[t._v("Recommendation")]),t._v(" "),e("p",[t._v("The Google Earth Engine implementation for openEO only supports Basic authentication, but generally the preferred authentication method is "),e("a",{attrs:{href:"#openid-connect-authentication"}},[t._v("OpenID Connect")]),t._v(" due to better security mechanisms implemented in the OpenID Connect protocol.")])]),t._v(" "),e("h3",{attrs:{id:"basic-authentication"}},[e("a",{staticClass:"header-anchor",attrs:{href:"#basic-authentication"}},[t._v("#")]),t._v(" Basic Authentication")]),t._v(" "),e("p",[t._v("The Basic authentication method is a common way of authenticate HTTP requests given username and password.")]),t._v(" "),e("p",[t._v("The following code snippet shows how to log in via Basic authentication:")]),t._v(" "),e("div",{staticClass:"language-python extra-class"},[e("pre",{pre:!0,attrs:{class:"language-python"}},[e("code",[e("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("print")]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),e("span",{pre:!0,attrs:{class:"token string"}},[t._v('"Authenticate with Basic authentication"')]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\nconnection"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),t._v("authenticate_basic"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),e("span",{pre:!0,attrs:{class:"token string"}},[t._v('"username"')]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),e("span",{pre:!0,attrs:{class:"token string"}},[t._v('"password"')]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n")])])]),e("div",{staticClass:"custom-block tip"},[e("p",{staticClass:"custom-block-title"},[t._v("TIP")]),t._v(" "),e("p",[t._v("You can get username and password here: "),e("a",{attrs:{href:"https://github.com/Open-EO/openeo-earthengine-driver#demo",target:"_blank",rel:"noopener noreferrer"}},[t._v("https://github.com/Open-EO/openeo-earthengine-driver#demo"),e("OutboundLink")],1)])]),t._v(" "),e("p",[t._v("After successfully calling the "),e("a",{attrs:{href:"https://open-eo.github.io/openeo-python-client/api.html#openeo.rest.connection.Connection.authenticate_basic",target:"_blank",rel:"noopener noreferrer"}},[e("code",[t._v("authenticate_basic")]),e("OutboundLink")],1),t._v(" method, you are logged into the back-end with your account.")]),t._v(" "),e("p",[t._v("This means, that every call that comes after that via the connection variable is executed by your user account.")]),t._v(" "),e("h3",{attrs:{id:"openid-connect-authentication"}},[e("a",{staticClass:"header-anchor",attrs:{href:"#openid-connect-authentication"}},[t._v("#")]),t._v(" OpenID Connect Authentication")]),t._v(" "),e("div",{staticClass:"custom-block warning"},[e("p",{staticClass:"custom-block-title"},[t._v("WARNING")]),t._v(" "),e("p",[t._v("For Google Earth Engine, only "),e("a",{attrs:{href:"#basic-authentication"}},[t._v("Basic Authentication")]),t._v(" is supported at the moment.")])]),t._v(" "),e("p",[t._v("The OIDC ("),e("a",{attrs:{href:"https://openid.net/connect/",target:"_blank",rel:"noopener noreferrer"}},[t._v("OpenID Connect"),e("OutboundLink")],1),t._v(") authentication can be used to authenticate via an external service given a client ID.\nThe following code snippet shows how to log in via OIDC authentication:")]),t._v(" "),e("div",{staticClass:"language-python extra-class"},[e("pre",{pre:!0,attrs:{class:"language-python"}},[e("code",[e("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("print")]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),e("span",{pre:!0,attrs:{class:"token string"}},[t._v('"Authenticate with OIDC authentication"')]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\nconnection"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),t._v("authenticate_oidc"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n")])])]),e("p",[t._v("Calling this method opens your system web browser, with which you can authenticate yourself on the back-end authentication system.\nAfter that the website will give you the instructions to go back to the python client, where your connection has logged your account in.\nThis means that every call that comes after that via the connection variable is executed by your user account.")]),t._v(" "),e("h2",{attrs:{id:"working-with-datacube"}},[e("a",{staticClass:"header-anchor",attrs:{href:"#working-with-datacube"}},[t._v("#")]),t._v(" Working with Datacube")]),t._v(" "),e("p",[t._v("Now that we know how to discover the capabilities of the back-end and how to authenticate,\nlet's do some real work and process some EO data in a batch job.\nWe'll build the desired algorithm by working on so-called \"Datacubes\",\nwhich is the central concept in openEO to represent EO data,\nas "),e("RouterLink",{attrs:{to:"/documentation/1.0/datacubes.html"}},[t._v("discussed in great detail here")]),t._v(".")],1),t._v(" "),e("h3",{attrs:{id:"creating-a-datacube"}},[e("a",{staticClass:"header-anchor",attrs:{href:"#creating-a-datacube"}},[t._v("#")]),t._v(" Creating a Datacube")]),t._v(" "),e("p",[t._v("The first step is loading the desired slice of a data collection\nwith "),e("a",{attrs:{href:"https://open-eo.github.io/openeo-python-client/api.html#openeo.rest.connection.Connection.load_collection",target:"_blank",rel:"noopener noreferrer"}},[e("code",[t._v("Connection.load_collection")]),e("OutboundLink")],1),t._v(":")]),t._v(" "),e("div",{staticClass:"language-python extra-class"},[e("pre",{pre:!0,attrs:{class:"language-python"}},[e("code",[t._v("datacube "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" connection"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),t._v("load_collection"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("\n "),e("span",{pre:!0,attrs:{class:"token string"}},[t._v('"SENTINEL1_GRD"')]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n spatial_extent"),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("{")]),e("span",{pre:!0,attrs:{class:"token string"}},[t._v('"west"')]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(":")]),t._v(" "),e("span",{pre:!0,attrs:{class:"token number"}},[t._v("16.06")]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),e("span",{pre:!0,attrs:{class:"token string"}},[t._v('"south"')]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(":")]),t._v(" "),e("span",{pre:!0,attrs:{class:"token number"}},[t._v("48.06")]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),e("span",{pre:!0,attrs:{class:"token string"}},[t._v('"east"')]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(":")]),t._v(" "),e("span",{pre:!0,attrs:{class:"token number"}},[t._v("16.65")]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),e("span",{pre:!0,attrs:{class:"token string"}},[t._v('"north"')]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(":")]),t._v(" "),e("span",{pre:!0,attrs:{class:"token number"}},[t._v("48.35")]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("}")]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n temporal_extent"),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),e("span",{pre:!0,attrs:{class:"token string"}},[t._v('"2017-03-01"')]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),e("span",{pre:!0,attrs:{class:"token string"}},[t._v('"2017-04-01"')]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n bands"),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),e("span",{pre:!0,attrs:{class:"token string"}},[t._v('"VV"')]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),e("span",{pre:!0,attrs:{class:"token string"}},[t._v('"VH"')]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),t._v("\n"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n")])])]),e("p",[t._v("This results in a "),e("a",{attrs:{href:"https://open-eo.github.io/openeo-python-client/api.html#openeo.rest.datacube.DataCube",target:"_blank",rel:"noopener noreferrer"}},[e("code",[t._v("Datacube")]),t._v(" object"),e("OutboundLink")],1),t._v('\ncontaining the "SENTINEL1_GRD" data restricted to the given spatial extent,\nthe given temporal extend and the given bands .')]),t._v(" "),e("div",{staticClass:"custom-block tip"},[e("p",{staticClass:"custom-block-title"},[t._v("TIP")]),t._v(" "),e("p",[t._v("You can also filter the datacube step by step or at a later stage by using the following filter methods:")]),t._v(" "),e("div",{staticClass:"language-python extra-class"},[e("pre",{pre:!0,attrs:{class:"language-python"}},[e("code",[t._v("datacube "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" datacube"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),t._v("filter_bbox"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("west"),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),e("span",{pre:!0,attrs:{class:"token number"}},[t._v("16.06")]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" south"),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),e("span",{pre:!0,attrs:{class:"token number"}},[t._v("48.06")]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" east"),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),e("span",{pre:!0,attrs:{class:"token number"}},[t._v("16.65")]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" north"),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),e("span",{pre:!0,attrs:{class:"token number"}},[t._v("48.35")]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\ndatacube "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" datacube"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),t._v("filter_temporal"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("start_date"),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),e("span",{pre:!0,attrs:{class:"token string"}},[t._v('"2017-03-01"')]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" end_date"),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),e("span",{pre:!0,attrs:{class:"token string"}},[t._v('"2017-04-01"')]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\ndatacube "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" datacube"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),t._v("filter_bands"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),e("span",{pre:!0,attrs:{class:"token string"}},[t._v('"VV"')]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),e("span",{pre:!0,attrs:{class:"token string"}},[t._v('"VH"')]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n")])])]),e("p",[t._v("Still, it is recommended to always use the filters directly in "),e("a",{attrs:{href:"https://open-eo.github.io/openeo-python-client/api.html#openeo.rest.connection.Connection.load_collection",target:"_blank",rel:"noopener noreferrer"}},[t._v("load_collection"),e("OutboundLink")],1),t._v("\nto avoid loading too much data upfront.")])]),t._v(" "),e("h3",{attrs:{id:"applying-processes"}},[e("a",{staticClass:"header-anchor",attrs:{href:"#applying-processes"}},[t._v("#")]),t._v(" Applying processes")]),t._v(" "),e("p",[t._v("By applying an openEO process on a datacube, we create a new datacube object that represents the manipulated data.\nThe standard way to do this with the Python client is to call the appropriate "),e("a",{attrs:{href:"https://open-eo.github.io/openeo-python-client/api.html#openeo.rest.datacube.DataCube",target:"_blank",rel:"noopener noreferrer"}},[e("code",[t._v("Datacube")]),t._v(" object"),e("OutboundLink")],1),t._v(" method.\nThe most common or popular openEO processes have a dedicated "),e("code",[t._v("Datacube")]),t._v(" method (e.g. "),e("code",[t._v("mask")]),t._v(", "),e("code",[t._v("aggregate_spatial")]),t._v(", "),e("code",[t._v("filter_bbox")]),t._v(", ...).\nOther processes without a dedicated method can still be applied in a generic way.\nAn on top of that, there are also some convenience methods that implement\nopenEO processes is a compact, Pythonic interface.")]),t._v(" "),e("p",[t._v("For example, the "),e("a",{attrs:{href:"https://open-eo.github.io/openeo-python-client/api.html#openeo.rest.datacube.DataCube.min_time",target:"_blank",rel:"noopener noreferrer"}},[e("code",[t._v("min_time")]),e("OutboundLink")],1),t._v(" method\nimplements a "),e("code",[t._v("reduce_dimension")]),t._v(" process along the temporal dimension, using the "),e("code",[t._v("min")]),t._v(" process as reducer function:")]),t._v(" "),e("div",{staticClass:"language-python extra-class"},[e("pre",{pre:!0,attrs:{class:"language-python"}},[e("code",[t._v("datacube "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" datacube"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),t._v("min_time"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n")])])]),e("p",[t._v("This creates a new datacube (we overwrite the existing variable),\nwhere the time dimension is eliminated and for each pixel we just have\nthe minimum value of the corresponding timeseries in the original datacube.")]),t._v(" "),e("p",[t._v("See the "),e("a",{attrs:{href:"https://open-eo.github.io/openeo-python-client/api.html#openeo.rest.datacube.DataCube",target:"_blank",rel:"noopener noreferrer"}},[t._v("Python client "),e("code",[t._v("Datacube")]),t._v(" API"),e("OutboundLink")],1),t._v(" for a more complete listing of methods that implement openEO processes.")]),t._v(" "),e("p",[t._v("openEO processes that are not supported by a dedicated "),e("code",[t._v("Datacube")]),t._v(" method\ncan be applied in a generic way with the "),e("a",{attrs:{href:"https://open-eo.github.io/openeo-python-client/api.html#openeo.rest.datacube.DataCube.process",target:"_blank",rel:"noopener noreferrer"}},[e("code",[t._v("process")]),t._v(" method"),e("OutboundLink")],1),t._v(", e.g.:")]),t._v(" "),e("div",{staticClass:"language-python extra-class"},[e("pre",{pre:!0,attrs:{class:"language-python"}},[e("code",[t._v("datacube "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" datacube"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),t._v("process"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("\n process_id"),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),e("span",{pre:!0,attrs:{class:"token string"}},[t._v('"ndvi"')]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" \n arguments"),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("{")]),t._v("\n "),e("span",{pre:!0,attrs:{class:"token string"}},[t._v('"data"')]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(":")]),t._v(" datacube"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" \n "),e("span",{pre:!0,attrs:{class:"token string"}},[t._v('"nir"')]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(":")]),t._v(" "),e("span",{pre:!0,attrs:{class:"token string"}},[t._v('"B8"')]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" \n "),e("span",{pre:!0,attrs:{class:"token string"}},[t._v('"red"')]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(":")]),t._v(" "),e("span",{pre:!0,attrs:{class:"token string"}},[t._v('"B4"')]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("}")]),t._v("\n"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n")])])]),e("p",[t._v("This applies the "),e("a",{attrs:{href:"https://docs.openeo.cloud/processes/#ndvi",target:"_blank",rel:"noopener noreferrer"}},[e("code",[t._v("ndvi")]),t._v(" process"),e("OutboundLink")],1),t._v(' to the datacube with the arguments of "data", "nir" and "red" (This example assumes a datacube with bands '),e("code",[t._v("B8")]),t._v(" and "),e("code",[t._v("B4")]),t._v(").")]),t._v(" "),e("div",{staticClass:"custom-block tip"},[e("p",{staticClass:"custom-block-title"},[t._v("Note")]),t._v(" "),e("p",[t._v("Still unsure on how to make use of processes with the Python client?\nVisit the "),e("a",{attrs:{href:"https://open-eo.github.io/openeo-python-client/processes.html#working-with-processes",target:"_blank",rel:"noopener noreferrer"}},[t._v("official documentation on working with processes"),e("OutboundLink")],1),t._v(".")])]),t._v(" "),e("h3",{attrs:{id:"defining-output-format"}},[e("a",{staticClass:"header-anchor",attrs:{href:"#defining-output-format"}},[t._v("#")]),t._v(" Defining output format")]),t._v(" "),e("p",[t._v("After applying all processes you want to execute, we need to tell the back-end to export the datacube, for example as GeoTiff:")]),t._v(" "),e("div",{staticClass:"language-python extra-class"},[e("pre",{pre:!0,attrs:{class:"language-python"}},[e("code",[t._v("result "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" datacube"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),t._v("save_result"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),e("span",{pre:!0,attrs:{class:"token string"}},[t._v('"GTiff"')]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n")])])]),e("h2",{attrs:{id:"execution"}},[e("a",{staticClass:"header-anchor",attrs:{href:"#execution"}},[t._v("#")]),t._v(" Execution")]),t._v(" "),e("p",[t._v("It's important to note that all the datacube processes we applied up to this point\nare not actually executed yet, neither locally nor remotely on the back-end.\nWe just built an abstract representation of the algorithm (input data and processing chain),\nencapsulated in a local "),e("code",[t._v("Datacube")]),t._v(" object (e.g. the "),e("code",[t._v("result")]),t._v(" variable above).\nTo trigger an actual execution (on the back-end) we have to explicitly send this representation\nto the back-end.")]),t._v(" "),e("p",[t._v("openEO defines "),e("RouterLink",{attrs:{to:"/documentation/1.0/glossary.html#data-processing-modes"}},[t._v("several processing modes")]),t._v(",\nbut for this introduction we'll focus on batch jobs, which is a good default choice.")],1),t._v(" "),e("h3",{attrs:{id:"batch-job-execution"}},[e("a",{staticClass:"header-anchor",attrs:{href:"#batch-job-execution"}},[t._v("#")]),t._v(" Batch job execution")]),t._v(" "),e("p",[t._v("The "),e("code",[t._v("result")]),t._v(" datacube object we built above describes the desired input collections, processing steps and output format.\nWe can now just send this description to the back-end to create a batch job with the "),e("a",{attrs:{href:"https://open-eo.github.io/openeo-python-client/api.html#openeo.rest.datacube.DataCube.create_job",target:"_blank",rel:"noopener noreferrer"}},[e("code",[t._v("create_job")]),t._v(" method"),e("OutboundLink")],1),t._v(" like this:")]),t._v(" "),e("div",{staticClass:"language-python extra-class"},[e("pre",{pre:!0,attrs:{class:"language-python"}},[e("code",[e("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# Creating a new job at the back-end by sending the datacube information.")]),t._v("\njob "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" result"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),t._v("create_job"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n")])])]),e("p",[t._v("The batch job, which is referenced by the returned "),e("code",[t._v("job")]),t._v(" object, is just created at the back-end,\nit is not started yet.\nTo start the job and let your Python script wait until the job has finished then\ndownload it automatically, you can use the "),e("code",[t._v("start_and_wait")]),t._v(" method.")]),t._v(" "),e("div",{staticClass:"language-python extra-class"},[e("pre",{pre:!0,attrs:{class:"language-python"}},[e("code",[e("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# Starts the job and waits until it finished to download the result.")]),t._v("\njob"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),t._v("start_and_wait"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\njob"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),t._v("get_results"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),t._v("download_files"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),e("span",{pre:!0,attrs:{class:"token string"}},[t._v('"output"')]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n")])])]),e("p",[t._v('When everything completes successfully, the processing result will be downloaded as a GeoTIFF file\nin a folder "output".')]),t._v(" "),e("div",{staticClass:"custom-block tip"},[e("p",{staticClass:"custom-block-title"},[t._v("TIP")]),t._v(" "),e("p",[t._v("The official openEO Python Client documentation has more information\non "),e("a",{attrs:{href:"https://open-eo.github.io/openeo-python-client/basics.html#managing-jobs-in-openeo",target:"_blank",rel:"noopener noreferrer"}},[t._v("batch job basics"),e("OutboundLink")],1),t._v("\nor "),e("a",{attrs:{href:"https://open-eo.github.io/openeo-python-client/batch_jobs.html",target:"_blank",rel:"noopener noreferrer"}},[t._v("more detailed batch job (result) management"),e("OutboundLink")],1)])]),t._v(" "),e("h2",{attrs:{id:"full-example"}},[e("a",{staticClass:"header-anchor",attrs:{href:"#full-example"}},[t._v("#")]),t._v(" Full Example")]),t._v(" "),e("p",[t._v("In this chapter we will show a full example of an earth observation use case using the Python client and the Google Earth Engine back-end.")]),t._v(" "),e("div",{staticClass:"custom-block tip"},[e("p",{staticClass:"custom-block-title"},[t._v("Use Case")]),t._v(" "),e("p",[t._v("We want to produce a monthly RGB composite of Sentinel 1 backscatter data over the area of Vienna, Austria for three\nmonths in 2017. This can be used for classification and crop monitoring.")])]),t._v(" "),e("p",[t._v("In the following code example, we use inline code comments to describe what we are doing.")]),t._v(" "),e("div",{staticClass:"custom-block warning"},[e("p",{staticClass:"custom-block-title"},[t._v("WARNING")]),t._v(" "),e("p",[t._v("The username and password in the example above work at the time of writing, but may be invalid at the time you read this. Please "),e("RouterLink",{attrs:{to:"/contact.html"}},[t._v("contact us")]),t._v(" for credentials.")],1)]),t._v(" "),e("div",{staticClass:"language-python extra-class"},[e("pre",{pre:!0,attrs:{class:"language-python"}},[e("code",[e("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("import")]),t._v(" openeo\n\n"),e("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# First, we connect to the back-end and authenticate ourselves via Basic authentication. ")]),t._v("\ncon "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" openeo"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),t._v("connect"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),e("span",{pre:!0,attrs:{class:"token string"}},[t._v('"https://earthengine.openeo.org"')]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\ncon"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),t._v("authenticate_basic"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),e("span",{pre:!0,attrs:{class:"token string"}},[t._v('"group11"')]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),e("span",{pre:!0,attrs:{class:"token string"}},[t._v('"test123"')]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n\n"),e("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# Now that we are connected, we can initialize our datacube object with the area around Vienna ")]),t._v("\n"),e("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# and the time range of interest using Sentinel 1 data.")]),t._v("\ndatacube "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" con"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),t._v("load_collection"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),e("span",{pre:!0,attrs:{class:"token string"}},[t._v('"COPERNICUS/S1_GRD"')]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n spatial_extent"),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("{")]),e("span",{pre:!0,attrs:{class:"token string"}},[t._v('"west"')]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(":")]),t._v(" "),e("span",{pre:!0,attrs:{class:"token number"}},[t._v("16.06")]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),e("span",{pre:!0,attrs:{class:"token string"}},[t._v('"south"')]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(":")]),t._v(" "),e("span",{pre:!0,attrs:{class:"token number"}},[t._v("48.06")]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),e("span",{pre:!0,attrs:{class:"token string"}},[t._v('"east"')]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(":")]),t._v(" "),e("span",{pre:!0,attrs:{class:"token number"}},[t._v("16.65")]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),e("span",{pre:!0,attrs:{class:"token string"}},[t._v('"north"')]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(":")]),t._v(" "),e("span",{pre:!0,attrs:{class:"token number"}},[t._v("48.35")]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("}")]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n temporal_extent"),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),e("span",{pre:!0,attrs:{class:"token string"}},[t._v('"2017-03-01"')]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),e("span",{pre:!0,attrs:{class:"token string"}},[t._v('"2017-06-01"')]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n bands"),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),e("span",{pre:!0,attrs:{class:"token string"}},[t._v('"VV"')]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n\n"),e("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# Since we are creating a monthly RGB composite, we need three (R, G and B) separated time ranges.")]),t._v("\n"),e("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# Therefore, we split the datacube into three datacubes by filtering temporal for March, April and May. ")]),t._v("\nmarch "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" datacube"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),t._v("filter_temporal"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),e("span",{pre:!0,attrs:{class:"token string"}},[t._v('"2017-03-01"')]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),e("span",{pre:!0,attrs:{class:"token string"}},[t._v('"2017-04-01"')]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\napril "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" datacube"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),t._v("filter_temporal"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),e("span",{pre:!0,attrs:{class:"token string"}},[t._v('"2017-04-01"')]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),e("span",{pre:!0,attrs:{class:"token string"}},[t._v('"2017-05-01"')]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\nmay "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" datacube"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),t._v("filter_temporal"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),e("span",{pre:!0,attrs:{class:"token string"}},[t._v('"2017-05-01"')]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),e("span",{pre:!0,attrs:{class:"token string"}},[t._v('"2017-06-01"')]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n\n"),e("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# Now that we split it into the correct time range, we have to aggregate the timeseries values into a single image.")]),t._v("\n"),e("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# Therefore, we make use of the Python Client function `mean_time`, which reduces the time dimension, ")]),t._v("\n"),e("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# by taking for every timeseries the mean value.")]),t._v("\n\nmean_march "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" march"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),t._v("mean_time"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\nmean_april "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" april"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),t._v("mean_time"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\nmean_may "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" may"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),t._v("mean_time"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n\n"),e("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# Now the three images will be combined into the temporal composite. ")]),t._v("\n"),e("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# Before merging them into one datacube, we need to rename the bands of the images, because otherwise, ")]),t._v("\n"),e("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# they would be overwritten in the merging process. ")]),t._v("\n"),e("span",{pre:!0,attrs:{class:"token comment"}},[t._v('# Therefore, we rename the bands of the datacubes using the `rename_labels` process to "R", "G" and "B".')]),t._v("\n"),e("span",{pre:!0,attrs:{class:"token comment"}},[t._v('# After that we merge them into the "RGB" datacube, which has now three bands ("R", "G" and "B")')]),t._v("\n\nR_band "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" mean_march"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),t._v("rename_labels"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("dimension"),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),e("span",{pre:!0,attrs:{class:"token string"}},[t._v('"bands"')]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" target"),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),e("span",{pre:!0,attrs:{class:"token string"}},[t._v('"R"')]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\nG_band "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" mean_april"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),t._v("rename_labels"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("dimension"),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),e("span",{pre:!0,attrs:{class:"token string"}},[t._v('"bands"')]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" target"),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),e("span",{pre:!0,attrs:{class:"token string"}},[t._v('"G"')]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\nB_band "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" mean_may"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),t._v("rename_labels"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("dimension"),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),e("span",{pre:!0,attrs:{class:"token string"}},[t._v('"bands"')]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" target"),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),e("span",{pre:!0,attrs:{class:"token string"}},[t._v('"B"')]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n\nRG "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" R_band"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),t._v("merge_cubes"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("G_band"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\nRGB "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" RG"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),t._v("merge_cubes"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("B_band"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n\n\n"),e("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# Last but not least, we add the process to save the result of the processing. There we define that ")]),t._v("\n"),e("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# the result should be a GeoTiff file.")]),t._v("\n"),e("span",{pre:!0,attrs:{class:"token comment"}},[t._v('# We also set, which band should be used for "red", "green" and "blue" color in the options.')]),t._v("\n\nRGB "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" RGB"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),t._v("save_result"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),e("span",{pre:!0,attrs:{class:"token builtin"}},[t._v("format")]),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),e("span",{pre:!0,attrs:{class:"token string"}},[t._v('"GTIFF-THUMB"')]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n\n"),e("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# With the last process we have finished the datacube definition and can create and start the job at the back-end.")]),t._v("\n\njob "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" RGB"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),t._v("create_job"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\njob"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),t._v("start_and_wait"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),t._v("download_results"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n")])])]),e("p",[t._v("Now the resulting GTiff file of the RGB backscatter composite is in your current directory.")]),t._v(" "),e("p",[e("img",{attrs:{src:a(193),alt:"RGB composite"}})]),t._v(" "),e("p",[t._v("The "),e("a",{attrs:{href:"https://github.com/Open-EO/openeo-python-client/blob/c21b928ab5f4b4561bb07b7c4a934f0ea9b4f0b8/examples/gee_uc1_temp.py",target:"_blank",rel:"noopener noreferrer"}},[t._v("source code"),e("OutboundLink")],1),t._v(" of this example can be found on GitHub.")]),t._v(" "),e("h2",{attrs:{id:"user-defined-functions"}},[e("a",{staticClass:"header-anchor",attrs:{href:"#user-defined-functions"}},[t._v("#")]),t._v(" User Defined Functions")]),t._v(" "),e("p",[t._v("If your use case can not be accomplished with the "),e("RouterLink",{attrs:{to:"/documentation/1.0/processes.html"}},[t._v("default processes")]),t._v(" of openEO, you can define a "),e("RouterLink",{attrs:{to:"/documentation/1.0/glossary.html#user-defined-function-udf"}},[t._v("user defined function")]),t._v(".\nTherefore, you can create a Python function that will be executed at the back-end and functions as a process in your process graph.")],1),t._v(" "),e("p",[t._v("Detailed information about Python UDFs can be found in the "),e("a",{attrs:{href:"https://open-eo.github.io/openeo-python-client/udf.html",target:"_blank",rel:"noopener noreferrer"}},[t._v("official documentation"),e("OutboundLink")],1),t._v(" as well as examples in the "),e("a",{attrs:{href:"https://github.com/Open-EO/openeo-python-client/tree/master/examples/udf",target:"_blank",rel:"noopener noreferrer"}},[t._v("Python client repository"),e("OutboundLink")],1),t._v(".")]),t._v(" "),e("h2",{attrs:{id:"additional-information"}},[e("a",{staticClass:"header-anchor",attrs:{href:"#additional-information"}},[t._v("#")]),t._v(" Additional Information")]),t._v(" "),e("p",[t._v("Additional information and resources about the openEO Python Client Library:")]),t._v(" "),e("ul",[e("li",[e("a",{attrs:{href:"https://github.com/Open-EO/openeo-python-client/tree/master/examples",target:"_blank",rel:"noopener noreferrer"}},[t._v("Example scripts"),e("OutboundLink")],1)]),t._v(" "),e("li",[e("a",{attrs:{href:"https://github.com/Open-EO/openeo-python-client/tree/master/examples/notebooks",target:"_blank",rel:"noopener noreferrer"}},[t._v("Example Jupyter Notebooks"),e("OutboundLink")],1)]),t._v(" "),e("li",[e("a",{attrs:{href:"https://open-eo.github.io/openeo-python-client/",target:"_blank",rel:"noopener noreferrer"}},[t._v("Official openEO Python Client Library Documentation"),e("OutboundLink")],1)]),t._v(" "),e("li",[e("a",{attrs:{href:"https://github.com/Open-EO/openeo-python-client",target:"_blank",rel:"noopener noreferrer"}},[t._v("Repository on GitHub"),e("OutboundLink")],1)])])])}),[],!1,null,null,null);e.default=s.exports}}]); \ No newline at end of file +(window.webpackJsonp=window.webpackJsonp||[]).push([[47],{193:function(t,e,a){t.exports=a.p+"assets/img/getting-started-result-example.7820ee84.jpg"},530:function(t,e,a){"use strict";a.r(e);var n=a(4),s=Object(n.a)({},(function(){var t=this,e=t._self._c;return e("ContentSlotsDistributor",{attrs:{"slot-key":t.$parent.slotKey}},[e("h1",{attrs:{id:"python-client"}},[e("a",{staticClass:"header-anchor",attrs:{href:"#python-client"}},[t._v("#")]),t._v(" Python Client")]),t._v(" "),e("p",[t._v("This Getting Started guide will give you just a simple overview of the capabilities of the openEO Python client library.\nMore in-depth information can be found in its "),e("a",{attrs:{href:"https://open-eo.github.io/openeo-python-client/",target:"_blank",rel:"noopener noreferrer"}},[t._v("official documentation"),e("OutboundLink")],1),t._v(".")]),t._v(" "),e("h2",{attrs:{id:"installation"}},[e("a",{staticClass:"header-anchor",attrs:{href:"#installation"}},[t._v("#")]),t._v(" Installation")]),t._v(" "),e("p",[t._v("The openEO Python client library is available on "),e("a",{attrs:{href:"https://pypi.org/project/openeo/",target:"_blank",rel:"noopener noreferrer"}},[t._v("PyPI"),e("OutboundLink")],1),t._v("\nand can easily be installed with a tool like "),e("code",[t._v("pip")]),t._v(", for example:")]),t._v(" "),e("div",{staticClass:"language-shell script extra-class"},[e("pre",{pre:!0,attrs:{class:"language-shell"}},[e("code",[t._v("pip "),e("span",{pre:!0,attrs:{class:"token function"}},[t._v("install")]),t._v(" openeo\n")])])]),e("p",[t._v("The client library is also available on "),e("a",{attrs:{href:"https://anaconda.org/conda-forge/openeo",target:"_blank",rel:"noopener noreferrer"}},[t._v("Conda Forge"),e("OutboundLink")],1),t._v(".")]),t._v(" "),e("p",[t._v("It's recommended to work in a virtual environment of some kind ("),e("code",[t._v("venv")]),t._v(", "),e("code",[t._v("conda")]),t._v(", ...),\ncontaining Python 3.6 or higher.")]),t._v(" "),e("div",{staticClass:"custom-block tip"},[e("p",{staticClass:"custom-block-title"},[t._v("TIP")]),t._v(" "),e("p",[t._v("For more details, alternative installation procedures or troubleshooting tips:\nsee the "),e("a",{attrs:{href:"https://open-eo.github.io/openeo-python-client/installation.html",target:"_blank",rel:"noopener noreferrer"}},[t._v("official "),e("code",[t._v("openeo")]),t._v(" package installation documentation"),e("OutboundLink")],1),t._v(".")])]),t._v(" "),e("h2",{attrs:{id:"exploring-a-back-end"}},[e("a",{staticClass:"header-anchor",attrs:{href:"#exploring-a-back-end"}},[t._v("#")]),t._v(" Exploring a back-end")]),t._v(" "),e("p",[t._v("If you do not know an openEO back-end that you want to connect to yet, you can have a look at the "),e("a",{attrs:{href:"https://hub.openeo.org/",target:"_blank",rel:"noopener noreferrer"}},[t._v("openEO Hub"),e("OutboundLink")],1),t._v(", to find all known back-ends with information on their capabilities.")]),t._v(" "),e("p",[t._v("For this tutorial we will use the openEO instance of Google Earth Engine, which is available at "),e("code",[t._v("https://earthengine.openeo.org")]),t._v(".\nNote that the code snippets in this guide work the same way for the other back-ends listed in the openEO Hub. Just the collection identifier and band names might differ.")]),t._v(" "),e("p",[t._v("First we need to establish a connection to the back-end.")]),t._v(" "),e("div",{staticClass:"language-python extra-class"},[e("pre",{pre:!0,attrs:{class:"language-python"}},[e("code",[e("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("import")]),t._v(" openeo\n\nconnection "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" openeo"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),t._v("connect"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),e("span",{pre:!0,attrs:{class:"token string"}},[t._v('"https://earthengine.openeo.org"')]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n")])])]),e("p",[t._v("The "),e("a",{attrs:{href:"https://open-eo.github.io/openeo-python-client/api.html#module-openeo.rest.connection",target:"_blank",rel:"noopener noreferrer"}},[e("code",[t._v("Connection")]),t._v(" object"),e("OutboundLink")],1),t._v("\nis your central gateway to")]),t._v(" "),e("ul",[e("li",[t._v("list data collections, available processes, file formats and other capabilities of the back-end")]),t._v(" "),e("li",[t._v("start building your openEO algorithm from the desired data on the back-end")]),t._v(" "),e("li",[t._v("execute and monitor (batch) jobs on the back-end")]),t._v(" "),e("li",[t._v("etc.")])]),t._v(" "),e("h3",{attrs:{id:"collections"}},[e("a",{staticClass:"header-anchor",attrs:{href:"#collections"}},[t._v("#")]),t._v(" Collections")]),t._v(" "),e("p",[t._v('The EO data available at a back-end is organised in so-called collections.\nFor example, a back-end might provide fundamental satellite collections like "Sentinel 1" or "Sentinel 2",\nor preprocessed collections like "NDVI".\nCollections are used as input data for your openEO jobs.')]),t._v(" "),e("div",{staticClass:"custom-block tip"},[e("p",{staticClass:"custom-block-title"},[t._v("Note")]),t._v(" "),e("p",[t._v('More information on how openEO "collections" relate to terminology used in other systems can be found in\n('),e("RouterLink",{attrs:{to:"/documentation/1.0/glossary.html#eo-data-collections"}},[t._v("the openEO glossary")]),t._v(").")],1)]),t._v(" "),e("p",[t._v("Let's list all available collections on the back-end,\nusing "),e("a",{attrs:{href:"https://open-eo.github.io/openeo-python-client/api.html#openeo.rest.connection.Connection.list_collections",target:"_blank",rel:"noopener noreferrer"}},[e("code",[t._v("list_collections")]),e("OutboundLink")],1),t._v(":")]),t._v(" "),e("div",{staticClass:"language-python extra-class"},[e("pre",{pre:!0,attrs:{class:"language-python"}},[e("code",[e("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("print")]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("connection"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),t._v("list_collections"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n")])])]),e("p",[t._v("which returns list of collection metadata dictionaries, e.g. something like:")]),t._v(" "),e("div",{staticClass:"language- extra-class"},[e("pre",{pre:!0,attrs:{class:"language-text"}},[e("code",[t._v("[{'id': 'AGERA5', 'title': 'ECMWF AGERA5 meteo dataset', 'description': 'Daily surface meteorolociga datal ...', ...},\n {'id': 'SENTINEL2_L2A_SENTINELHUB', 'title': 'Sentinel-2 top of canopy', ...},\n {'id': 'SENTINEL1_GRD', ...},\n ...]\n")])])]),e("p",[t._v("This listing includes basic metadata for each collection.\nIf necessary, a more detailed metadata listing for a given collection can be obtained with\n"),e("a",{attrs:{href:"https://open-eo.github.io/openeo-python-client/api.html#openeo.rest.connection.Connection.describe_collection",target:"_blank",rel:"noopener noreferrer"}},[e("code",[t._v("describe_collection")]),e("OutboundLink")],1),t._v(".")]),t._v(" "),e("div",{staticClass:"custom-block tip"},[e("p",{staticClass:"custom-block-title"},[t._v("TIP")]),t._v(" "),e("p",[t._v("Programmatically listing collections is just a very simple usage example of the Python client.\nIn reality, you probably want to look up or inspect available collections in a web based overview such as the "),e("a",{attrs:{href:"https://hub.openeo.org/",target:"_blank",rel:"noopener noreferrer"}},[t._v("openEO Hub"),e("OutboundLink")],1),t._v(".")])]),t._v(" "),e("h3",{attrs:{id:"processes"}},[e("a",{staticClass:"header-anchor",attrs:{href:"#processes"}},[t._v("#")]),t._v(" Processes")]),t._v(" "),e("p",[t._v('Processes in openEO are operations that can be applied on (EO) data\n(e.g. calculate the mean of an array, or mask out observations outside a given polygon).\nThe output of one process can be used as the input of another process,\nand by doing so, multiple processes can be connected that way in a larger "process graph":\na new (user-defined) processes that implements a certain algorithm.')]),t._v(" "),e("div",{staticClass:"custom-block tip"},[e("p",{staticClass:"custom-block-title"},[t._v("Note")]),t._v(" "),e("p",[t._v("Check "),e("RouterLink",{attrs:{to:"/documentation/1.0/glossary.html#processes"}},[t._v("the openEO glossary")]),t._v("\nfor more details on pre-defined, user-defined processes and process graphs.")],1)]),t._v(" "),e("p",[t._v("Let's list the (pre-defined) processes available on the back-end\nwith "),e("a",{attrs:{href:"https://open-eo.github.io/openeo-python-client/api.html#openeo.rest.connection.Connection.list_processes",target:"_blank",rel:"noopener noreferrer"}},[e("code",[t._v("list_processes")]),e("OutboundLink")],1),t._v(":")]),t._v(" "),e("div",{staticClass:"language-python extra-class"},[e("pre",{pre:!0,attrs:{class:"language-python"}},[e("code",[e("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("print")]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("connection"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),t._v("list_processes"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n")])])]),e("p",[t._v("which returns a list of dictionaries describing the process (including expected arguments and return type), e.g.:")]),t._v(" "),e("div",{staticClass:"language- extra-class"},[e("pre",{pre:!0,attrs:{class:"language-text"}},[e("code",[t._v("[{'id': 'absolute', 'summary': 'Absolute value', 'description': 'Computes the absolute value of a real number `x`, which is th...', \n {'id': 'mean', 'summary': 'Arithmetic mean(average)', ...}\n ...]\n")])])]),e("p",[t._v("Like with collections, instead of programmatic exploration you'll probably prefer a web-based overview such as the "),e("a",{attrs:{href:"https://hub.openeo.org/",target:"_blank",rel:"noopener noreferrer"}},[t._v("openEO Hub"),e("OutboundLink")],1),t._v(" for back-end specific process descriptions\nor browse the "),e("a",{attrs:{href:"https://processes.openeo.org/",target:"_blank",rel:"noopener noreferrer"}},[t._v("reference specifications of openEO processes"),e("OutboundLink")],1),t._v(".")]),t._v(" "),e("h2",{attrs:{id:"authentication"}},[e("a",{staticClass:"header-anchor",attrs:{href:"#authentication"}},[t._v("#")]),t._v(" Authentication")]),t._v(" "),e("p",[t._v("In the code snippets above we did not need to log in\nsince we just queried publicly available back-end information.\nHowever, to run non-trivial processing queries one has to authenticate\nso that permissions, resource usage, etc. can be managed properly.")]),t._v(" "),e("p",[t._v("Depending on the back-end, there might be two different approaches to authenticate.\nYou need to inform yourself at your back-end provider of choice, which authentication approach you have to carry out.\nYou can also have a look at the "),e("a",{attrs:{href:"https://hub.openeo.org/",target:"_blank",rel:"noopener noreferrer"}},[t._v("openEO Hub"),e("OutboundLink")],1),t._v(" to see the available authentication types of the back-ends.")]),t._v(" "),e("p",[t._v("A detailed description of why and how to use the authentication methods is on the "),e("a",{attrs:{href:"https://open-eo.github.io/openeo-python-client/auth.html#authentication-and-account-management",target:"_blank",rel:"noopener noreferrer"}},[t._v("official documentation"),e("OutboundLink")],1),t._v(".")]),t._v(" "),e("div",{staticClass:"custom-block tip"},[e("p",{staticClass:"custom-block-title"},[t._v("Recommendation")]),t._v(" "),e("p",[t._v("The Google Earth Engine implementation for openEO only supports Basic authentication, but generally the preferred authentication method is "),e("a",{attrs:{href:"#openid-connect-authentication"}},[t._v("OpenID Connect")]),t._v(" due to better security mechanisms implemented in the OpenID Connect protocol.")])]),t._v(" "),e("h3",{attrs:{id:"basic-authentication"}},[e("a",{staticClass:"header-anchor",attrs:{href:"#basic-authentication"}},[t._v("#")]),t._v(" Basic Authentication")]),t._v(" "),e("p",[t._v("The Basic authentication method is a common way of authenticate HTTP requests given username and password.")]),t._v(" "),e("p",[t._v("The following code snippet shows how to log in via Basic authentication:")]),t._v(" "),e("div",{staticClass:"language-python extra-class"},[e("pre",{pre:!0,attrs:{class:"language-python"}},[e("code",[e("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("print")]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),e("span",{pre:!0,attrs:{class:"token string"}},[t._v('"Authenticate with Basic authentication"')]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\nconnection"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),t._v("authenticate_basic"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),e("span",{pre:!0,attrs:{class:"token string"}},[t._v('"username"')]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),e("span",{pre:!0,attrs:{class:"token string"}},[t._v('"password"')]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n")])])]),e("div",{staticClass:"custom-block tip"},[e("p",{staticClass:"custom-block-title"},[t._v("TIP")]),t._v(" "),e("p",[t._v("You can get username and password here: "),e("a",{attrs:{href:"https://github.com/Open-EO/openeo-earthengine-driver#demo",target:"_blank",rel:"noopener noreferrer"}},[t._v("https://github.com/Open-EO/openeo-earthengine-driver#demo"),e("OutboundLink")],1)])]),t._v(" "),e("p",[t._v("After successfully calling the "),e("a",{attrs:{href:"https://open-eo.github.io/openeo-python-client/api.html#openeo.rest.connection.Connection.authenticate_basic",target:"_blank",rel:"noopener noreferrer"}},[e("code",[t._v("authenticate_basic")]),e("OutboundLink")],1),t._v(" method, you are logged into the back-end with your account.")]),t._v(" "),e("p",[t._v("This means, that every call that comes after that via the connection variable is executed by your user account.")]),t._v(" "),e("h3",{attrs:{id:"openid-connect-authentication"}},[e("a",{staticClass:"header-anchor",attrs:{href:"#openid-connect-authentication"}},[t._v("#")]),t._v(" OpenID Connect Authentication")]),t._v(" "),e("div",{staticClass:"custom-block warning"},[e("p",{staticClass:"custom-block-title"},[t._v("WARNING")]),t._v(" "),e("p",[t._v("For Google Earth Engine, only "),e("a",{attrs:{href:"#basic-authentication"}},[t._v("Basic Authentication")]),t._v(" is supported at the moment.")])]),t._v(" "),e("p",[t._v("The OIDC ("),e("a",{attrs:{href:"https://openid.net/connect/",target:"_blank",rel:"noopener noreferrer"}},[t._v("OpenID Connect"),e("OutboundLink")],1),t._v(") authentication can be used to authenticate via an external service given a client ID.\nThe following code snippet shows how to log in via OIDC authentication:")]),t._v(" "),e("div",{staticClass:"language-python extra-class"},[e("pre",{pre:!0,attrs:{class:"language-python"}},[e("code",[e("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("print")]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),e("span",{pre:!0,attrs:{class:"token string"}},[t._v('"Authenticate with OIDC authentication"')]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\nconnection"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),t._v("authenticate_oidc"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n")])])]),e("p",[t._v("Calling this method opens your system web browser, with which you can authenticate yourself on the back-end authentication system.\nAfter that the website will give you the instructions to go back to the python client, where your connection has logged your account in.\nThis means that every call that comes after that via the connection variable is executed by your user account.")]),t._v(" "),e("h2",{attrs:{id:"working-with-datacube"}},[e("a",{staticClass:"header-anchor",attrs:{href:"#working-with-datacube"}},[t._v("#")]),t._v(" Working with Datacube")]),t._v(" "),e("p",[t._v("Now that we know how to discover the capabilities of the back-end and how to authenticate,\nlet's do some real work and process some EO data in a batch job.\nWe'll build the desired algorithm by working on so-called \"Datacubes\",\nwhich is the central concept in openEO to represent EO data,\nas "),e("RouterLink",{attrs:{to:"/documentation/1.0/datacubes.html"}},[t._v("discussed in great detail here")]),t._v(".")],1),t._v(" "),e("h3",{attrs:{id:"creating-a-datacube"}},[e("a",{staticClass:"header-anchor",attrs:{href:"#creating-a-datacube"}},[t._v("#")]),t._v(" Creating a Datacube")]),t._v(" "),e("p",[t._v("The first step is loading the desired slice of a data collection\nwith "),e("a",{attrs:{href:"https://open-eo.github.io/openeo-python-client/api.html#openeo.rest.connection.Connection.load_collection",target:"_blank",rel:"noopener noreferrer"}},[e("code",[t._v("Connection.load_collection")]),e("OutboundLink")],1),t._v(":")]),t._v(" "),e("div",{staticClass:"language-python extra-class"},[e("pre",{pre:!0,attrs:{class:"language-python"}},[e("code",[t._v("datacube "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" connection"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),t._v("load_collection"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("\n "),e("span",{pre:!0,attrs:{class:"token string"}},[t._v('"SENTINEL1_GRD"')]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n spatial_extent"),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("{")]),e("span",{pre:!0,attrs:{class:"token string"}},[t._v('"west"')]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(":")]),t._v(" "),e("span",{pre:!0,attrs:{class:"token number"}},[t._v("16.06")]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),e("span",{pre:!0,attrs:{class:"token string"}},[t._v('"south"')]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(":")]),t._v(" "),e("span",{pre:!0,attrs:{class:"token number"}},[t._v("48.06")]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),e("span",{pre:!0,attrs:{class:"token string"}},[t._v('"east"')]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(":")]),t._v(" "),e("span",{pre:!0,attrs:{class:"token number"}},[t._v("16.65")]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),e("span",{pre:!0,attrs:{class:"token string"}},[t._v('"north"')]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(":")]),t._v(" "),e("span",{pre:!0,attrs:{class:"token number"}},[t._v("48.35")]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("}")]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n temporal_extent"),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),e("span",{pre:!0,attrs:{class:"token string"}},[t._v('"2017-03-01"')]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),e("span",{pre:!0,attrs:{class:"token string"}},[t._v('"2017-04-01"')]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n bands"),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),e("span",{pre:!0,attrs:{class:"token string"}},[t._v('"VV"')]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),e("span",{pre:!0,attrs:{class:"token string"}},[t._v('"VH"')]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),t._v("\n"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n")])])]),e("p",[t._v("This results in a "),e("a",{attrs:{href:"https://open-eo.github.io/openeo-python-client/api.html#openeo.rest.datacube.DataCube",target:"_blank",rel:"noopener noreferrer"}},[e("code",[t._v("Datacube")]),t._v(" object"),e("OutboundLink")],1),t._v('\ncontaining the "SENTINEL1_GRD" data restricted to the given spatial extent,\nthe given temporal extend and the given bands .')]),t._v(" "),e("div",{staticClass:"custom-block tip"},[e("p",{staticClass:"custom-block-title"},[t._v("TIP")]),t._v(" "),e("p",[t._v("You can also filter the datacube step by step or at a later stage by using the following filter methods:")]),t._v(" "),e("div",{staticClass:"language-python extra-class"},[e("pre",{pre:!0,attrs:{class:"language-python"}},[e("code",[t._v("datacube "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" datacube"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),t._v("filter_bbox"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("west"),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),e("span",{pre:!0,attrs:{class:"token number"}},[t._v("16.06")]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" south"),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),e("span",{pre:!0,attrs:{class:"token number"}},[t._v("48.06")]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" east"),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),e("span",{pre:!0,attrs:{class:"token number"}},[t._v("16.65")]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" north"),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),e("span",{pre:!0,attrs:{class:"token number"}},[t._v("48.35")]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\ndatacube "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" datacube"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),t._v("filter_temporal"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("start_date"),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),e("span",{pre:!0,attrs:{class:"token string"}},[t._v('"2017-03-01"')]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" end_date"),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),e("span",{pre:!0,attrs:{class:"token string"}},[t._v('"2017-04-01"')]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\ndatacube "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" datacube"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),t._v("filter_bands"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),e("span",{pre:!0,attrs:{class:"token string"}},[t._v('"VV"')]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),e("span",{pre:!0,attrs:{class:"token string"}},[t._v('"VH"')]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n")])])]),e("p",[t._v("Still, it is recommended to always use the filters directly in "),e("a",{attrs:{href:"https://open-eo.github.io/openeo-python-client/api.html#openeo.rest.connection.Connection.load_collection",target:"_blank",rel:"noopener noreferrer"}},[t._v("load_collection"),e("OutboundLink")],1),t._v("\nto avoid loading too much data upfront.")])]),t._v(" "),e("h3",{attrs:{id:"applying-processes"}},[e("a",{staticClass:"header-anchor",attrs:{href:"#applying-processes"}},[t._v("#")]),t._v(" Applying processes")]),t._v(" "),e("p",[t._v("By applying an openEO process on a datacube, we create a new datacube object that represents the manipulated data.\nThe standard way to do this with the Python client is to call the appropriate "),e("a",{attrs:{href:"https://open-eo.github.io/openeo-python-client/api.html#openeo.rest.datacube.DataCube",target:"_blank",rel:"noopener noreferrer"}},[e("code",[t._v("Datacube")]),t._v(" object"),e("OutboundLink")],1),t._v(" method.\nThe most common or popular openEO processes have a dedicated "),e("code",[t._v("Datacube")]),t._v(" method (e.g. "),e("code",[t._v("mask")]),t._v(", "),e("code",[t._v("aggregate_spatial")]),t._v(", "),e("code",[t._v("filter_bbox")]),t._v(", ...).\nOther processes without a dedicated method can still be applied in a generic way.\nAn on top of that, there are also some convenience methods that implement\nopenEO processes is a compact, Pythonic interface.")]),t._v(" "),e("p",[t._v("For example, the "),e("a",{attrs:{href:"https://open-eo.github.io/openeo-python-client/api.html#openeo.rest.datacube.DataCube.min_time",target:"_blank",rel:"noopener noreferrer"}},[e("code",[t._v("min_time")]),e("OutboundLink")],1),t._v(" method\nimplements a "),e("code",[t._v("reduce_dimension")]),t._v(" process along the temporal dimension, using the "),e("code",[t._v("min")]),t._v(" process as reducer function:")]),t._v(" "),e("div",{staticClass:"language-python extra-class"},[e("pre",{pre:!0,attrs:{class:"language-python"}},[e("code",[t._v("datacube "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" datacube"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),t._v("min_time"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n")])])]),e("p",[t._v("This creates a new datacube (we overwrite the existing variable),\nwhere the time dimension is eliminated and for each pixel we just have\nthe minimum value of the corresponding timeseries in the original datacube.")]),t._v(" "),e("p",[t._v("See the "),e("a",{attrs:{href:"https://open-eo.github.io/openeo-python-client/api.html#openeo.rest.datacube.DataCube",target:"_blank",rel:"noopener noreferrer"}},[t._v("Python client "),e("code",[t._v("Datacube")]),t._v(" API"),e("OutboundLink")],1),t._v(" for a more complete listing of methods that implement openEO processes.")]),t._v(" "),e("p",[t._v("openEO processes that are not supported by a dedicated "),e("code",[t._v("Datacube")]),t._v(" method\ncan be applied in a generic way with the "),e("a",{attrs:{href:"https://open-eo.github.io/openeo-python-client/api.html#openeo.rest.datacube.DataCube.process",target:"_blank",rel:"noopener noreferrer"}},[e("code",[t._v("process")]),t._v(" method"),e("OutboundLink")],1),t._v(", e.g.:")]),t._v(" "),e("div",{staticClass:"language-python extra-class"},[e("pre",{pre:!0,attrs:{class:"language-python"}},[e("code",[t._v("datacube "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" datacube"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),t._v("process"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("\n process_id"),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),e("span",{pre:!0,attrs:{class:"token string"}},[t._v('"ndvi"')]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" \n arguments"),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("{")]),t._v("\n "),e("span",{pre:!0,attrs:{class:"token string"}},[t._v('"data"')]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(":")]),t._v(" datacube"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" \n "),e("span",{pre:!0,attrs:{class:"token string"}},[t._v('"nir"')]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(":")]),t._v(" "),e("span",{pre:!0,attrs:{class:"token string"}},[t._v('"B8"')]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" \n "),e("span",{pre:!0,attrs:{class:"token string"}},[t._v('"red"')]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(":")]),t._v(" "),e("span",{pre:!0,attrs:{class:"token string"}},[t._v('"B4"')]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("}")]),t._v("\n"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n")])])]),e("p",[t._v("This applies the "),e("a",{attrs:{href:"https://docs.openeo.cloud/processes/#ndvi",target:"_blank",rel:"noopener noreferrer"}},[e("code",[t._v("ndvi")]),t._v(" process"),e("OutboundLink")],1),t._v(' to the datacube with the arguments of "data", "nir" and "red" (This example assumes a datacube with bands '),e("code",[t._v("B8")]),t._v(" and "),e("code",[t._v("B4")]),t._v(").")]),t._v(" "),e("div",{staticClass:"custom-block tip"},[e("p",{staticClass:"custom-block-title"},[t._v("Note")]),t._v(" "),e("p",[t._v("Still unsure on how to make use of processes with the Python client?\nVisit the "),e("a",{attrs:{href:"https://open-eo.github.io/openeo-python-client/processes.html#working-with-processes",target:"_blank",rel:"noopener noreferrer"}},[t._v("official documentation on working with processes"),e("OutboundLink")],1),t._v(".")])]),t._v(" "),e("h3",{attrs:{id:"defining-output-format"}},[e("a",{staticClass:"header-anchor",attrs:{href:"#defining-output-format"}},[t._v("#")]),t._v(" Defining output format")]),t._v(" "),e("p",[t._v("After applying all processes you want to execute, we need to tell the back-end to export the datacube, for example as GeoTiff:")]),t._v(" "),e("div",{staticClass:"language-python extra-class"},[e("pre",{pre:!0,attrs:{class:"language-python"}},[e("code",[t._v("result "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" datacube"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),t._v("save_result"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),e("span",{pre:!0,attrs:{class:"token string"}},[t._v('"GTiff"')]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n")])])]),e("h2",{attrs:{id:"execution"}},[e("a",{staticClass:"header-anchor",attrs:{href:"#execution"}},[t._v("#")]),t._v(" Execution")]),t._v(" "),e("p",[t._v("It's important to note that all the datacube processes we applied up to this point\nare not actually executed yet, neither locally nor remotely on the back-end.\nWe just built an abstract representation of the algorithm (input data and processing chain),\nencapsulated in a local "),e("code",[t._v("Datacube")]),t._v(" object (e.g. the "),e("code",[t._v("result")]),t._v(" variable above).\nTo trigger an actual execution (on the back-end) we have to explicitly send this representation\nto the back-end.")]),t._v(" "),e("p",[t._v("openEO defines "),e("RouterLink",{attrs:{to:"/documentation/1.0/glossary.html#data-processing-modes"}},[t._v("several processing modes")]),t._v(",\nbut for this introduction we'll focus on batch jobs, which is a good default choice.")],1),t._v(" "),e("h3",{attrs:{id:"batch-job-execution"}},[e("a",{staticClass:"header-anchor",attrs:{href:"#batch-job-execution"}},[t._v("#")]),t._v(" Batch job execution")]),t._v(" "),e("p",[t._v("The "),e("code",[t._v("result")]),t._v(" datacube object we built above describes the desired input collections, processing steps and output format.\nWe can now just send this description to the back-end to create a batch job with the "),e("a",{attrs:{href:"https://open-eo.github.io/openeo-python-client/api.html#openeo.rest.datacube.DataCube.create_job",target:"_blank",rel:"noopener noreferrer"}},[e("code",[t._v("create_job")]),t._v(" method"),e("OutboundLink")],1),t._v(" like this:")]),t._v(" "),e("div",{staticClass:"language-python extra-class"},[e("pre",{pre:!0,attrs:{class:"language-python"}},[e("code",[e("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# Creating a new job at the back-end by sending the datacube information.")]),t._v("\njob "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" result"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),t._v("create_job"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n")])])]),e("p",[t._v("The batch job, which is referenced by the returned "),e("code",[t._v("job")]),t._v(" object, is just created at the back-end,\nit is not started yet.\nTo start the job and let your Python script wait until the job has finished then\ndownload it automatically, you can use the "),e("code",[t._v("start_and_wait")]),t._v(" method.")]),t._v(" "),e("div",{staticClass:"language-python extra-class"},[e("pre",{pre:!0,attrs:{class:"language-python"}},[e("code",[e("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# Starts the job and waits until it finished to download the result.")]),t._v("\njob"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),t._v("start_and_wait"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\njob"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),t._v("get_results"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),t._v("download_files"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),e("span",{pre:!0,attrs:{class:"token string"}},[t._v('"output"')]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n")])])]),e("p",[t._v('When everything completes successfully, the processing result will be downloaded as a GeoTIFF file\nin a folder "output".')]),t._v(" "),e("div",{staticClass:"custom-block tip"},[e("p",{staticClass:"custom-block-title"},[t._v("TIP")]),t._v(" "),e("p",[t._v("The official openEO Python Client documentation has more information\non "),e("a",{attrs:{href:"https://open-eo.github.io/openeo-python-client/basics.html#managing-jobs-in-openeo",target:"_blank",rel:"noopener noreferrer"}},[t._v("batch job basics"),e("OutboundLink")],1),t._v("\nor "),e("a",{attrs:{href:"https://open-eo.github.io/openeo-python-client/batch_jobs.html",target:"_blank",rel:"noopener noreferrer"}},[t._v("more detailed batch job (result) management"),e("OutboundLink")],1)])]),t._v(" "),e("h2",{attrs:{id:"full-example"}},[e("a",{staticClass:"header-anchor",attrs:{href:"#full-example"}},[t._v("#")]),t._v(" Full Example")]),t._v(" "),e("p",[t._v("In this chapter we will show a full example of an earth observation use case using the Python client and the Google Earth Engine back-end.")]),t._v(" "),e("div",{staticClass:"custom-block tip"},[e("p",{staticClass:"custom-block-title"},[t._v("Use Case")]),t._v(" "),e("p",[t._v("We want to produce a monthly RGB composite of Sentinel 1 backscatter data over the area of Vienna, Austria for three\nmonths in 2017. This can be used for classification and crop monitoring.")])]),t._v(" "),e("p",[t._v("In the following code example, we use inline code comments to describe what we are doing.")]),t._v(" "),e("div",{staticClass:"custom-block warning"},[e("p",{staticClass:"custom-block-title"},[t._v("WARNING")]),t._v(" "),e("p",[t._v("The username and password in the example above work at the time of writing, but may be invalid at the time you read this. Please "),e("RouterLink",{attrs:{to:"/contact.html"}},[t._v("contact us")]),t._v(" for credentials.")],1)]),t._v(" "),e("div",{staticClass:"language-python extra-class"},[e("pre",{pre:!0,attrs:{class:"language-python"}},[e("code",[e("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("import")]),t._v(" openeo\n\n"),e("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# First, we connect to the back-end and authenticate ourselves via Basic authentication. ")]),t._v("\ncon "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" openeo"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),t._v("connect"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),e("span",{pre:!0,attrs:{class:"token string"}},[t._v('"https://earthengine.openeo.org"')]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\ncon"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),t._v("authenticate_basic"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),e("span",{pre:!0,attrs:{class:"token string"}},[t._v('"group11"')]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),e("span",{pre:!0,attrs:{class:"token string"}},[t._v('"test123"')]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n\n"),e("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# Now that we are connected, we can initialize our datacube object with the area around Vienna ")]),t._v("\n"),e("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# and the time range of interest using Sentinel 1 data.")]),t._v("\ndatacube "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" con"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),t._v("load_collection"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),e("span",{pre:!0,attrs:{class:"token string"}},[t._v('"COPERNICUS/S1_GRD"')]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n spatial_extent"),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("{")]),e("span",{pre:!0,attrs:{class:"token string"}},[t._v('"west"')]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(":")]),t._v(" "),e("span",{pre:!0,attrs:{class:"token number"}},[t._v("16.06")]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),e("span",{pre:!0,attrs:{class:"token string"}},[t._v('"south"')]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(":")]),t._v(" "),e("span",{pre:!0,attrs:{class:"token number"}},[t._v("48.06")]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),e("span",{pre:!0,attrs:{class:"token string"}},[t._v('"east"')]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(":")]),t._v(" "),e("span",{pre:!0,attrs:{class:"token number"}},[t._v("16.65")]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),e("span",{pre:!0,attrs:{class:"token string"}},[t._v('"north"')]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(":")]),t._v(" "),e("span",{pre:!0,attrs:{class:"token number"}},[t._v("48.35")]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("}")]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n temporal_extent"),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),e("span",{pre:!0,attrs:{class:"token string"}},[t._v('"2017-03-01"')]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),e("span",{pre:!0,attrs:{class:"token string"}},[t._v('"2017-06-01"')]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n bands"),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),e("span",{pre:!0,attrs:{class:"token string"}},[t._v('"VV"')]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n\n"),e("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# Since we are creating a monthly RGB composite, we need three (R, G and B) separated time ranges.")]),t._v("\n"),e("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# Therefore, we split the datacube into three datacubes by filtering temporal for March, April and May. ")]),t._v("\nmarch "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" datacube"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),t._v("filter_temporal"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),e("span",{pre:!0,attrs:{class:"token string"}},[t._v('"2017-03-01"')]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),e("span",{pre:!0,attrs:{class:"token string"}},[t._v('"2017-04-01"')]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\napril "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" datacube"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),t._v("filter_temporal"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),e("span",{pre:!0,attrs:{class:"token string"}},[t._v('"2017-04-01"')]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),e("span",{pre:!0,attrs:{class:"token string"}},[t._v('"2017-05-01"')]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\nmay "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" datacube"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),t._v("filter_temporal"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),e("span",{pre:!0,attrs:{class:"token string"}},[t._v('"2017-05-01"')]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),e("span",{pre:!0,attrs:{class:"token string"}},[t._v('"2017-06-01"')]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n\n"),e("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# Now that we split it into the correct time range, we have to aggregate the timeseries values into a single image.")]),t._v("\n"),e("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# Therefore, we make use of the Python Client function `mean_time`, which reduces the time dimension, ")]),t._v("\n"),e("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# by taking for every timeseries the mean value.")]),t._v("\n\nmean_march "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" march"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),t._v("mean_time"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\nmean_april "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" april"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),t._v("mean_time"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\nmean_may "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" may"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),t._v("mean_time"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n\n"),e("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# Now the three images will be combined into the temporal composite. ")]),t._v("\n"),e("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# Before merging them into one datacube, we need to rename the bands of the images, because otherwise, ")]),t._v("\n"),e("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# they would be overwritten in the merging process. ")]),t._v("\n"),e("span",{pre:!0,attrs:{class:"token comment"}},[t._v('# Therefore, we rename the bands of the datacubes using the `rename_labels` process to "R", "G" and "B".')]),t._v("\n"),e("span",{pre:!0,attrs:{class:"token comment"}},[t._v('# After that we merge them into the "RGB" datacube, which has now three bands ("R", "G" and "B")')]),t._v("\n\nR_band "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" mean_march"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),t._v("rename_labels"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("dimension"),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),e("span",{pre:!0,attrs:{class:"token string"}},[t._v('"bands"')]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" target"),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),e("span",{pre:!0,attrs:{class:"token string"}},[t._v('"R"')]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\nG_band "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" mean_april"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),t._v("rename_labels"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("dimension"),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),e("span",{pre:!0,attrs:{class:"token string"}},[t._v('"bands"')]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" target"),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),e("span",{pre:!0,attrs:{class:"token string"}},[t._v('"G"')]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\nB_band "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" mean_may"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),t._v("rename_labels"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("dimension"),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),e("span",{pre:!0,attrs:{class:"token string"}},[t._v('"bands"')]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" target"),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),e("span",{pre:!0,attrs:{class:"token string"}},[t._v('"B"')]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n\nRG "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" R_band"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),t._v("merge_cubes"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("G_band"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\nRGB "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" RG"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),t._v("merge_cubes"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("B_band"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n\n\n"),e("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# Last but not least, we add the process to save the result of the processing. There we define that ")]),t._v("\n"),e("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# the result should be a GeoTiff file.")]),t._v("\n"),e("span",{pre:!0,attrs:{class:"token comment"}},[t._v('# We also set, which band should be used for "red", "green" and "blue" color in the options.')]),t._v("\n\nRGB "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" RGB"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),t._v("save_result"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),e("span",{pre:!0,attrs:{class:"token builtin"}},[t._v("format")]),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),e("span",{pre:!0,attrs:{class:"token string"}},[t._v('"GTIFF-THUMB"')]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n\n"),e("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# With the last process we have finished the datacube definition and can create and start the job at the back-end.")]),t._v("\n\njob "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" RGB"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),t._v("create_job"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\njob"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),t._v("start_and_wait"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),t._v("download_results"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n")])])]),e("p",[t._v("Now the resulting GTiff file of the RGB backscatter composite is in your current directory.")]),t._v(" "),e("p",[e("img",{attrs:{src:a(193),alt:"RGB composite"}})]),t._v(" "),e("p",[t._v("The "),e("a",{attrs:{href:"https://github.com/Open-EO/openeo-python-client/blob/c21b928ab5f4b4561bb07b7c4a934f0ea9b4f0b8/examples/gee_uc1_temp.py",target:"_blank",rel:"noopener noreferrer"}},[t._v("source code"),e("OutboundLink")],1),t._v(" of this example can be found on GitHub.")]),t._v(" "),e("h2",{attrs:{id:"user-defined-functions"}},[e("a",{staticClass:"header-anchor",attrs:{href:"#user-defined-functions"}},[t._v("#")]),t._v(" User Defined Functions")]),t._v(" "),e("p",[t._v("If your use case can not be accomplished with the "),e("RouterLink",{attrs:{to:"/documentation/1.0/processes.html"}},[t._v("default processes")]),t._v(" of openEO, you can define a "),e("RouterLink",{attrs:{to:"/documentation/1.0/glossary.html#user-defined-function-udf"}},[t._v("user defined function")]),t._v(".\nTherefore, you can create a Python function that will be executed at the back-end and functions as a process in your process graph.")],1),t._v(" "),e("p",[t._v("Detailed information about Python UDFs can be found in the "),e("a",{attrs:{href:"https://open-eo.github.io/openeo-python-client/udf.html",target:"_blank",rel:"noopener noreferrer"}},[t._v("official documentation"),e("OutboundLink")],1),t._v(" as well as examples in the "),e("a",{attrs:{href:"https://github.com/Open-EO/openeo-python-client/tree/master/examples/udf",target:"_blank",rel:"noopener noreferrer"}},[t._v("Python client repository"),e("OutboundLink")],1),t._v(".")]),t._v(" "),e("h2",{attrs:{id:"additional-information"}},[e("a",{staticClass:"header-anchor",attrs:{href:"#additional-information"}},[t._v("#")]),t._v(" Additional Information")]),t._v(" "),e("p",[t._v("Additional information and resources about the openEO Python Client Library:")]),t._v(" "),e("ul",[e("li",[e("a",{attrs:{href:"https://github.com/Open-EO/openeo-python-client/tree/master/examples",target:"_blank",rel:"noopener noreferrer"}},[t._v("Example scripts"),e("OutboundLink")],1)]),t._v(" "),e("li",[e("a",{attrs:{href:"https://github.com/Open-EO/openeo-python-client/tree/master/examples/notebooks",target:"_blank",rel:"noopener noreferrer"}},[t._v("Example Jupyter Notebooks"),e("OutboundLink")],1)]),t._v(" "),e("li",[e("a",{attrs:{href:"https://open-eo.github.io/openeo-python-client/",target:"_blank",rel:"noopener noreferrer"}},[t._v("Official openEO Python Client Library Documentation"),e("OutboundLink")],1)]),t._v(" "),e("li",[e("a",{attrs:{href:"https://github.com/Open-EO/openeo-python-client",target:"_blank",rel:"noopener noreferrer"}},[t._v("Repository on GitHub"),e("OutboundLink")],1)])])])}),[],!1,null,null,null);e.default=s.exports}}]); \ No newline at end of file diff --git a/assets/js/48.44794e44.js b/assets/js/48.aa42c484.js similarity index 99% rename from assets/js/48.44794e44.js rename to assets/js/48.aa42c484.js index 2d8b6054a..033f68f43 100644 --- a/assets/js/48.44794e44.js +++ b/assets/js/48.aa42c484.js @@ -1 +1 @@ -(window.webpackJsonp=window.webpackJsonp||[]).push([[48],{193:function(t,e,a){t.exports=a.p+"assets/img/getting-started-result-example.7820ee84.jpg"},534:function(t,e,a){"use strict";a.r(e);var s=a(4),n=Object(s.a)({},(function(){var t=this,e=t._self._c;return e("ContentSlotsDistributor",{attrs:{"slot-key":t.$parent.slotKey}},[e("h1",{attrs:{id:"r-client"}},[e("a",{staticClass:"header-anchor",attrs:{href:"#r-client"}},[t._v("#")]),t._v(" R Client")]),t._v(" "),e("h2",{attrs:{id:"useful-links"}},[e("a",{staticClass:"header-anchor",attrs:{href:"#useful-links"}},[t._v("#")]),t._v(" Useful links")]),t._v(" "),e("ul",[e("li",[e("a",{attrs:{href:"https://open-eo.github.io/openeo-r-client/index.html",target:"_blank",rel:"noopener noreferrer"}},[t._v("Documentation"),e("OutboundLink")],1)]),t._v(" "),e("li",[e("a",{attrs:{href:"https://open-eo.github.io/openeo-r-client/articles/",target:"_blank",rel:"noopener noreferrer"}},[t._v("Vignettes"),e("OutboundLink")],1)]),t._v(" "),e("li",[e("a",{attrs:{href:"https://github.com/Open-EO/openeo-r-client",target:"_blank",rel:"noopener noreferrer"}},[t._v("Code Repository"),e("OutboundLink")],1)]),t._v(" "),e("li",[t._v("for function documentation, use R's "),e("code",[t._v("?")]),t._v(" function or see the "),e("a",{attrs:{href:"https://open-eo.github.io/openeo-r-client/index.html",target:"_blank",rel:"noopener noreferrer"}},[t._v("online documentation"),e("OutboundLink")],1)])]),t._v(" "),e("h2",{attrs:{id:"installation"}},[e("a",{staticClass:"header-anchor",attrs:{href:"#installation"}},[t._v("#")]),t._v(" Installation")]),t._v(" "),e("p",[t._v("Before you install the R client module into your R environment, please make sure that you have at least R version 3.6. Older versions might also work, but were not tested.")]),t._v(" "),e("p",[t._v("Stable releases can be installed from CRAN:")]),t._v(" "),e("div",{staticClass:"language-r extra-class"},[e("pre",{pre:!0,attrs:{class:"language-r"}},[e("code",[t._v("install.packages"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),e("span",{pre:!0,attrs:{class:"token string"}},[t._v('"openeo"')]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n")])])]),e("div",{staticClass:"custom-block tip"},[e("p",{staticClass:"custom-block-title"},[t._v("Installing the development version")]),t._v(" "),e("p",[t._v("If you want to install the development version, you can install from GitHub. It may contain more features, but may also be unstable.")]),t._v(" "),e("p",[t._v("You need to have the package 'devtools' installed. If it is not installed use "),e("code",[t._v('install.packages("devtools")')]),t._v(".")]),t._v(" "),e("p",[t._v("Now you can use "),e("code",[t._v("install_github")]),t._v(" from the devtools package to install the development version:")]),t._v(" "),e("div",{staticClass:"language-r extra-class"},[e("pre",{pre:!0,attrs:{class:"language-r"}},[e("code",[t._v("devtools"),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("::")]),t._v("install_github"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("repo"),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),e("span",{pre:!0,attrs:{class:"token string"}},[t._v('"Open-EO/openeo-r-client"')]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" dependencies"),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),e("span",{pre:!0,attrs:{class:"token boolean"}},[t._v("TRUE")]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" ref"),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),e("span",{pre:!0,attrs:{class:"token string"}},[t._v('"develop"')]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n")])])]),e("p",[t._v("If this gives you an error, something went wrong with the installation so please check the requirements again.")])]),t._v(" "),e("p",[t._v("If you have troubles installing the package, feel free to "),e("RouterLink",{attrs:{to:"/contact.html"}},[t._v("contact us")]),t._v(" or leave an issue at the "),e("a",{attrs:{href:"https://github.com/Open-EO/openeo-r-client/issues",target:"_blank",rel:"noopener noreferrer"}},[t._v("GitHub project"),e("OutboundLink")],1),t._v(".")],1),t._v(" "),e("p",[t._v("Now that the installation was successfully finished, we can load the package and connect to openEO compliant back-ends.\nIn the following chapters we quickly walk through the main features of the R client.")]),t._v(" "),e("h2",{attrs:{id:"exploring-a-back-end"}},[e("a",{staticClass:"header-anchor",attrs:{href:"#exploring-a-back-end"}},[t._v("#")]),t._v(" Exploring a back-end")]),t._v(" "),e("p",[t._v("If you do not know an openEO back-end that you want to connect to yet, you can have a look at the "),e("a",{attrs:{href:"https://hub.openeo.org/",target:"_blank",rel:"noopener noreferrer"}},[t._v("openEO Hub"),e("OutboundLink")],1),t._v(", to find all known back-ends with information on their capabilities.")]),t._v(" "),e("p",[t._v("For this tutorial we will use the openEO instance of Google Earth Engine, which is available at "),e("code",[t._v("https://earthengine.openeo.org")]),t._v(".\nNote that the code snippets in this guide work the same way for the other back-ends listed in the openEO Hub. Just the collection identifier and band names might differ.")]),t._v(" "),e("p",[t._v("First we need to establish a connection to the back-end.")]),t._v(" "),e("div",{staticClass:"language-r extra-class"},[e("pre",{pre:!0,attrs:{class:"language-r"}},[e("code",[t._v("library"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("openeo"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\ngee "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" connect"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("host "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),e("span",{pre:!0,attrs:{class:"token string"}},[t._v('"https://earthengine.openeo.org"')]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n")])])]),e("p",[t._v("The object stored as variable "),e("code",[t._v("gee")]),t._v(" is a connection and resembles the "),e("code",[t._v("OpenEOClient")]),t._v(" - an object, that bundles all information and functions to interact with the openEO back-end. It can be used explicitly in all of the functions to determine which connection has to be used (usually parameter "),e("code",[t._v("con")]),t._v("). If only one connection is active, then you can omit the parameter, because the last active connection is always stored in a package environment and used if no specific connection was present (see "),e("code",[t._v("?active_connection")]),t._v(" in the package documentation).")]),t._v(" "),e("p",[t._v("The capabilities of the back-end and the collections are generally publicly available, unless the data collections are proprietary and licensing issues prevent the back-end provider from publishing the collection. For the publicly available information you do not need to have an account on the back-end for reading them.")]),t._v(" "),e("h3",{attrs:{id:"collections"}},[e("a",{staticClass:"header-anchor",attrs:{href:"#collections"}},[t._v("#")]),t._v(" Collections")]),t._v(" "),e("p",[t._v("Collections represent the basic data the back-end provides (e.g. Sentinel 1 collection) and are therefore often used as input data for job executions ("),e("RouterLink",{attrs:{to:"/documentation/1.0/glossary.html#eo-data-collections"}},[t._v("more info on collections")]),t._v(").\nWith the following code snippet you can get all available collection names and their description. The collection list and its entries have their own implementations of the "),e("code",[t._v("print")]),t._v(" function. The collection list object is coerced into a "),e("code",[t._v("data.frame")]),t._v(" only for printing purposes and the collection for the collection some key information are printed.")],1),t._v(" "),e("p",[t._v("To get the collection list can be indexed by the collections ID to get the more details about the overview information. With the "),e("code",[t._v("describe_collection")]),t._v(" function you can get an even more detailed information about the collection.")]),t._v(" "),e("div",{staticClass:"language-r extra-class"},[e("pre",{pre:!0,attrs:{class:"language-r"}},[e("code",[e("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# get the collection list")]),t._v("\ncollections "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" list_collections"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n\n"),e("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# print an overview of the available collections (printed as data.frame or tibble)")]),t._v("\nprint"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("collections"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n\n"),e("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# to print more of the reduced overview metadata")]),t._v("\nprint"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("collections"),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("$")]),t._v("`COPERNICUS"),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("/")]),t._v("S2`"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n\n"),e("span",{pre:!0,attrs:{class:"token comment"}},[t._v('# Dictionary of the full metadata of the "COPERNICUS/S2" collection (dict)')]),t._v("\ns2 "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" describe_collection"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),e("span",{pre:!0,attrs:{class:"token string"}},[t._v('"COPERNICUS/S2"')]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v(" "),e("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# or use the collection entry from the list, e.g. collections$`COPERNICUS/S2`")]),t._v("\nprint"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("s2"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n")])])]),e("p",[t._v("In general all metadata objects are based on lists, so you can use "),e("code",[t._v("str()")]),t._v(" to get the structure of the list and address fields by the "),e("code",[t._v("$")]),t._v(" operator.")]),t._v(" "),e("div",{staticClass:"custom-block tip"},[e("p",{staticClass:"custom-block-title"},[t._v("TIP")]),t._v(" "),e("p",[t._v("If the package is used with RStudio the metadata can also be nicely rendered as a web page in the viewer panel by running "),e("code",[t._v('collection_viewer(x="COPERNICUS/S2")')]),t._v(".")])]),t._v(" "),e("h3",{attrs:{id:"processes"}},[e("a",{staticClass:"header-anchor",attrs:{href:"#processes"}},[t._v("#")]),t._v(" Processes")]),t._v(" "),e("p",[t._v("Processes in openEO are tasks that can be applied to (EO) data.\nThe input of a process might be the output of another process, so that several connected processes form a new (user-defined) process itself.\nTherefore, a process resembles the smallest unit of task descriptions in openEO ("),e("RouterLink",{attrs:{to:"/documentation/1.0/glossary.html#processes"}},[t._v("more details on processes")]),t._v(").\nThe following code snippet shows how to get the available processes.")],1),t._v(" "),e("div",{staticClass:"language-r extra-class"},[e("pre",{pre:!0,attrs:{class:"language-r"}},[e("code",[e("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# List of available openEO processes with full metadata")]),t._v("\nprocesses "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" list_processes"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n\n"),e("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# List of available openEO processes by identifiers (string)")]),t._v("\nprint"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("names"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("processes"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n\n"),e("span",{pre:!0,attrs:{class:"token comment"}},[t._v('# print metadata of the process with ID "load_collection"')]),t._v("\nprint"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("processes"),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("$")]),t._v("load_collection"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n")])])]),e("p",[t._v("The "),e("code",[t._v("list_processes()")]),t._v(" method returns a list of process metadata objects that the back-end provides.\nEach process list entry is a more complex list object (called 'ProcessInfo') and contains the process identifier and additional metadata about the process, such as expected arguments and return types.")]),t._v(" "),e("div",{staticClass:"custom-block tip"},[e("p",{staticClass:"custom-block-title"},[t._v("TIP")]),t._v(" "),e("p",[t._v("As for the collection, processes can also be rendered as a web page in the viewer panel, if RStudio is used. In order to open the viewer use "),e("code",[t._v("process_viewer()")]),t._v(" with either a particular process ("),e("code",[t._v('process_viewer("load_collection")')]),t._v(") or you can pass on all processes ("),e("code",[t._v("process_viewer(processes)")]),t._v("). When all processes are chosen, there is also a search bar and a category tree.")])]),t._v(" "),e("p",[t._v("For other graphical overviews of the openEO processes, there is an "),e("RouterLink",{attrs:{to:"/documentation/1.0/processes.html"}},[t._v("online documentation")]),t._v(" for general process descriptions and the "),e("a",{attrs:{href:"https://hub.openeo.org/",target:"_blank",rel:"noopener noreferrer"}},[t._v("openEO Hub"),e("OutboundLink")],1),t._v(" for back-end specific process descriptions.")],1),t._v(" "),e("h2",{attrs:{id:"authentication"}},[e("a",{staticClass:"header-anchor",attrs:{href:"#authentication"}},[t._v("#")]),t._v(" Authentication")]),t._v(" "),e("p",[t._v("In the code snippets above, authentication is usually not necessary, since we only fetch general information about the back-end.\nTo run your own jobs at the back-end or to access job results, you need to authenticate at the back-end.")]),t._v(" "),e("p",[t._v("Depending on the back-end, there might be two different approaches to authenticate.\nYou need to inform yourself at your back-end provider of choice, which authentication approach you have to carry out and how to obtain login credentials for yourself and your 'openeo' installation in R.")]),t._v(" "),e("p",[t._v("You can also have a look at the "),e("a",{attrs:{href:"https://hub.openeo.org/",target:"_blank",rel:"noopener noreferrer"}},[t._v("openEO Hub"),e("OutboundLink")],1),t._v(" to see the available authentication types of the back-ends.\nFor Google Earth Engine, only "),e("a",{attrs:{href:"#basic-authentication"}},[t._v("Basic Authentication")]),t._v(" is supported at the moment.")]),t._v(" "),e("div",{staticClass:"custom-block tip"},[e("p",{staticClass:"custom-block-title"},[t._v("Recommendation")]),t._v(" "),e("p",[t._v("The Google Earth Engine implementation for openEO only supports Basic authentication, but generally the preferred authentication method is "),e("a",{attrs:{href:"#openid-connect-authentication"}},[t._v("OpenID Connect")]),t._v(" due to better security mechanisms implemented in the OpenID Connect protocol.")])]),t._v(" "),e("h3",{attrs:{id:"basic-authentication"}},[e("a",{staticClass:"header-anchor",attrs:{href:"#basic-authentication"}},[t._v("#")]),t._v(" Basic Authentication")]),t._v(" "),e("p",[t._v("The Basic authentication method is a common way of authenticate HTTP requests given username and password.")]),t._v(" "),e("p",[t._v("The following code snippet shows how to log in via Basic authentication:")]),t._v(" "),e("div",{staticClass:"language-r extra-class"},[e("pre",{pre:!0,attrs:{class:"language-r"}},[e("code",[t._v("login"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("login_type"),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),e("span",{pre:!0,attrs:{class:"token string"}},[t._v('"basic"')]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n user"),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),e("span",{pre:!0,attrs:{class:"token string"}},[t._v('"user"')]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n password"),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),e("span",{pre:!0,attrs:{class:"token string"}},[t._v('"password"')]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n")])])]),e("div",{staticClass:"custom-block tip"},[e("p",{staticClass:"custom-block-title"},[t._v("TIP")]),t._v(" "),e("p",[t._v("You can get username and password here: "),e("a",{attrs:{href:"https://github.com/Open-EO/openeo-earthengine-driver#demo",target:"_blank",rel:"noopener noreferrer"}},[t._v("https://github.com/Open-EO/openeo-earthengine-driver#demo"),e("OutboundLink")],1)])]),t._v(" "),e("p",[t._v("After successfully calling the "),e("code",[t._v("login")]),t._v(' method with the "basic" login type, you are logged into the back-end with your account.\nThis means, that every call that comes after that via the connection variable is executed by your user account.')]),t._v(" "),e("h3",{attrs:{id:"openid-connect-authentication"}},[e("a",{staticClass:"header-anchor",attrs:{href:"#openid-connect-authentication"}},[t._v("#")]),t._v(" OpenID Connect Authentication")]),t._v(" "),e("div",{staticClass:"custom-block warning"},[e("p",{staticClass:"custom-block-title"},[t._v("WARNING")]),t._v(" "),e("p",[t._v("For Google Earth Engine, only "),e("a",{attrs:{href:"#basic-authentication"}},[t._v("Basic Authentication")]),t._v(" is supported at the moment.")])]),t._v(" "),e("p",[t._v("The OIDC ("),e("a",{attrs:{href:"https://openid.net/connect/",target:"_blank",rel:"noopener noreferrer"}},[t._v("OpenID Connect"),e("OutboundLink")],1),t._v(") authentication can be used to authenticate via an external service.")]),t._v(" "),e("p",[t._v("The following code snippet shows how to log in via OIDC authentication if the back-end supports the simplified authentication method:")]),t._v(" "),e("div",{staticClass:"language-r extra-class"},[e("pre",{pre:!0,attrs:{class:"language-r"}},[e("code",[t._v("login"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n")])])]),e("p",[t._v("The following code snippet shows how to log in via OIDC authentication if the simplified authentication method doesn't work and you need to provide a client ID and secret:")]),t._v(" "),e("div",{staticClass:"language-r extra-class"},[e("pre",{pre:!0,attrs:{class:"language-r"}},[e("code",[e("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# get supported OIDC providers which the back-end supports")]),t._v("\noidc_providers "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" list_oidc_providers"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n\nlogin"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("provider "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" oidc_providers"),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("$")]),t._v("some_provider"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n config "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" list"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("\n client_id"),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),e("span",{pre:!0,attrs:{class:"token string"}},[t._v('"..."')]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n secret "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),e("span",{pre:!0,attrs:{class:"token string"}},[t._v('"..."')]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n")])])]),e("p",[t._v("Calling this method opens your system web browser, with which you can authenticate yourself on the back-end authentication system.\nAfter that the website will give you the instructions to go back to the R client, where your connection has logged your account in.\nThis means, that every call that comes after that via the connection variable is executed by your user account.")]),t._v(" "),e("h2",{attrs:{id:"creating-a-user-defined-process"}},[e("a",{staticClass:"header-anchor",attrs:{href:"#creating-a-user-defined-process"}},[t._v("#")]),t._v(" Creating a (user-defined) process")]),t._v(" "),e("p",[t._v("Now that we know how to discover the back-end and how to authenticate, lets continue by creating a new batch job to process some data.")]),t._v(" "),e("p",[t._v("First we need to create a process builder object that carries all the available predefined openEO processes of the connected back-end as attached R functions with the parameters stated in the process metadata.")]),t._v(" "),e("div",{staticClass:"language-r extra-class"},[e("pre",{pre:!0,attrs:{class:"language-r"}},[e("code",[t._v("p "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" processes"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n")])])]),e("p",[t._v("The functions of the builder return process nodes, which represent a particular result in the workflow. As one of the first steps we need to select the source data collection.")]),t._v(" "),e("div",{staticClass:"language-r extra-class"},[e("pre",{pre:!0,attrs:{class:"language-r"}},[e("code",[t._v("datacube "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" p"),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("$")]),t._v("load_collection"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("\n id "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),e("span",{pre:!0,attrs:{class:"token string"}},[t._v('"COPERNICUS/S1_GRD"')]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n spatial_extent"),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v("list"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("west "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),e("span",{pre:!0,attrs:{class:"token number"}},[t._v("16.06")]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" south "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),e("span",{pre:!0,attrs:{class:"token number"}},[t._v("48.06")]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" east "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),e("span",{pre:!0,attrs:{class:"token number"}},[t._v("16.65")]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" north "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),e("span",{pre:!0,attrs:{class:"token number"}},[t._v("48.35")]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n temporal_extent"),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v("c"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),e("span",{pre:!0,attrs:{class:"token string"}},[t._v('"2017-03-01"')]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),e("span",{pre:!0,attrs:{class:"token string"}},[t._v('"2017-04-01"')]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n bands"),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v("c"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),e("span",{pre:!0,attrs:{class:"token string"}},[t._v('"VV"')]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),e("span",{pre:!0,attrs:{class:"token string"}},[t._v('"VH"')]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n")])])]),e("p",[t._v("This results in a process node that represents a "),e("RouterLink",{attrs:{to:"/documentation/1.0/glossary.html#spatial-datacubes"}},[e("code",[t._v("datacube")])]),t._v(' and contains the "COPERNICUS/S1_GRD" data restricted to the given spatial extent, the given temporal extent and the given bands .')],1),t._v(" "),e("div",{staticClass:"custom-block tip"},[e("p",{staticClass:"custom-block-title"},[t._v("Sample Data Retrieval")]),t._v(" "),e("p",[t._v("In order to get a better understanding about the processing mechanisms and the data structures used in openEO Platform, it helps to check the actual data from time to time.\nThe function "),e("a",{attrs:{href:"https://open-eo.github.io/openeo-r-client/reference/get_sample.html",target:"_blank",rel:"noopener noreferrer"}},[e("code",[t._v("get_sample")]),e("OutboundLink")],1),t._v(" aids the user in downloading data for a very small spatial extent. It is automatically loaded into R so that you can directly inspect it with "),e("code",[t._v("stars")]),t._v('.\nRead the vignette on "'),e("a",{attrs:{href:"https://open-eo.github.io/openeo-r-client/articles/sample_data.html",target:"_blank",rel:"noopener noreferrer"}},[t._v("Sample Data Retrieval"),e("OutboundLink")],1),t._v('" for more details.')])]),t._v(" "),e("p",[t._v("Having the input data ready, we want to apply a process on the datacube.\nTherefore, we can call the process directly on the datacube object, which then returns a datacube with the process applied.")]),t._v(" "),e("div",{staticClass:"language-r extra-class"},[e("pre",{pre:!0,attrs:{class:"language-r"}},[e("code",[t._v("min_reducer "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),e("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("function")]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("data"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("context"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v(" "),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("{")]),t._v(" \n return"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("p"),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("$")]),t._v("min"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("data "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" data"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("}")]),t._v("\n\nreduced "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" p"),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("$")]),t._v("reduce_dimension"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("data "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" datacube"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" reducer "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" min_reducer"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" dimension"),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),e("span",{pre:!0,attrs:{class:"token string"}},[t._v('"t"')]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n")])])]),e("p",[t._v("The datacube is now reduced by the time dimension named "),e("code",[t._v("t")]),t._v(', by taking the minimum value of the timeseries values. Now the datacube has no time dimension left. Other so called "reducer" processes exist, e.g. for computing maximum and mean values.')]),t._v(" "),e("div",{staticClass:"custom-block tip"},[e("p",{staticClass:"custom-block-title"},[t._v("Note")]),t._v(" "),e("p",[t._v("Everything applied to the datacube at this point is neither executed locally on your machine nor executed on the back-end.\nIt just defines the input data and process chain the back-end needs to apply when it sends the datacube to the back-end and executes it there.\nHow this can be done is the topic of the next chapter.")])]),t._v(" "),e("p",[t._v("After applying all processes you want to execute, we need to tell the back-end to export the datacube, for example as GeoTiff:")]),t._v(" "),e("div",{staticClass:"language-r extra-class"},[e("pre",{pre:!0,attrs:{class:"language-r"}},[e("code",[t._v("formats "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" list_file_formats"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n\nresult "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" p"),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("$")]),t._v("save_result"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("data "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" reduced"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" format "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" formats"),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("$")]),t._v("output"),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("$")]),t._v("`GTIFF"),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("-")]),t._v("ZIP`"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n")])])]),e("p",[t._v("The first line retrieves the back-ends offered input and output formats. The second line creates the result node, which stores the data as a zipped GeoTiff.")]),t._v(" "),e("h2",{attrs:{id:"batch-job-management"}},[e("a",{staticClass:"header-anchor",attrs:{href:"#batch-job-management"}},[t._v("#")]),t._v(" Batch Job Management")]),t._v(" "),e("p",[t._v("After you have finished working on your (user-defined) process, we can now send it to the back-end and start the execution.\nIn openEO, an execution of a (user-defined) process is called a "),e("RouterLink",{attrs:{to:"/documentation/1.0/glossary.html#data-processing-modes"}},[t._v("(batch) job")]),t._v(".\nTherefore, we need to create a job at the back-end using our datacube, giving it the title "),e("code",[t._v("Example Title")]),t._v(".")],1),t._v(" "),e("div",{staticClass:"language-r extra-class"},[e("pre",{pre:!0,attrs:{class:"language-r"}},[e("code",[t._v("job "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" create_job"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("graph"),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v("result"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("title "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),e("span",{pre:!0,attrs:{class:"token string"}},[t._v('"Example Title"')]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n")])])]),e("p",[t._v("The "),e("code",[t._v("create_job")]),t._v(" method sends all necessary information to the back-end and creates a new job, which gets returned.\nAfter this, the job is just created, but has not started the execution at the back-end yet.\nIt needs to be queued for processing explicitly:")]),t._v(" "),e("div",{staticClass:"language-r extra-class"},[e("pre",{pre:!0,attrs:{class:"language-r"}},[e("code",[t._v("start_job"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("job "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" job"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n")])])]),e("p",[t._v("After the job was executed, status updates can be fetched by using the "),e("code",[t._v("list_jobs()")]),t._v(" function. This function returns a list of job descriptions, which can be indexed with the jobs ID to limit the search results. But remember that only "),e("code",[t._v("list_jobs()")]),t._v(" refreshes this list. So, to monitor a job you have to iteratively call the job ("),e("code",[t._v("describe_job()")]),t._v(") or the job list "),e("code",[t._v("list_jobs()")]),t._v(".")]),t._v(" "),e("div",{staticClass:"language-r extra-class"},[e("pre",{pre:!0,attrs:{class:"language-r"}},[e("code",[t._v("jobs "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" list_jobs"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\njobs "),e("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# printed as a tibble or data.frame, but the object is a list")]),t._v("\n\n"),e("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# or use the job id (in this example 'cZ2ND0Z5nhBFNQFq') as index to get a particular job overview")]),t._v("\njobs"),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("$")]),t._v("cZ2ND0Z5nhBFNQFq\n\n"),e("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# alternatively request detailed information about the job")]),t._v("\ndescribe_job"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("job "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" job"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n")])])]),e("p",[t._v("When the job is finished, calling "),e("code",[t._v("download_results()")]),t._v(" will download the results of a job. Using "),e("code",[t._v("list_results()")]),t._v(" will return an overview about the created files and their download link or it states the error message, in case of an error.")]),t._v(" "),e("div",{staticClass:"language-r extra-class"},[e("pre",{pre:!0,attrs:{class:"language-r"}},[e("code",[e("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# list the processed results")]),t._v("\nlist_results"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("job "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" job"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n\n"),e("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# download all the files into a folder on the file system")]),t._v("\ndownload_results"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("job "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" job"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" folder "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),e("span",{pre:!0,attrs:{class:"token string"}},[t._v('"/some/folder/on/filesystem"')]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n")])])]),e("div",{staticClass:"custom-block tip"},[e("p",{staticClass:"custom-block-title"},[t._v("Note")]),t._v(" "),e("p",[t._v("The printing behavior and the actual data structure might differ!")])]),t._v(" "),e("p",[t._v("Now you know the general workflow of job executions.")]),t._v(" "),e("h2",{attrs:{id:"full-example"}},[e("a",{staticClass:"header-anchor",attrs:{href:"#full-example"}},[t._v("#")]),t._v(" Full Example")]),t._v(" "),e("p",[t._v("In this chapter we will show a full example of an earth observation use case using the R client and the Google Earth Engine back-end.\nInstead of batch job processing, we compute the image synchronously. Synchronous processing means the result is directly returned in the response, which usually works only for smaller amounts of data.")]),t._v(" "),e("div",{staticClass:"custom-block tip"},[e("p",{staticClass:"custom-block-title"},[t._v("Use Case")]),t._v(" "),e("p",[t._v("We want to produce a monthly RGB composite of Sentinel 1 backscatter data over the area of Vienna, Austria for three\nmonths in 2017. This can be used for classification and crop monitoring.")])]),t._v(" "),e("p",[t._v("In the following code example, we use inline code comments to describe what we are doing.")]),t._v(" "),e("div",{staticClass:"custom-block warning"},[e("p",{staticClass:"custom-block-title"},[t._v("WARNING")]),t._v(" "),e("p",[t._v("The username and password in the example above work at the time of writing, but may be invalid at the time you read this. Please "),e("RouterLink",{attrs:{to:"/contact.html"}},[t._v("contact us")]),t._v(" for credentials.")],1)]),t._v(" "),e("div",{staticClass:"language-r extra-class"},[e("pre",{pre:!0,attrs:{class:"language-r"}},[e("code",[t._v("library"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("openeo"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\nlibrary"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("tibble"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n\nuser "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),e("span",{pre:!0,attrs:{class:"token string"}},[t._v('"group7"')]),t._v("\npwd "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),e("span",{pre:!0,attrs:{class:"token string"}},[t._v('"test123"')]),t._v("\n\n"),e("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# connect to the back-end and login either via explicit call of login, or use your credentials in the connect function")]),t._v("\ngee "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" connect"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("host "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),e("span",{pre:!0,attrs:{class:"token string"}},[t._v('"https://earthengine.openeo.org"')]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("user "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" user"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("password "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" pwd"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("login_type "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),e("span",{pre:!0,attrs:{class:"token string"}},[t._v('"basic"')]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n\n"),e("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# get the process collection to use the predefined processes of the back-end")]),t._v("\np "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" processes"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n\n"),e("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# get the collection list to get easier access to the collection ids, via auto completion")]),t._v("\ncollections "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" list_collections"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n\n"),e("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# get the formats")]),t._v("\nformats "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" list_file_formats"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n\n"),e("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# load the initial data collection and limit the amount of data loaded")]),t._v("\n"),e("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# note: for the collection id and later the format you can also use the its character value")]),t._v("\ndata "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" p"),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("$")]),t._v("load_collection"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("id "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" collections"),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("$")]),t._v("`COPERNICUS"),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("/")]),t._v("S1_GRD`"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n spatial_extent "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" list"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("west"),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),e("span",{pre:!0,attrs:{class:"token number"}},[t._v("16.06")]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" \n south"),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),e("span",{pre:!0,attrs:{class:"token number"}},[t._v("48.06")]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n east"),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),e("span",{pre:!0,attrs:{class:"token number"}},[t._v("16.65")]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n north"),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),e("span",{pre:!0,attrs:{class:"token number"}},[t._v("48.35")]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n temporal_extent "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" c"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),e("span",{pre:!0,attrs:{class:"token string"}},[t._v('"2017-03-01"')]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),e("span",{pre:!0,attrs:{class:"token string"}},[t._v('"2017-06-01"')]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n bands "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" c"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),e("span",{pre:!0,attrs:{class:"token string"}},[t._v('"VV"')]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n\n"),e("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# create three monthly sub data sets, which will be merged back into a single data cube later")]),t._v("\nmarch "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" p"),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("$")]),t._v("filter_temporal"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("data "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" data"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n extent "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" c"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),e("span",{pre:!0,attrs:{class:"token string"}},[t._v('"2017-03-01"')]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),e("span",{pre:!0,attrs:{class:"token string"}},[t._v('"2017-04-01"')]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n\napril "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" p"),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("$")]),t._v("filter_temporal"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("data "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" data"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n extent "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" c"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),e("span",{pre:!0,attrs:{class:"token string"}},[t._v('"2017-04-01"')]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),e("span",{pre:!0,attrs:{class:"token string"}},[t._v('"2017-05-01"')]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n\nmay "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" p"),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("$")]),t._v("filter_temporal"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("data "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" data"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n extent "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" c"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),e("span",{pre:!0,attrs:{class:"token string"}},[t._v('"2017-05-01"')]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),e("span",{pre:!0,attrs:{class:"token string"}},[t._v('"2017-06-01"')]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n\n"),e("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# The aggregation function for the following temporal reducer")]),t._v("\nagg_fun_mean "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),e("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("function")]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("data"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" context"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v(" "),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("{")]),t._v("\n mean"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("data"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("}")]),t._v("\n\nmarch_reduced "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" p"),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("$")]),t._v("reduce_dimension"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("data "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" march"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n reducer "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" agg_fun_mean"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n dimension "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),e("span",{pre:!0,attrs:{class:"token string"}},[t._v('"t"')]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n\napril_reduced "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" p"),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("$")]),t._v("reduce_dimension"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("data "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" april"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n reducer "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" agg_fun_mean"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n dimension "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),e("span",{pre:!0,attrs:{class:"token string"}},[t._v('"t"')]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n\nmay_reduced "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" p"),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("$")]),t._v("reduce_dimension"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("data "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" may"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n reducer "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" agg_fun_mean"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n dimension "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),e("span",{pre:!0,attrs:{class:"token string"}},[t._v('"t"')]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n\n"),e("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# Each band is currently called VV. We need to rename at least the label of one dimension, ")]),t._v("\n"),e("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# because otherwise identity of the data cubes is assumed. The bands dimension consists ")]),t._v("\n"),e("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# only of one label, so we can rename this to be able to merge those data cubes.")]),t._v("\nmarch_renamed "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" p"),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("$")]),t._v("rename_labels"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("data "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" march_reduced"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n dimension "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),e("span",{pre:!0,attrs:{class:"token string"}},[t._v('"bands"')]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n target "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" c"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),e("span",{pre:!0,attrs:{class:"token string"}},[t._v('"R"')]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n source "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" c"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),e("span",{pre:!0,attrs:{class:"token string"}},[t._v('"VV"')]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n\napril_renamed "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" p"),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("$")]),t._v("rename_labels"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("data "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" april_reduced"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n dimension "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),e("span",{pre:!0,attrs:{class:"token string"}},[t._v('"bands"')]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n target "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" c"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),e("span",{pre:!0,attrs:{class:"token string"}},[t._v('"G"')]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n source "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" c"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),e("span",{pre:!0,attrs:{class:"token string"}},[t._v('"VV"')]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n\nmay_renamed "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" p"),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("$")]),t._v("rename_labels"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("data "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" may_reduced"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n dimension "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),e("span",{pre:!0,attrs:{class:"token string"}},[t._v('"bands"')]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n target "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" c"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),e("span",{pre:!0,attrs:{class:"token string"}},[t._v('"B"')]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n source "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" c"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),e("span",{pre:!0,attrs:{class:"token string"}},[t._v('"VV"')]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n\n"),e("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# combine the individual data cubes into one")]),t._v("\n"),e("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# this is done one by one, since the dimensionalities have to match between each of the data cubes")]),t._v("\nmerge_1 "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" p"),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("$")]),t._v("merge_cubes"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("cube1 "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" march_renamed"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("cube2 "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" april_renamed"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\nmerge_2 "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" p"),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("$")]),t._v("merge_cubes"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("cube1 "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" merge_1"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" cube2 "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" may_renamed"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n\n"),e("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# rescale the the back scatter measurements into 8Bit integer to view the results as PNG")]),t._v("\nrescaled "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" p"),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("$")]),t._v("apply"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("data "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" merge_2"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n process "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),e("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("function")]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("data"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("context"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v(" "),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("{")]),t._v("\n p"),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("$")]),t._v("linear_scale_range"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("x"),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v("data"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" inputMin "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("-")]),e("span",{pre:!0,attrs:{class:"token number"}},[t._v("20")]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("inputMax "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("-")]),e("span",{pre:!0,attrs:{class:"token number"}},[t._v("5")]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" outputMin "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),e("span",{pre:!0,attrs:{class:"token number"}},[t._v("0")]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" outputMax "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),e("span",{pre:!0,attrs:{class:"token number"}},[t._v("255")]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n "),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("}")]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n\n"),e("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# export shall be format PNG")]),t._v("\n"),e("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# look at the format description")]),t._v("\nformats"),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("$")]),t._v("output"),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("$")]),t._v("PNG\n\n"),e("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# store the results using the format and set the create options")]),t._v("\nresult "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" p"),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("$")]),t._v("save_result"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("data "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" rescaled"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("format "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" formats"),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("$")]),t._v("output"),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("$")]),t._v("PNG"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" options "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" list"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("red"),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),e("span",{pre:!0,attrs:{class:"token string"}},[t._v('"R"')]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("green"),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),e("span",{pre:!0,attrs:{class:"token string"}},[t._v('"G"')]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("blue"),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),e("span",{pre:!0,attrs:{class:"token string"}},[t._v('"B"')]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n\n"),e("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# create a job")]),t._v("\njob "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" create_job"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("graph "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" result"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" title "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),e("span",{pre:!0,attrs:{class:"token string"}},[t._v('"S1 Example R"')]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" description "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),e("span",{pre:!0,attrs:{class:"token string"}},[t._v('"Getting Started example on openeo.org for R-client"')]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n\n"),e("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# then start the processing of the job and turn on logging (messages that are captured on the back-end during the process execution)")]),t._v("\nstart_job"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("job "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" job"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" log "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),e("span",{pre:!0,attrs:{class:"token boolean"}},[t._v("TRUE")]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n")])])]),e("p",[t._v("Now the resulting PNG file of the RGB backscatter composite is stored as a PNG file in the current working directory. It looks like this:")]),t._v(" "),e("p",[e("img",{attrs:{src:a(193),alt:"RGB composite"}})]),t._v(" "),e("div",{staticClass:"custom-block tip"},[e("p",{staticClass:"custom-block-title"},[t._v("TIP")]),t._v(" "),e("p",[t._v("The "),e("a",{attrs:{href:"https://github.com/Open-EO/openeo-r-client/blob/master/examples/S1-example.R",target:"_blank",rel:"noopener noreferrer"}},[t._v("source code"),e("OutboundLink")],1),t._v(" of the example can also be found on the R client repository on Github.")])]),t._v(" "),e("h2",{attrs:{id:"user-defined-functions"}},[e("a",{staticClass:"header-anchor",attrs:{href:"#user-defined-functions"}},[t._v("#")]),t._v(" User Defined Functions")]),t._v(" "),e("p",[t._v("If your use case can not be accomplished with the "),e("RouterLink",{attrs:{to:"/documentation/1.0/processes.html"}},[t._v("default processes")]),t._v(" of openEO, you can define a "),e("RouterLink",{attrs:{to:"/documentation/1.0/glossary.html#user-defined-function-udf"}},[t._v("user defined function")]),t._v(".")],1),t._v(" "),e("p",[t._v("In general the processing workflow works by uploading the Python or R script into the users file directory on the back-end and reference the script via its URL or by its relational name (e.g. "),e("code",[t._v("/scripts/script1.R")]),t._v(") in the function "),e("code",[t._v("run_udf")]),t._v(". The latter function is a predefined openEO process that the back-end might provide, if UDFs are supported.")]),t._v(" "),e("p",[t._v("Find out more about UDFs in the respective "),e("a",{attrs:{href:"https://github.com/Open-EO/openeo-udf",target:"_blank",rel:"noopener noreferrer"}},[t._v("Python UDF"),e("OutboundLink")],1),t._v(" and "),e("a",{attrs:{href:"https://github.com/Open-EO/openeo-r-udf",target:"_blank",rel:"noopener noreferrer"}},[t._v("R UDF"),e("OutboundLink")],1),t._v(" repositories with their documentation and examples.")])])}),[],!1,null,null,null);e.default=n.exports}}]); \ No newline at end of file +(window.webpackJsonp=window.webpackJsonp||[]).push([[48],{193:function(t,e,a){t.exports=a.p+"assets/img/getting-started-result-example.7820ee84.jpg"},535:function(t,e,a){"use strict";a.r(e);var s=a(4),n=Object(s.a)({},(function(){var t=this,e=t._self._c;return e("ContentSlotsDistributor",{attrs:{"slot-key":t.$parent.slotKey}},[e("h1",{attrs:{id:"r-client"}},[e("a",{staticClass:"header-anchor",attrs:{href:"#r-client"}},[t._v("#")]),t._v(" R Client")]),t._v(" "),e("h2",{attrs:{id:"useful-links"}},[e("a",{staticClass:"header-anchor",attrs:{href:"#useful-links"}},[t._v("#")]),t._v(" Useful links")]),t._v(" "),e("ul",[e("li",[e("a",{attrs:{href:"https://open-eo.github.io/openeo-r-client/index.html",target:"_blank",rel:"noopener noreferrer"}},[t._v("Documentation"),e("OutboundLink")],1)]),t._v(" "),e("li",[e("a",{attrs:{href:"https://open-eo.github.io/openeo-r-client/articles/",target:"_blank",rel:"noopener noreferrer"}},[t._v("Vignettes"),e("OutboundLink")],1)]),t._v(" "),e("li",[e("a",{attrs:{href:"https://github.com/Open-EO/openeo-r-client",target:"_blank",rel:"noopener noreferrer"}},[t._v("Code Repository"),e("OutboundLink")],1)]),t._v(" "),e("li",[t._v("for function documentation, use R's "),e("code",[t._v("?")]),t._v(" function or see the "),e("a",{attrs:{href:"https://open-eo.github.io/openeo-r-client/index.html",target:"_blank",rel:"noopener noreferrer"}},[t._v("online documentation"),e("OutboundLink")],1)])]),t._v(" "),e("h2",{attrs:{id:"installation"}},[e("a",{staticClass:"header-anchor",attrs:{href:"#installation"}},[t._v("#")]),t._v(" Installation")]),t._v(" "),e("p",[t._v("Before you install the R client module into your R environment, please make sure that you have at least R version 3.6. Older versions might also work, but were not tested.")]),t._v(" "),e("p",[t._v("Stable releases can be installed from CRAN:")]),t._v(" "),e("div",{staticClass:"language-r extra-class"},[e("pre",{pre:!0,attrs:{class:"language-r"}},[e("code",[t._v("install.packages"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),e("span",{pre:!0,attrs:{class:"token string"}},[t._v('"openeo"')]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n")])])]),e("div",{staticClass:"custom-block tip"},[e("p",{staticClass:"custom-block-title"},[t._v("Installing the development version")]),t._v(" "),e("p",[t._v("If you want to install the development version, you can install from GitHub. It may contain more features, but may also be unstable.")]),t._v(" "),e("p",[t._v("You need to have the package 'devtools' installed. If it is not installed use "),e("code",[t._v('install.packages("devtools")')]),t._v(".")]),t._v(" "),e("p",[t._v("Now you can use "),e("code",[t._v("install_github")]),t._v(" from the devtools package to install the development version:")]),t._v(" "),e("div",{staticClass:"language-r extra-class"},[e("pre",{pre:!0,attrs:{class:"language-r"}},[e("code",[t._v("devtools"),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("::")]),t._v("install_github"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("repo"),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),e("span",{pre:!0,attrs:{class:"token string"}},[t._v('"Open-EO/openeo-r-client"')]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" dependencies"),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),e("span",{pre:!0,attrs:{class:"token boolean"}},[t._v("TRUE")]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" ref"),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),e("span",{pre:!0,attrs:{class:"token string"}},[t._v('"develop"')]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n")])])]),e("p",[t._v("If this gives you an error, something went wrong with the installation so please check the requirements again.")])]),t._v(" "),e("p",[t._v("If you have troubles installing the package, feel free to "),e("RouterLink",{attrs:{to:"/contact.html"}},[t._v("contact us")]),t._v(" or leave an issue at the "),e("a",{attrs:{href:"https://github.com/Open-EO/openeo-r-client/issues",target:"_blank",rel:"noopener noreferrer"}},[t._v("GitHub project"),e("OutboundLink")],1),t._v(".")],1),t._v(" "),e("p",[t._v("Now that the installation was successfully finished, we can load the package and connect to openEO compliant back-ends.\nIn the following chapters we quickly walk through the main features of the R client.")]),t._v(" "),e("h2",{attrs:{id:"exploring-a-back-end"}},[e("a",{staticClass:"header-anchor",attrs:{href:"#exploring-a-back-end"}},[t._v("#")]),t._v(" Exploring a back-end")]),t._v(" "),e("p",[t._v("If you do not know an openEO back-end that you want to connect to yet, you can have a look at the "),e("a",{attrs:{href:"https://hub.openeo.org/",target:"_blank",rel:"noopener noreferrer"}},[t._v("openEO Hub"),e("OutboundLink")],1),t._v(", to find all known back-ends with information on their capabilities.")]),t._v(" "),e("p",[t._v("For this tutorial we will use the openEO instance of Google Earth Engine, which is available at "),e("code",[t._v("https://earthengine.openeo.org")]),t._v(".\nNote that the code snippets in this guide work the same way for the other back-ends listed in the openEO Hub. Just the collection identifier and band names might differ.")]),t._v(" "),e("p",[t._v("First we need to establish a connection to the back-end.")]),t._v(" "),e("div",{staticClass:"language-r extra-class"},[e("pre",{pre:!0,attrs:{class:"language-r"}},[e("code",[t._v("library"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("openeo"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\ngee "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" connect"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("host "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),e("span",{pre:!0,attrs:{class:"token string"}},[t._v('"https://earthengine.openeo.org"')]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n")])])]),e("p",[t._v("The object stored as variable "),e("code",[t._v("gee")]),t._v(" is a connection and resembles the "),e("code",[t._v("OpenEOClient")]),t._v(" - an object, that bundles all information and functions to interact with the openEO back-end. It can be used explicitly in all of the functions to determine which connection has to be used (usually parameter "),e("code",[t._v("con")]),t._v("). If only one connection is active, then you can omit the parameter, because the last active connection is always stored in a package environment and used if no specific connection was present (see "),e("code",[t._v("?active_connection")]),t._v(" in the package documentation).")]),t._v(" "),e("p",[t._v("The capabilities of the back-end and the collections are generally publicly available, unless the data collections are proprietary and licensing issues prevent the back-end provider from publishing the collection. For the publicly available information you do not need to have an account on the back-end for reading them.")]),t._v(" "),e("h3",{attrs:{id:"collections"}},[e("a",{staticClass:"header-anchor",attrs:{href:"#collections"}},[t._v("#")]),t._v(" Collections")]),t._v(" "),e("p",[t._v("Collections represent the basic data the back-end provides (e.g. Sentinel 1 collection) and are therefore often used as input data for job executions ("),e("RouterLink",{attrs:{to:"/documentation/1.0/glossary.html#eo-data-collections"}},[t._v("more info on collections")]),t._v(").\nWith the following code snippet you can get all available collection names and their description. The collection list and its entries have their own implementations of the "),e("code",[t._v("print")]),t._v(" function. The collection list object is coerced into a "),e("code",[t._v("data.frame")]),t._v(" only for printing purposes and the collection for the collection some key information are printed.")],1),t._v(" "),e("p",[t._v("To get the collection list can be indexed by the collections ID to get the more details about the overview information. With the "),e("code",[t._v("describe_collection")]),t._v(" function you can get an even more detailed information about the collection.")]),t._v(" "),e("div",{staticClass:"language-r extra-class"},[e("pre",{pre:!0,attrs:{class:"language-r"}},[e("code",[e("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# get the collection list")]),t._v("\ncollections "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" list_collections"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n\n"),e("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# print an overview of the available collections (printed as data.frame or tibble)")]),t._v("\nprint"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("collections"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n\n"),e("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# to print more of the reduced overview metadata")]),t._v("\nprint"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("collections"),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("$")]),t._v("`COPERNICUS"),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("/")]),t._v("S2`"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n\n"),e("span",{pre:!0,attrs:{class:"token comment"}},[t._v('# Dictionary of the full metadata of the "COPERNICUS/S2" collection (dict)')]),t._v("\ns2 "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" describe_collection"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),e("span",{pre:!0,attrs:{class:"token string"}},[t._v('"COPERNICUS/S2"')]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v(" "),e("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# or use the collection entry from the list, e.g. collections$`COPERNICUS/S2`")]),t._v("\nprint"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("s2"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n")])])]),e("p",[t._v("In general all metadata objects are based on lists, so you can use "),e("code",[t._v("str()")]),t._v(" to get the structure of the list and address fields by the "),e("code",[t._v("$")]),t._v(" operator.")]),t._v(" "),e("div",{staticClass:"custom-block tip"},[e("p",{staticClass:"custom-block-title"},[t._v("TIP")]),t._v(" "),e("p",[t._v("If the package is used with RStudio the metadata can also be nicely rendered as a web page in the viewer panel by running "),e("code",[t._v('collection_viewer(x="COPERNICUS/S2")')]),t._v(".")])]),t._v(" "),e("h3",{attrs:{id:"processes"}},[e("a",{staticClass:"header-anchor",attrs:{href:"#processes"}},[t._v("#")]),t._v(" Processes")]),t._v(" "),e("p",[t._v("Processes in openEO are tasks that can be applied to (EO) data.\nThe input of a process might be the output of another process, so that several connected processes form a new (user-defined) process itself.\nTherefore, a process resembles the smallest unit of task descriptions in openEO ("),e("RouterLink",{attrs:{to:"/documentation/1.0/glossary.html#processes"}},[t._v("more details on processes")]),t._v(").\nThe following code snippet shows how to get the available processes.")],1),t._v(" "),e("div",{staticClass:"language-r extra-class"},[e("pre",{pre:!0,attrs:{class:"language-r"}},[e("code",[e("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# List of available openEO processes with full metadata")]),t._v("\nprocesses "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" list_processes"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n\n"),e("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# List of available openEO processes by identifiers (string)")]),t._v("\nprint"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("names"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("processes"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n\n"),e("span",{pre:!0,attrs:{class:"token comment"}},[t._v('# print metadata of the process with ID "load_collection"')]),t._v("\nprint"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("processes"),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("$")]),t._v("load_collection"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n")])])]),e("p",[t._v("The "),e("code",[t._v("list_processes()")]),t._v(" method returns a list of process metadata objects that the back-end provides.\nEach process list entry is a more complex list object (called 'ProcessInfo') and contains the process identifier and additional metadata about the process, such as expected arguments and return types.")]),t._v(" "),e("div",{staticClass:"custom-block tip"},[e("p",{staticClass:"custom-block-title"},[t._v("TIP")]),t._v(" "),e("p",[t._v("As for the collection, processes can also be rendered as a web page in the viewer panel, if RStudio is used. In order to open the viewer use "),e("code",[t._v("process_viewer()")]),t._v(" with either a particular process ("),e("code",[t._v('process_viewer("load_collection")')]),t._v(") or you can pass on all processes ("),e("code",[t._v("process_viewer(processes)")]),t._v("). When all processes are chosen, there is also a search bar and a category tree.")])]),t._v(" "),e("p",[t._v("For other graphical overviews of the openEO processes, there is an "),e("RouterLink",{attrs:{to:"/documentation/1.0/processes.html"}},[t._v("online documentation")]),t._v(" for general process descriptions and the "),e("a",{attrs:{href:"https://hub.openeo.org/",target:"_blank",rel:"noopener noreferrer"}},[t._v("openEO Hub"),e("OutboundLink")],1),t._v(" for back-end specific process descriptions.")],1),t._v(" "),e("h2",{attrs:{id:"authentication"}},[e("a",{staticClass:"header-anchor",attrs:{href:"#authentication"}},[t._v("#")]),t._v(" Authentication")]),t._v(" "),e("p",[t._v("In the code snippets above, authentication is usually not necessary, since we only fetch general information about the back-end.\nTo run your own jobs at the back-end or to access job results, you need to authenticate at the back-end.")]),t._v(" "),e("p",[t._v("Depending on the back-end, there might be two different approaches to authenticate.\nYou need to inform yourself at your back-end provider of choice, which authentication approach you have to carry out and how to obtain login credentials for yourself and your 'openeo' installation in R.")]),t._v(" "),e("p",[t._v("You can also have a look at the "),e("a",{attrs:{href:"https://hub.openeo.org/",target:"_blank",rel:"noopener noreferrer"}},[t._v("openEO Hub"),e("OutboundLink")],1),t._v(" to see the available authentication types of the back-ends.\nFor Google Earth Engine, only "),e("a",{attrs:{href:"#basic-authentication"}},[t._v("Basic Authentication")]),t._v(" is supported at the moment.")]),t._v(" "),e("div",{staticClass:"custom-block tip"},[e("p",{staticClass:"custom-block-title"},[t._v("Recommendation")]),t._v(" "),e("p",[t._v("The Google Earth Engine implementation for openEO only supports Basic authentication, but generally the preferred authentication method is "),e("a",{attrs:{href:"#openid-connect-authentication"}},[t._v("OpenID Connect")]),t._v(" due to better security mechanisms implemented in the OpenID Connect protocol.")])]),t._v(" "),e("h3",{attrs:{id:"basic-authentication"}},[e("a",{staticClass:"header-anchor",attrs:{href:"#basic-authentication"}},[t._v("#")]),t._v(" Basic Authentication")]),t._v(" "),e("p",[t._v("The Basic authentication method is a common way of authenticate HTTP requests given username and password.")]),t._v(" "),e("p",[t._v("The following code snippet shows how to log in via Basic authentication:")]),t._v(" "),e("div",{staticClass:"language-r extra-class"},[e("pre",{pre:!0,attrs:{class:"language-r"}},[e("code",[t._v("login"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("login_type"),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),e("span",{pre:!0,attrs:{class:"token string"}},[t._v('"basic"')]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n user"),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),e("span",{pre:!0,attrs:{class:"token string"}},[t._v('"user"')]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n password"),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),e("span",{pre:!0,attrs:{class:"token string"}},[t._v('"password"')]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n")])])]),e("div",{staticClass:"custom-block tip"},[e("p",{staticClass:"custom-block-title"},[t._v("TIP")]),t._v(" "),e("p",[t._v("You can get username and password here: "),e("a",{attrs:{href:"https://github.com/Open-EO/openeo-earthengine-driver#demo",target:"_blank",rel:"noopener noreferrer"}},[t._v("https://github.com/Open-EO/openeo-earthengine-driver#demo"),e("OutboundLink")],1)])]),t._v(" "),e("p",[t._v("After successfully calling the "),e("code",[t._v("login")]),t._v(' method with the "basic" login type, you are logged into the back-end with your account.\nThis means, that every call that comes after that via the connection variable is executed by your user account.')]),t._v(" "),e("h3",{attrs:{id:"openid-connect-authentication"}},[e("a",{staticClass:"header-anchor",attrs:{href:"#openid-connect-authentication"}},[t._v("#")]),t._v(" OpenID Connect Authentication")]),t._v(" "),e("div",{staticClass:"custom-block warning"},[e("p",{staticClass:"custom-block-title"},[t._v("WARNING")]),t._v(" "),e("p",[t._v("For Google Earth Engine, only "),e("a",{attrs:{href:"#basic-authentication"}},[t._v("Basic Authentication")]),t._v(" is supported at the moment.")])]),t._v(" "),e("p",[t._v("The OIDC ("),e("a",{attrs:{href:"https://openid.net/connect/",target:"_blank",rel:"noopener noreferrer"}},[t._v("OpenID Connect"),e("OutboundLink")],1),t._v(") authentication can be used to authenticate via an external service.")]),t._v(" "),e("p",[t._v("The following code snippet shows how to log in via OIDC authentication if the back-end supports the simplified authentication method:")]),t._v(" "),e("div",{staticClass:"language-r extra-class"},[e("pre",{pre:!0,attrs:{class:"language-r"}},[e("code",[t._v("login"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n")])])]),e("p",[t._v("The following code snippet shows how to log in via OIDC authentication if the simplified authentication method doesn't work and you need to provide a client ID and secret:")]),t._v(" "),e("div",{staticClass:"language-r extra-class"},[e("pre",{pre:!0,attrs:{class:"language-r"}},[e("code",[e("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# get supported OIDC providers which the back-end supports")]),t._v("\noidc_providers "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" list_oidc_providers"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n\nlogin"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("provider "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" oidc_providers"),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("$")]),t._v("some_provider"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n config "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" list"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("\n client_id"),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),e("span",{pre:!0,attrs:{class:"token string"}},[t._v('"..."')]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n secret "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),e("span",{pre:!0,attrs:{class:"token string"}},[t._v('"..."')]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n")])])]),e("p",[t._v("Calling this method opens your system web browser, with which you can authenticate yourself on the back-end authentication system.\nAfter that the website will give you the instructions to go back to the R client, where your connection has logged your account in.\nThis means, that every call that comes after that via the connection variable is executed by your user account.")]),t._v(" "),e("h2",{attrs:{id:"creating-a-user-defined-process"}},[e("a",{staticClass:"header-anchor",attrs:{href:"#creating-a-user-defined-process"}},[t._v("#")]),t._v(" Creating a (user-defined) process")]),t._v(" "),e("p",[t._v("Now that we know how to discover the back-end and how to authenticate, lets continue by creating a new batch job to process some data.")]),t._v(" "),e("p",[t._v("First we need to create a process builder object that carries all the available predefined openEO processes of the connected back-end as attached R functions with the parameters stated in the process metadata.")]),t._v(" "),e("div",{staticClass:"language-r extra-class"},[e("pre",{pre:!0,attrs:{class:"language-r"}},[e("code",[t._v("p "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" processes"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n")])])]),e("p",[t._v("The functions of the builder return process nodes, which represent a particular result in the workflow. As one of the first steps we need to select the source data collection.")]),t._v(" "),e("div",{staticClass:"language-r extra-class"},[e("pre",{pre:!0,attrs:{class:"language-r"}},[e("code",[t._v("datacube "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" p"),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("$")]),t._v("load_collection"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("\n id "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),e("span",{pre:!0,attrs:{class:"token string"}},[t._v('"COPERNICUS/S1_GRD"')]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n spatial_extent"),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v("list"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("west "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),e("span",{pre:!0,attrs:{class:"token number"}},[t._v("16.06")]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" south "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),e("span",{pre:!0,attrs:{class:"token number"}},[t._v("48.06")]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" east "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),e("span",{pre:!0,attrs:{class:"token number"}},[t._v("16.65")]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" north "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),e("span",{pre:!0,attrs:{class:"token number"}},[t._v("48.35")]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n temporal_extent"),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v("c"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),e("span",{pre:!0,attrs:{class:"token string"}},[t._v('"2017-03-01"')]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),e("span",{pre:!0,attrs:{class:"token string"}},[t._v('"2017-04-01"')]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n bands"),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v("c"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),e("span",{pre:!0,attrs:{class:"token string"}},[t._v('"VV"')]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),e("span",{pre:!0,attrs:{class:"token string"}},[t._v('"VH"')]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n")])])]),e("p",[t._v("This results in a process node that represents a "),e("RouterLink",{attrs:{to:"/documentation/1.0/glossary.html#spatial-datacubes"}},[e("code",[t._v("datacube")])]),t._v(' and contains the "COPERNICUS/S1_GRD" data restricted to the given spatial extent, the given temporal extent and the given bands .')],1),t._v(" "),e("div",{staticClass:"custom-block tip"},[e("p",{staticClass:"custom-block-title"},[t._v("Sample Data Retrieval")]),t._v(" "),e("p",[t._v("In order to get a better understanding about the processing mechanisms and the data structures used in openEO Platform, it helps to check the actual data from time to time.\nThe function "),e("a",{attrs:{href:"https://open-eo.github.io/openeo-r-client/reference/get_sample.html",target:"_blank",rel:"noopener noreferrer"}},[e("code",[t._v("get_sample")]),e("OutboundLink")],1),t._v(" aids the user in downloading data for a very small spatial extent. It is automatically loaded into R so that you can directly inspect it with "),e("code",[t._v("stars")]),t._v('.\nRead the vignette on "'),e("a",{attrs:{href:"https://open-eo.github.io/openeo-r-client/articles/sample_data.html",target:"_blank",rel:"noopener noreferrer"}},[t._v("Sample Data Retrieval"),e("OutboundLink")],1),t._v('" for more details.')])]),t._v(" "),e("p",[t._v("Having the input data ready, we want to apply a process on the datacube.\nTherefore, we can call the process directly on the datacube object, which then returns a datacube with the process applied.")]),t._v(" "),e("div",{staticClass:"language-r extra-class"},[e("pre",{pre:!0,attrs:{class:"language-r"}},[e("code",[t._v("min_reducer "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),e("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("function")]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("data"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("context"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v(" "),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("{")]),t._v(" \n return"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("p"),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("$")]),t._v("min"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("data "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" data"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("}")]),t._v("\n\nreduced "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" p"),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("$")]),t._v("reduce_dimension"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("data "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" datacube"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" reducer "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" min_reducer"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" dimension"),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),e("span",{pre:!0,attrs:{class:"token string"}},[t._v('"t"')]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n")])])]),e("p",[t._v("The datacube is now reduced by the time dimension named "),e("code",[t._v("t")]),t._v(', by taking the minimum value of the timeseries values. Now the datacube has no time dimension left. Other so called "reducer" processes exist, e.g. for computing maximum and mean values.')]),t._v(" "),e("div",{staticClass:"custom-block tip"},[e("p",{staticClass:"custom-block-title"},[t._v("Note")]),t._v(" "),e("p",[t._v("Everything applied to the datacube at this point is neither executed locally on your machine nor executed on the back-end.\nIt just defines the input data and process chain the back-end needs to apply when it sends the datacube to the back-end and executes it there.\nHow this can be done is the topic of the next chapter.")])]),t._v(" "),e("p",[t._v("After applying all processes you want to execute, we need to tell the back-end to export the datacube, for example as GeoTiff:")]),t._v(" "),e("div",{staticClass:"language-r extra-class"},[e("pre",{pre:!0,attrs:{class:"language-r"}},[e("code",[t._v("formats "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" list_file_formats"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n\nresult "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" p"),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("$")]),t._v("save_result"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("data "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" reduced"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" format "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" formats"),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("$")]),t._v("output"),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("$")]),t._v("`GTIFF"),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("-")]),t._v("ZIP`"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n")])])]),e("p",[t._v("The first line retrieves the back-ends offered input and output formats. The second line creates the result node, which stores the data as a zipped GeoTiff.")]),t._v(" "),e("h2",{attrs:{id:"batch-job-management"}},[e("a",{staticClass:"header-anchor",attrs:{href:"#batch-job-management"}},[t._v("#")]),t._v(" Batch Job Management")]),t._v(" "),e("p",[t._v("After you have finished working on your (user-defined) process, we can now send it to the back-end and start the execution.\nIn openEO, an execution of a (user-defined) process is called a "),e("RouterLink",{attrs:{to:"/documentation/1.0/glossary.html#data-processing-modes"}},[t._v("(batch) job")]),t._v(".\nTherefore, we need to create a job at the back-end using our datacube, giving it the title "),e("code",[t._v("Example Title")]),t._v(".")],1),t._v(" "),e("div",{staticClass:"language-r extra-class"},[e("pre",{pre:!0,attrs:{class:"language-r"}},[e("code",[t._v("job "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" create_job"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("graph"),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v("result"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("title "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),e("span",{pre:!0,attrs:{class:"token string"}},[t._v('"Example Title"')]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n")])])]),e("p",[t._v("The "),e("code",[t._v("create_job")]),t._v(" method sends all necessary information to the back-end and creates a new job, which gets returned.\nAfter this, the job is just created, but has not started the execution at the back-end yet.\nIt needs to be queued for processing explicitly:")]),t._v(" "),e("div",{staticClass:"language-r extra-class"},[e("pre",{pre:!0,attrs:{class:"language-r"}},[e("code",[t._v("start_job"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("job "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" job"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n")])])]),e("p",[t._v("After the job was executed, status updates can be fetched by using the "),e("code",[t._v("list_jobs()")]),t._v(" function. This function returns a list of job descriptions, which can be indexed with the jobs ID to limit the search results. But remember that only "),e("code",[t._v("list_jobs()")]),t._v(" refreshes this list. So, to monitor a job you have to iteratively call the job ("),e("code",[t._v("describe_job()")]),t._v(") or the job list "),e("code",[t._v("list_jobs()")]),t._v(".")]),t._v(" "),e("div",{staticClass:"language-r extra-class"},[e("pre",{pre:!0,attrs:{class:"language-r"}},[e("code",[t._v("jobs "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" list_jobs"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\njobs "),e("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# printed as a tibble or data.frame, but the object is a list")]),t._v("\n\n"),e("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# or use the job id (in this example 'cZ2ND0Z5nhBFNQFq') as index to get a particular job overview")]),t._v("\njobs"),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("$")]),t._v("cZ2ND0Z5nhBFNQFq\n\n"),e("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# alternatively request detailed information about the job")]),t._v("\ndescribe_job"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("job "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" job"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n")])])]),e("p",[t._v("When the job is finished, calling "),e("code",[t._v("download_results()")]),t._v(" will download the results of a job. Using "),e("code",[t._v("list_results()")]),t._v(" will return an overview about the created files and their download link or it states the error message, in case of an error.")]),t._v(" "),e("div",{staticClass:"language-r extra-class"},[e("pre",{pre:!0,attrs:{class:"language-r"}},[e("code",[e("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# list the processed results")]),t._v("\nlist_results"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("job "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" job"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n\n"),e("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# download all the files into a folder on the file system")]),t._v("\ndownload_results"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("job "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" job"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" folder "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),e("span",{pre:!0,attrs:{class:"token string"}},[t._v('"/some/folder/on/filesystem"')]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n")])])]),e("div",{staticClass:"custom-block tip"},[e("p",{staticClass:"custom-block-title"},[t._v("Note")]),t._v(" "),e("p",[t._v("The printing behavior and the actual data structure might differ!")])]),t._v(" "),e("p",[t._v("Now you know the general workflow of job executions.")]),t._v(" "),e("h2",{attrs:{id:"full-example"}},[e("a",{staticClass:"header-anchor",attrs:{href:"#full-example"}},[t._v("#")]),t._v(" Full Example")]),t._v(" "),e("p",[t._v("In this chapter we will show a full example of an earth observation use case using the R client and the Google Earth Engine back-end.\nInstead of batch job processing, we compute the image synchronously. Synchronous processing means the result is directly returned in the response, which usually works only for smaller amounts of data.")]),t._v(" "),e("div",{staticClass:"custom-block tip"},[e("p",{staticClass:"custom-block-title"},[t._v("Use Case")]),t._v(" "),e("p",[t._v("We want to produce a monthly RGB composite of Sentinel 1 backscatter data over the area of Vienna, Austria for three\nmonths in 2017. This can be used for classification and crop monitoring.")])]),t._v(" "),e("p",[t._v("In the following code example, we use inline code comments to describe what we are doing.")]),t._v(" "),e("div",{staticClass:"custom-block warning"},[e("p",{staticClass:"custom-block-title"},[t._v("WARNING")]),t._v(" "),e("p",[t._v("The username and password in the example above work at the time of writing, but may be invalid at the time you read this. Please "),e("RouterLink",{attrs:{to:"/contact.html"}},[t._v("contact us")]),t._v(" for credentials.")],1)]),t._v(" "),e("div",{staticClass:"language-r extra-class"},[e("pre",{pre:!0,attrs:{class:"language-r"}},[e("code",[t._v("library"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("openeo"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\nlibrary"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("tibble"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n\nuser "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),e("span",{pre:!0,attrs:{class:"token string"}},[t._v('"group7"')]),t._v("\npwd "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),e("span",{pre:!0,attrs:{class:"token string"}},[t._v('"test123"')]),t._v("\n\n"),e("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# connect to the back-end and login either via explicit call of login, or use your credentials in the connect function")]),t._v("\ngee "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" connect"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("host "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),e("span",{pre:!0,attrs:{class:"token string"}},[t._v('"https://earthengine.openeo.org"')]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("user "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" user"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("password "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" pwd"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("login_type "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),e("span",{pre:!0,attrs:{class:"token string"}},[t._v('"basic"')]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n\n"),e("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# get the process collection to use the predefined processes of the back-end")]),t._v("\np "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" processes"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n\n"),e("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# get the collection list to get easier access to the collection ids, via auto completion")]),t._v("\ncollections "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" list_collections"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n\n"),e("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# get the formats")]),t._v("\nformats "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" list_file_formats"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n\n"),e("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# load the initial data collection and limit the amount of data loaded")]),t._v("\n"),e("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# note: for the collection id and later the format you can also use the its character value")]),t._v("\ndata "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" p"),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("$")]),t._v("load_collection"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("id "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" collections"),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("$")]),t._v("`COPERNICUS"),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("/")]),t._v("S1_GRD`"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n spatial_extent "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" list"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("west"),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),e("span",{pre:!0,attrs:{class:"token number"}},[t._v("16.06")]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" \n south"),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),e("span",{pre:!0,attrs:{class:"token number"}},[t._v("48.06")]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n east"),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),e("span",{pre:!0,attrs:{class:"token number"}},[t._v("16.65")]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n north"),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),e("span",{pre:!0,attrs:{class:"token number"}},[t._v("48.35")]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n temporal_extent "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" c"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),e("span",{pre:!0,attrs:{class:"token string"}},[t._v('"2017-03-01"')]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),e("span",{pre:!0,attrs:{class:"token string"}},[t._v('"2017-06-01"')]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n bands "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" c"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),e("span",{pre:!0,attrs:{class:"token string"}},[t._v('"VV"')]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n\n"),e("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# create three monthly sub data sets, which will be merged back into a single data cube later")]),t._v("\nmarch "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" p"),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("$")]),t._v("filter_temporal"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("data "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" data"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n extent "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" c"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),e("span",{pre:!0,attrs:{class:"token string"}},[t._v('"2017-03-01"')]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),e("span",{pre:!0,attrs:{class:"token string"}},[t._v('"2017-04-01"')]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n\napril "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" p"),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("$")]),t._v("filter_temporal"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("data "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" data"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n extent "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" c"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),e("span",{pre:!0,attrs:{class:"token string"}},[t._v('"2017-04-01"')]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),e("span",{pre:!0,attrs:{class:"token string"}},[t._v('"2017-05-01"')]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n\nmay "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" p"),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("$")]),t._v("filter_temporal"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("data "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" data"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n extent "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" c"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),e("span",{pre:!0,attrs:{class:"token string"}},[t._v('"2017-05-01"')]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),e("span",{pre:!0,attrs:{class:"token string"}},[t._v('"2017-06-01"')]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n\n"),e("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# The aggregation function for the following temporal reducer")]),t._v("\nagg_fun_mean "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),e("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("function")]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("data"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" context"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v(" "),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("{")]),t._v("\n mean"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("data"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("}")]),t._v("\n\nmarch_reduced "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" p"),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("$")]),t._v("reduce_dimension"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("data "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" march"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n reducer "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" agg_fun_mean"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n dimension "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),e("span",{pre:!0,attrs:{class:"token string"}},[t._v('"t"')]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n\napril_reduced "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" p"),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("$")]),t._v("reduce_dimension"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("data "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" april"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n reducer "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" agg_fun_mean"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n dimension "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),e("span",{pre:!0,attrs:{class:"token string"}},[t._v('"t"')]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n\nmay_reduced "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" p"),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("$")]),t._v("reduce_dimension"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("data "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" may"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n reducer "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" agg_fun_mean"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n dimension "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),e("span",{pre:!0,attrs:{class:"token string"}},[t._v('"t"')]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n\n"),e("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# Each band is currently called VV. We need to rename at least the label of one dimension, ")]),t._v("\n"),e("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# because otherwise identity of the data cubes is assumed. The bands dimension consists ")]),t._v("\n"),e("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# only of one label, so we can rename this to be able to merge those data cubes.")]),t._v("\nmarch_renamed "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" p"),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("$")]),t._v("rename_labels"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("data "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" march_reduced"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n dimension "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),e("span",{pre:!0,attrs:{class:"token string"}},[t._v('"bands"')]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n target "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" c"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),e("span",{pre:!0,attrs:{class:"token string"}},[t._v('"R"')]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n source "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" c"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),e("span",{pre:!0,attrs:{class:"token string"}},[t._v('"VV"')]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n\napril_renamed "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" p"),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("$")]),t._v("rename_labels"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("data "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" april_reduced"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n dimension "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),e("span",{pre:!0,attrs:{class:"token string"}},[t._v('"bands"')]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n target "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" c"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),e("span",{pre:!0,attrs:{class:"token string"}},[t._v('"G"')]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n source "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" c"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),e("span",{pre:!0,attrs:{class:"token string"}},[t._v('"VV"')]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n\nmay_renamed "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" p"),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("$")]),t._v("rename_labels"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("data "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" may_reduced"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n dimension "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),e("span",{pre:!0,attrs:{class:"token string"}},[t._v('"bands"')]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n target "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" c"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),e("span",{pre:!0,attrs:{class:"token string"}},[t._v('"B"')]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n source "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" c"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),e("span",{pre:!0,attrs:{class:"token string"}},[t._v('"VV"')]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n\n"),e("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# combine the individual data cubes into one")]),t._v("\n"),e("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# this is done one by one, since the dimensionalities have to match between each of the data cubes")]),t._v("\nmerge_1 "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" p"),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("$")]),t._v("merge_cubes"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("cube1 "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" march_renamed"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("cube2 "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" april_renamed"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\nmerge_2 "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" p"),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("$")]),t._v("merge_cubes"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("cube1 "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" merge_1"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" cube2 "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" may_renamed"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n\n"),e("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# rescale the the back scatter measurements into 8Bit integer to view the results as PNG")]),t._v("\nrescaled "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" p"),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("$")]),t._v("apply"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("data "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" merge_2"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n process "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),e("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("function")]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("data"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("context"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v(" "),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("{")]),t._v("\n p"),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("$")]),t._v("linear_scale_range"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("x"),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v("data"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" inputMin "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("-")]),e("span",{pre:!0,attrs:{class:"token number"}},[t._v("20")]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("inputMax "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("-")]),e("span",{pre:!0,attrs:{class:"token number"}},[t._v("5")]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" outputMin "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),e("span",{pre:!0,attrs:{class:"token number"}},[t._v("0")]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" outputMax "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),e("span",{pre:!0,attrs:{class:"token number"}},[t._v("255")]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n "),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("}")]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n\n"),e("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# export shall be format PNG")]),t._v("\n"),e("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# look at the format description")]),t._v("\nformats"),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("$")]),t._v("output"),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("$")]),t._v("PNG\n\n"),e("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# store the results using the format and set the create options")]),t._v("\nresult "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" p"),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("$")]),t._v("save_result"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("data "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" rescaled"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("format "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" formats"),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("$")]),t._v("output"),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("$")]),t._v("PNG"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" options "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" list"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("red"),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),e("span",{pre:!0,attrs:{class:"token string"}},[t._v('"R"')]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("green"),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),e("span",{pre:!0,attrs:{class:"token string"}},[t._v('"G"')]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("blue"),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),e("span",{pre:!0,attrs:{class:"token string"}},[t._v('"B"')]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n\n"),e("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# create a job")]),t._v("\njob "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" create_job"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("graph "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" result"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" title "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),e("span",{pre:!0,attrs:{class:"token string"}},[t._v('"S1 Example R"')]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" description "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),e("span",{pre:!0,attrs:{class:"token string"}},[t._v('"Getting Started example on openeo.org for R-client"')]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n\n"),e("span",{pre:!0,attrs:{class:"token comment"}},[t._v("# then start the processing of the job and turn on logging (messages that are captured on the back-end during the process execution)")]),t._v("\nstart_job"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("job "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" job"),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" log "),e("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),e("span",{pre:!0,attrs:{class:"token boolean"}},[t._v("TRUE")]),e("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n")])])]),e("p",[t._v("Now the resulting PNG file of the RGB backscatter composite is stored as a PNG file in the current working directory. It looks like this:")]),t._v(" "),e("p",[e("img",{attrs:{src:a(193),alt:"RGB composite"}})]),t._v(" "),e("div",{staticClass:"custom-block tip"},[e("p",{staticClass:"custom-block-title"},[t._v("TIP")]),t._v(" "),e("p",[t._v("The "),e("a",{attrs:{href:"https://github.com/Open-EO/openeo-r-client/blob/master/examples/S1-example.R",target:"_blank",rel:"noopener noreferrer"}},[t._v("source code"),e("OutboundLink")],1),t._v(" of the example can also be found on the R client repository on Github.")])]),t._v(" "),e("h2",{attrs:{id:"user-defined-functions"}},[e("a",{staticClass:"header-anchor",attrs:{href:"#user-defined-functions"}},[t._v("#")]),t._v(" User Defined Functions")]),t._v(" "),e("p",[t._v("If your use case can not be accomplished with the "),e("RouterLink",{attrs:{to:"/documentation/1.0/processes.html"}},[t._v("default processes")]),t._v(" of openEO, you can define a "),e("RouterLink",{attrs:{to:"/documentation/1.0/glossary.html#user-defined-function-udf"}},[t._v("user defined function")]),t._v(".")],1),t._v(" "),e("p",[t._v("In general the processing workflow works by uploading the Python or R script into the users file directory on the back-end and reference the script via its URL or by its relational name (e.g. "),e("code",[t._v("/scripts/script1.R")]),t._v(") in the function "),e("code",[t._v("run_udf")]),t._v(". The latter function is a predefined openEO process that the back-end might provide, if UDFs are supported.")]),t._v(" "),e("p",[t._v("Find out more about UDFs in the respective "),e("a",{attrs:{href:"https://github.com/Open-EO/openeo-udf",target:"_blank",rel:"noopener noreferrer"}},[t._v("Python UDF"),e("OutboundLink")],1),t._v(" and "),e("a",{attrs:{href:"https://github.com/Open-EO/openeo-r-udf",target:"_blank",rel:"noopener noreferrer"}},[t._v("R UDF"),e("OutboundLink")],1),t._v(" repositories with their documentation and examples.")])])}),[],!1,null,null,null);e.default=n.exports}}]); \ No newline at end of file diff --git a/assets/js/50.d1e2d680.js b/assets/js/50.549385c8.js similarity index 99% rename from assets/js/50.d1e2d680.js rename to assets/js/50.549385c8.js index 6b6a0af22..849704e45 100644 --- a/assets/js/50.d1e2d680.js +++ b/assets/js/50.549385c8.js @@ -1 +1 @@ -(window.webpackJsonp=window.webpackJsonp||[]).push([[50],{337:function(t,s,a){t.exports=a.p+"assets/img/040-pg-example.8a5fae89.png"},546:function(t,s,a){"use strict";a.r(s);var n=a(4),e=Object(n.a)({},(function(){var t=this,s=t._self._c;return s("ContentSlotsDistributor",{attrs:{"slot-key":t.$parent.slotKey}},[s("p",[t._v("Today, the openEO Consortium "),s("strong",[t._v("released the new version 0.4.0 of the "),s("a",{attrs:{href:"https://open-eo.github.io/openeo-api/",target:"_blank",rel:"noopener noreferrer"}},[t._v("openEO API"),s("OutboundLink")],1)]),t._v(". The following blog post will give a short overview over the most notable changes and additions to the API specification.")]),t._v(" "),s("h2",{attrs:{id:"new-process-catalogue-and-process-graph-changes"}},[s("a",{staticClass:"header-anchor",attrs:{href:"#new-process-catalogue-and-process-graph-changes"}},[t._v("#")]),t._v(" New process catalogue and process graph changes")]),t._v(" "),s("p",[t._v("The focus of this release was the definition of a "),s("a",{attrs:{href:"http://processes.openeo.org",target:"_blank",rel:"noopener noreferrer"}},[t._v("full process catalogue"),s("OutboundLink")],1),t._v(", which is now in implementation by the back-ends. We defined a set of over 100 processes, which can soon be used for remote sensing and related tasks. For this, we had to introduce a new encoding for the process graphs, which now allows parallelism, callbacks and more.")]),t._v(" "),s("p",[t._v("The following image shows visually how a user could derive minimum EVI measurements over pixel time series of Sentinel 2 imagery:")]),t._v(" "),s("p",[s("img",{attrs:{src:a(337),alt:"Algorithm to process an EVI"}})]),t._v(" "),s("p",[t._v("Once implemented, we plan that the following Python client code could be used to generate the process graph to send it to a back-end:")]),t._v(" "),s("div",{staticClass:"language-python extra-class"},[s("pre",{pre:!0,attrs:{class:"language-python"}},[s("code",[s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("import")]),t._v(" openeo\nsession "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" openeo"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),t._v("connect"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"https://example.openeo.org"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\ns2_radio "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" session"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),t._v("imagecollection"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"Sentinel-2"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" spatial_extent "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("{")]),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"west"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(":")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("16.1")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"east"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(":")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("16.6")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"north"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(":")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("48.6")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"south"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(":")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("47.2")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("}")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" temporal_extent "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"2018-01-01"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"2018-02-01"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\nblue "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" s2_radio"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),t._v("band"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token string"}},[t._v("'B02'")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\nred "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" s2_radio"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),t._v("band"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token string"}},[t._v("'B04'")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\nnir "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" s2_radio"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),t._v("band"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token string"}},[t._v("'B08'")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\nevi_cube "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("2.5")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("*")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("nir "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("-")]),t._v(" red"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("/")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("nir "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("+")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("6.0")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("*")]),t._v(" red "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("-")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("7.5")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("*")]),t._v(" blue"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("+")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("1.0")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\nresult "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" evi_cube"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token builtin"}},[t._v("reduce")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"temporal"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"min"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),t._v("save_result"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"GTiff"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n")])])]),s("p",[t._v("In JavaScript it is planned to work as follows:")]),t._v(" "),s("div",{staticClass:"language-js extra-class"},[s("pre",{pre:!0,attrs:{class:"language-js"}},[s("code",[s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("function")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("eviReducer")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token parameter"}},[t._v("b"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" data")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("{")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("var")]),t._v(" blue "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" data"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("at")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("0")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(";")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("var")]),t._v(" red "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" data"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("at")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("1")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(";")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("var")]),t._v(" nir "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" data"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("at")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("2")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(";")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("return")]),t._v(" b"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("product")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("2.5")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n b"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("divide")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),t._v("\n b"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("subtract")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),t._v("nir"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" red"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n b"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("sum")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("1")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" nir"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" b"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("product")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("6")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" red"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" b"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("product")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("-")]),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("7.5")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" blue"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(";")]),t._v("\n"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("}")]),t._v("\n\n"),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("var")]),t._v(" connection "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" OpenEO"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("connect")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"https://example.openeo.org"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(";")]),t._v("\n"),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("var")]),t._v(" builder "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" connection"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("buildProcessGraph")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(";")]),t._v("\n"),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("var")]),t._v(" result "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" builder"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("loadCollection")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"Sentinel-2"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("{")]),s("span",{pre:!0,attrs:{class:"token literal-property property"}},[t._v("west")]),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v(":")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("16.1")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token literal-property property"}},[t._v("east")]),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v(":")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("16.6")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token literal-property property"}},[t._v("north")]),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v(":")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("48.6")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token literal-property property"}},[t._v("south")]),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v(":")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("47.2")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("}")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"2018-01-01"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"2018-02-01"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("filterBands")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"B02"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"B04"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"B08"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("reduce")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"spectral"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" eviReducer"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("reduce")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"temporal"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token parameter"}},[t._v("b"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" data")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=>")]),t._v(" data"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("min")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("saveResult")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"GTiff"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(";")]),t._v("\n")])])]),s("p",[t._v("Similarly, it would work in the R client. You can also check the "),s("a",{attrs:{href:"https://open-eo.github.io/openeo-api/processgraphs/#example",target:"_blank",rel:"noopener noreferrer"}},[t._v("process graph documentation"),s("OutboundLink")],1),t._v(" if you'd like to know how this algorithm looks as a process graph.")]),t._v(" "),s("h2",{attrs:{id:"other-improvements"}},[s("a",{staticClass:"header-anchor",attrs:{href:"#other-improvements"}},[t._v("#")]),t._v(" Other improvements")]),t._v(" "),s("p",[t._v("We also updated our Data Discovery to be compatible with "),s("a",{attrs:{href:"https://medium.com/radiant-earth-insights/stac-extensions-and-0-6-2-release-b0cf34272ed7",target:"_blank",rel:"noopener noreferrer"}},[t._v("the most recent version of STAC, v0.6.2"),s("OutboundLink")],1),t._v(". In the last months, openEO contributed several extensions to the STAC specification such as "),s("a",{attrs:{href:"https://github.com/radiantearth/stac-spec/blob/master/extensions/sar/README.md",target:"_blank",rel:"noopener noreferrer"}},[t._v("an extension to describe Synthetic-Aperture Radar (SAR) data"),s("OutboundLink")],1),t._v(" or "),s("a",{attrs:{href:"https://github.com/radiantearth/stac-spec/blob/master/extensions/datacube/README.md",target:"_blank",rel:"noopener noreferrer"}},[t._v("an extension to describe Data Cubes"),s("OutboundLink")],1),t._v(".")]),t._v(" "),s("p",[t._v("Despite the process and data discovery, we generally improved the discovery of openEO back-ends. For example, the API now also allows clients to automatically detect supported API versions at the back-end, so that users don't need to keep track of that and can always connect to the same URL without worrying about compatibility between clients and back-ends. Our approach to "),s("a",{attrs:{href:"https://github.com/Open-EO/openeo-udf",target:"_blank",rel:"noopener noreferrer"}},[t._v("user-defined functions (UDFs)"),s("OutboundLink")],1),t._v(" was also better integrated withing the API. UDF runtimes can be discovered now and well-defined processes allow executing UDFs. Many more improvements were incorporated into the API specification based on feedback from the review meeting, discussions with users and implementations (see the "),s("a",{attrs:{href:"https://open-eo.github.io/openeo-api/changelog/",target:"_blank",rel:"noopener noreferrer"}},[t._v("full changelog"),s("OutboundLink")],1),t._v(").")]),t._v(" "),s("h2",{attrs:{id:"next-steps"}},[s("a",{staticClass:"header-anchor",attrs:{href:"#next-steps"}},[t._v("#")]),t._v(" Next steps")]),t._v(" "),s("p",[t._v("This is the API version, which is targeted towards getting the first more universally usable version of the openEO clients and back-ends released. We will work hard now to implement the back-ends and clients to comply with the new API version and will follow up with a new blog post once this is achieved. Afterwards, all interested parties can use clients and back-ends to get a first solid impression of the project. In the meantime, it is already possible to make experiments with the back-ends and clients working on the API version 0.3.1. Please "),s("a",{attrs:{href:"http://openeo.org/contact/",target:"_blank",rel:"noopener noreferrer"}},[t._v("contact us"),s("OutboundLink")],1),t._v(" to get more information about it. Having said that, the new version is not the last one and we will continue to improve the API, client and back-ends. So any feedback is highly appreciated and can be sent our way via GitHub issues in the corresponding "),s("a",{attrs:{href:"https://github.com/open-eo",target:"_blank",rel:"noopener noreferrer"}},[t._v("GitHub repositories"),s("OutboundLink")],1),t._v(" or via any of the other "),s("a",{attrs:{href:"http://openeo.org/contact/",target:"_blank",rel:"noopener noreferrer"}},[t._v("contact options"),s("OutboundLink")],1),t._v(".")])])}),[],!1,null,null,null);s.default=e.exports}}]); \ No newline at end of file +(window.webpackJsonp=window.webpackJsonp||[]).push([[50],{337:function(t,s,a){t.exports=a.p+"assets/img/040-pg-example.8a5fae89.png"},544:function(t,s,a){"use strict";a.r(s);var n=a(4),e=Object(n.a)({},(function(){var t=this,s=t._self._c;return s("ContentSlotsDistributor",{attrs:{"slot-key":t.$parent.slotKey}},[s("p",[t._v("Today, the openEO Consortium "),s("strong",[t._v("released the new version 0.4.0 of the "),s("a",{attrs:{href:"https://open-eo.github.io/openeo-api/",target:"_blank",rel:"noopener noreferrer"}},[t._v("openEO API"),s("OutboundLink")],1)]),t._v(". The following blog post will give a short overview over the most notable changes and additions to the API specification.")]),t._v(" "),s("h2",{attrs:{id:"new-process-catalogue-and-process-graph-changes"}},[s("a",{staticClass:"header-anchor",attrs:{href:"#new-process-catalogue-and-process-graph-changes"}},[t._v("#")]),t._v(" New process catalogue and process graph changes")]),t._v(" "),s("p",[t._v("The focus of this release was the definition of a "),s("a",{attrs:{href:"http://processes.openeo.org",target:"_blank",rel:"noopener noreferrer"}},[t._v("full process catalogue"),s("OutboundLink")],1),t._v(", which is now in implementation by the back-ends. We defined a set of over 100 processes, which can soon be used for remote sensing and related tasks. For this, we had to introduce a new encoding for the process graphs, which now allows parallelism, callbacks and more.")]),t._v(" "),s("p",[t._v("The following image shows visually how a user could derive minimum EVI measurements over pixel time series of Sentinel 2 imagery:")]),t._v(" "),s("p",[s("img",{attrs:{src:a(337),alt:"Algorithm to process an EVI"}})]),t._v(" "),s("p",[t._v("Once implemented, we plan that the following Python client code could be used to generate the process graph to send it to a back-end:")]),t._v(" "),s("div",{staticClass:"language-python extra-class"},[s("pre",{pre:!0,attrs:{class:"language-python"}},[s("code",[s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("import")]),t._v(" openeo\nsession "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" openeo"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),t._v("connect"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"https://example.openeo.org"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\ns2_radio "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" session"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),t._v("imagecollection"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"Sentinel-2"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" spatial_extent "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("{")]),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"west"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(":")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("16.1")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"east"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(":")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("16.6")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"north"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(":")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("48.6")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"south"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(":")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("47.2")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("}")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" temporal_extent "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"2018-01-01"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"2018-02-01"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\nblue "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" s2_radio"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),t._v("band"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token string"}},[t._v("'B02'")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\nred "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" s2_radio"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),t._v("band"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token string"}},[t._v("'B04'")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\nnir "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" s2_radio"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),t._v("band"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token string"}},[t._v("'B08'")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\nevi_cube "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("2.5")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("*")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("nir "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("-")]),t._v(" red"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("/")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("nir "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("+")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("6.0")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("*")]),t._v(" red "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("-")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("7.5")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("*")]),t._v(" blue"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("+")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("1.0")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\nresult "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" evi_cube"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token builtin"}},[t._v("reduce")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"temporal"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"min"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),t._v("save_result"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"GTiff"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n")])])]),s("p",[t._v("In JavaScript it is planned to work as follows:")]),t._v(" "),s("div",{staticClass:"language-js extra-class"},[s("pre",{pre:!0,attrs:{class:"language-js"}},[s("code",[s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("function")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("eviReducer")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token parameter"}},[t._v("b"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" data")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("{")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("var")]),t._v(" blue "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" data"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("at")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("0")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(";")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("var")]),t._v(" red "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" data"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("at")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("1")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(";")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("var")]),t._v(" nir "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" data"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("at")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("2")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(";")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("return")]),t._v(" b"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("product")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("2.5")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n b"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("divide")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),t._v("\n b"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("subtract")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),t._v("nir"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" red"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n b"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("sum")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("1")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" nir"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" b"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("product")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("6")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" red"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" b"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("product")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("-")]),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("7.5")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" blue"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(";")]),t._v("\n"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("}")]),t._v("\n\n"),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("var")]),t._v(" connection "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" OpenEO"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("connect")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"https://example.openeo.org"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(";")]),t._v("\n"),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("var")]),t._v(" builder "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" connection"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("buildProcessGraph")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(";")]),t._v("\n"),s("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("var")]),t._v(" result "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" builder"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("loadCollection")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"Sentinel-2"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("{")]),s("span",{pre:!0,attrs:{class:"token literal-property property"}},[t._v("west")]),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v(":")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("16.1")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token literal-property property"}},[t._v("east")]),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v(":")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("16.6")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token literal-property property"}},[t._v("north")]),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v(":")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("48.6")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token literal-property property"}},[t._v("south")]),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v(":")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token number"}},[t._v("47.2")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("}")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"2018-01-01"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"2018-02-01"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("filterBands")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"B02"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"B04"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"B08"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("reduce")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"spectral"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" eviReducer"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("reduce")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"temporal"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token parameter"}},[t._v("b"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" data")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v(" "),s("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=>")]),t._v(" data"),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("min")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n "),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),s("span",{pre:!0,attrs:{class:"token function"}},[t._v("saveResult")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),s("span",{pre:!0,attrs:{class:"token string"}},[t._v('"GTiff"')]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),s("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(";")]),t._v("\n")])])]),s("p",[t._v("Similarly, it would work in the R client. You can also check the "),s("a",{attrs:{href:"https://open-eo.github.io/openeo-api/processgraphs/#example",target:"_blank",rel:"noopener noreferrer"}},[t._v("process graph documentation"),s("OutboundLink")],1),t._v(" if you'd like to know how this algorithm looks as a process graph.")]),t._v(" "),s("h2",{attrs:{id:"other-improvements"}},[s("a",{staticClass:"header-anchor",attrs:{href:"#other-improvements"}},[t._v("#")]),t._v(" Other improvements")]),t._v(" "),s("p",[t._v("We also updated our Data Discovery to be compatible with "),s("a",{attrs:{href:"https://medium.com/radiant-earth-insights/stac-extensions-and-0-6-2-release-b0cf34272ed7",target:"_blank",rel:"noopener noreferrer"}},[t._v("the most recent version of STAC, v0.6.2"),s("OutboundLink")],1),t._v(". In the last months, openEO contributed several extensions to the STAC specification such as "),s("a",{attrs:{href:"https://github.com/radiantearth/stac-spec/blob/master/extensions/sar/README.md",target:"_blank",rel:"noopener noreferrer"}},[t._v("an extension to describe Synthetic-Aperture Radar (SAR) data"),s("OutboundLink")],1),t._v(" or "),s("a",{attrs:{href:"https://github.com/radiantearth/stac-spec/blob/master/extensions/datacube/README.md",target:"_blank",rel:"noopener noreferrer"}},[t._v("an extension to describe Data Cubes"),s("OutboundLink")],1),t._v(".")]),t._v(" "),s("p",[t._v("Despite the process and data discovery, we generally improved the discovery of openEO back-ends. For example, the API now also allows clients to automatically detect supported API versions at the back-end, so that users don't need to keep track of that and can always connect to the same URL without worrying about compatibility between clients and back-ends. Our approach to "),s("a",{attrs:{href:"https://github.com/Open-EO/openeo-udf",target:"_blank",rel:"noopener noreferrer"}},[t._v("user-defined functions (UDFs)"),s("OutboundLink")],1),t._v(" was also better integrated withing the API. UDF runtimes can be discovered now and well-defined processes allow executing UDFs. Many more improvements were incorporated into the API specification based on feedback from the review meeting, discussions with users and implementations (see the "),s("a",{attrs:{href:"https://open-eo.github.io/openeo-api/changelog/",target:"_blank",rel:"noopener noreferrer"}},[t._v("full changelog"),s("OutboundLink")],1),t._v(").")]),t._v(" "),s("h2",{attrs:{id:"next-steps"}},[s("a",{staticClass:"header-anchor",attrs:{href:"#next-steps"}},[t._v("#")]),t._v(" Next steps")]),t._v(" "),s("p",[t._v("This is the API version, which is targeted towards getting the first more universally usable version of the openEO clients and back-ends released. We will work hard now to implement the back-ends and clients to comply with the new API version and will follow up with a new blog post once this is achieved. Afterwards, all interested parties can use clients and back-ends to get a first solid impression of the project. In the meantime, it is already possible to make experiments with the back-ends and clients working on the API version 0.3.1. Please "),s("a",{attrs:{href:"http://openeo.org/contact/",target:"_blank",rel:"noopener noreferrer"}},[t._v("contact us"),s("OutboundLink")],1),t._v(" to get more information about it. Having said that, the new version is not the last one and we will continue to improve the API, client and back-ends. So any feedback is highly appreciated and can be sent our way via GitHub issues in the corresponding "),s("a",{attrs:{href:"https://github.com/open-eo",target:"_blank",rel:"noopener noreferrer"}},[t._v("GitHub repositories"),s("OutboundLink")],1),t._v(" or via any of the other "),s("a",{attrs:{href:"http://openeo.org/contact/",target:"_blank",rel:"noopener noreferrer"}},[t._v("contact options"),s("OutboundLink")],1),t._v(".")])])}),[],!1,null,null,null);s.default=e.exports}}]); \ No newline at end of file diff --git a/assets/js/56.d02232ba.js b/assets/js/56.e2cfc988.js similarity index 97% rename from assets/js/56.d02232ba.js rename to assets/js/56.e2cfc988.js index 1820960d6..99816163b 100644 --- a/assets/js/56.d02232ba.js +++ b/assets/js/56.e2cfc988.js @@ -1 +1 @@ -(window.webpackJsonp=window.webpackJsonp||[]).push([[56],{495:function(e,t,n){"use strict";n.r(t);var r=n(4),o=Object(r.a)({},(function(){var e=this,t=e._self._c;return t("ContentSlotsDistributor",{attrs:{"slot-key":e.$parent.slotKey}},[t("h1",{attrs:{id:"contact"}},[t("a",{staticClass:"header-anchor",attrs:{href:"#contact"}},[e._v("#")]),e._v(" Contact")]),e._v(" "),t("p",[e._v("University of Münster"),t("br"),e._v("\nInstitute for Geoinformatics"),t("br"),e._v("\nc/o Edzer Pebesma"),t("br"),e._v("\nHeisenbergstraße 2"),t("br"),e._v("\n48149 Münster"),t("br"),e._v("\nGermany"),t("br")]),e._v(" "),t("div",{staticClass:"custom-block tip"},[t("p",{staticClass:"custom-block-title"},[e._v("Note")]),e._v(" "),t("p",[e._v("The email address below is meant for general topics around the openEO project, openEO PSC, openEO API specification, or openEO process specification.\nThe email address below is "),t("strong",[e._v("NOT")]),e._v(" meant for technical support regarding specific service providers or client implementations.")]),e._v(" "),t("ul",[t("li",[e._v("If you need help with specific service providers (e.g. openEO Platform or CDSE), please use their support channels.\n"),t("ul",[t("li",[t("a",{attrs:{href:"https://forums.openeo.cloud",target:"_blank",rel:"noopener noreferrer"}},[e._v("openEO Platform Support Forum"),t("OutboundLink")],1)]),e._v(" "),t("li",[t("a",{attrs:{href:"https://helpcenter.dataspace.copernicus.eu/hc/en-gb/community/topics",target:"_blank",rel:"noopener noreferrer"}},[e._v("Copernicus Dataspace Ecosystem Support"),t("OutboundLink")],1)])])]),e._v(" "),t("li",[e._v("If you need help with specific clients, please use the corresponding GitHub issue trackers:\n"),t("ul",[t("li",[t("a",{attrs:{href:"https://github.com/Open-EO/openeo-python-client/issues",target:"_blank",rel:"noopener noreferrer"}},[e._v("Python client"),t("OutboundLink")],1)]),e._v(" "),t("li",[t("a",{attrs:{href:"https://github.com/Open-EO/openeo-r-client/issues",target:"_blank",rel:"noopener noreferrer"}},[e._v("R Client"),t("OutboundLink")],1)]),e._v(" "),t("li",[t("a",{attrs:{href:"https://github.com/Open-EO/openeo-js-client/issues",target:"_blank",rel:"noopener noreferrer"}},[e._v("Javascript Client"),t("OutboundLink")],1)]),e._v(" "),t("li",[t("a",{attrs:{href:"https://github.com/Open-EO/openeo-web-editor/issues",target:"_blank",rel:"noopener noreferrer"}},[e._v("Web Editor"),t("OutboundLink")],1)])])]),e._v(" "),t("li",[e._v("If you have general questions or want to get in touch with the community, we recommend to join the chat (see below) and/or "),t("RouterLink",{attrs:{to:"/news/2022-07-07-monthly-dev-calls.html"}},[e._v("join the monthly community calls")]),e._v(".")],1)])]),e._v(" "),t("Channels",{attrs:{youtube:!1,code:!1}})],1)}),[],!1,null,null,null);t.default=o.exports}}]); \ No newline at end of file +(window.webpackJsonp=window.webpackJsonp||[]).push([[56],{493:function(e,t,n){"use strict";n.r(t);var r=n(4),o=Object(r.a)({},(function(){var e=this,t=e._self._c;return t("ContentSlotsDistributor",{attrs:{"slot-key":e.$parent.slotKey}},[t("h1",{attrs:{id:"contact"}},[t("a",{staticClass:"header-anchor",attrs:{href:"#contact"}},[e._v("#")]),e._v(" Contact")]),e._v(" "),t("p",[e._v("University of Münster"),t("br"),e._v("\nInstitute for Geoinformatics"),t("br"),e._v("\nc/o Edzer Pebesma"),t("br"),e._v("\nHeisenbergstraße 2"),t("br"),e._v("\n48149 Münster"),t("br"),e._v("\nGermany"),t("br")]),e._v(" "),t("div",{staticClass:"custom-block tip"},[t("p",{staticClass:"custom-block-title"},[e._v("Note")]),e._v(" "),t("p",[e._v("The email address below is meant for general topics around the openEO project, openEO PSC, openEO API specification, or openEO process specification.\nThe email address below is "),t("strong",[e._v("NOT")]),e._v(" meant for technical support regarding specific service providers or client implementations.")]),e._v(" "),t("ul",[t("li",[e._v("If you need help with specific service providers (e.g. openEO Platform or CDSE), please use their support channels.\n"),t("ul",[t("li",[t("a",{attrs:{href:"https://forums.openeo.cloud",target:"_blank",rel:"noopener noreferrer"}},[e._v("openEO Platform Support Forum"),t("OutboundLink")],1)]),e._v(" "),t("li",[t("a",{attrs:{href:"https://helpcenter.dataspace.copernicus.eu/hc/en-gb/community/topics",target:"_blank",rel:"noopener noreferrer"}},[e._v("Copernicus Dataspace Ecosystem Support"),t("OutboundLink")],1)])])]),e._v(" "),t("li",[e._v("If you need help with specific clients, please use the corresponding GitHub issue trackers:\n"),t("ul",[t("li",[t("a",{attrs:{href:"https://github.com/Open-EO/openeo-python-client/issues",target:"_blank",rel:"noopener noreferrer"}},[e._v("Python client"),t("OutboundLink")],1)]),e._v(" "),t("li",[t("a",{attrs:{href:"https://github.com/Open-EO/openeo-r-client/issues",target:"_blank",rel:"noopener noreferrer"}},[e._v("R Client"),t("OutboundLink")],1)]),e._v(" "),t("li",[t("a",{attrs:{href:"https://github.com/Open-EO/openeo-js-client/issues",target:"_blank",rel:"noopener noreferrer"}},[e._v("Javascript Client"),t("OutboundLink")],1)]),e._v(" "),t("li",[t("a",{attrs:{href:"https://github.com/Open-EO/openeo-web-editor/issues",target:"_blank",rel:"noopener noreferrer"}},[e._v("Web Editor"),t("OutboundLink")],1)])])]),e._v(" "),t("li",[e._v("If you have general questions or want to get in touch with the community, we recommend to join the chat (see below) and/or "),t("RouterLink",{attrs:{to:"/news/2022-07-07-monthly-dev-calls.html"}},[e._v("join the monthly community calls")]),e._v(".")],1)])]),e._v(" "),t("Channels",{attrs:{youtube:!1,code:!1}})],1)}),[],!1,null,null,null);t.default=o.exports}}]); \ No newline at end of file diff --git a/assets/js/57.be023c0a.js b/assets/js/57.11b1ea76.js similarity index 96% rename from assets/js/57.be023c0a.js rename to assets/js/57.11b1ea76.js index 5ca5b832f..32d1de22d 100644 --- a/assets/js/57.be023c0a.js +++ b/assets/js/57.11b1ea76.js @@ -1 +1 @@ -(window.webpackJsonp=window.webpackJsonp||[]).push([[57],{493:function(t,e,o){"use strict";o.r(e);var n=o(4),s=Object(n.a)({},(function(){var t=this,e=t._self._c;return e("ContentSlotsDistributor",{attrs:{"slot-key":t.$parent.slotKey}},[e("h1",{attrs:{id:"openeo-documentation"}},[e("a",{staticClass:"header-anchor",attrs:{href:"#openeo-documentation"}},[t._v("#")]),t._v(" openEO Documentation")]),t._v(" "),e("p",[t._v("This is the openEO Documentation for "),e("strong",[t._v("API versions 0.4")]),t._v(". This version is "),e("strong",[t._v("outdated")]),t._v(" and got replaced by "),e("strong",[e("RouterLink",{attrs:{to:"/documentation/1.0/"}},[t._v("API version 1.0")])],1),t._v(".")]),t._v(" "),e("p",[t._v("Some useful links to get started:")]),t._v(" "),e("ul",[e("li",[e("RouterLink",{attrs:{to:"/documentation/0.4/getting-started.html"}},[t._v("Getting started for users")])],1),t._v(" "),e("li",[e("RouterLink",{attrs:{to:"/documentation/0.4/developers/clients/getting-started.html"}},[t._v("Getting started for client developers")])],1),t._v(" "),e("li",[e("RouterLink",{attrs:{to:"/documentation/0.4/developers/backends/getting-started.html"}},[t._v("Getting started for service providers")])],1),t._v(" "),e("li",[e("RouterLink",{attrs:{to:"/documentation/0.4/glossary.html"}},[t._v("openEO Glossary")])],1),t._v(" "),e("li",[e("RouterLink",{attrs:{to:"/documentation/0.4/processes.html"}},[t._v("openEO Processes")])],1),t._v(" "),e("li",[e("RouterLink",{attrs:{to:"/documentation/0.4/udfs.html"}},[t._v("openEO UDFs for users")])],1),t._v(" "),e("li",[e("RouterLink",{attrs:{to:"/documentation/0.4/developers/api/reference.html"}},[t._v("openEO API")])],1)]),t._v(" "),e("p",[t._v('Feel encouraged to use the "User Documentation" and "Developers" menu items for further navigation through the documentation.')])])}),[],!1,null,null,null);e.default=s.exports}}]); \ No newline at end of file +(window.webpackJsonp=window.webpackJsonp||[]).push([[57],{497:function(t,e,o){"use strict";o.r(e);var n=o(4),s=Object(n.a)({},(function(){var t=this,e=t._self._c;return e("ContentSlotsDistributor",{attrs:{"slot-key":t.$parent.slotKey}},[e("h1",{attrs:{id:"openeo-documentation"}},[e("a",{staticClass:"header-anchor",attrs:{href:"#openeo-documentation"}},[t._v("#")]),t._v(" openEO Documentation")]),t._v(" "),e("p",[t._v("This is the openEO Documentation for "),e("strong",[t._v("API versions 0.4")]),t._v(". This version is "),e("strong",[t._v("outdated")]),t._v(" and got replaced by "),e("strong",[e("RouterLink",{attrs:{to:"/documentation/1.0/"}},[t._v("API version 1.0")])],1),t._v(".")]),t._v(" "),e("p",[t._v("Some useful links to get started:")]),t._v(" "),e("ul",[e("li",[e("RouterLink",{attrs:{to:"/documentation/0.4/getting-started.html"}},[t._v("Getting started for users")])],1),t._v(" "),e("li",[e("RouterLink",{attrs:{to:"/documentation/0.4/developers/clients/getting-started.html"}},[t._v("Getting started for client developers")])],1),t._v(" "),e("li",[e("RouterLink",{attrs:{to:"/documentation/0.4/developers/backends/getting-started.html"}},[t._v("Getting started for service providers")])],1),t._v(" "),e("li",[e("RouterLink",{attrs:{to:"/documentation/0.4/glossary.html"}},[t._v("openEO Glossary")])],1),t._v(" "),e("li",[e("RouterLink",{attrs:{to:"/documentation/0.4/processes.html"}},[t._v("openEO Processes")])],1),t._v(" "),e("li",[e("RouterLink",{attrs:{to:"/documentation/0.4/udfs.html"}},[t._v("openEO UDFs for users")])],1),t._v(" "),e("li",[e("RouterLink",{attrs:{to:"/documentation/0.4/developers/api/reference.html"}},[t._v("openEO API")])],1)]),t._v(" "),e("p",[t._v('Feel encouraged to use the "User Documentation" and "Developers" menu items for further navigation through the documentation.')])])}),[],!1,null,null,null);e.default=s.exports}}]); \ No newline at end of file diff --git a/assets/js/59.98d52ecf.js b/assets/js/59.5579ff71.js similarity index 77% rename from assets/js/59.98d52ecf.js rename to assets/js/59.5579ff71.js index 5215f7702..618abe94d 100644 --- a/assets/js/59.98d52ecf.js +++ b/assets/js/59.5579ff71.js @@ -1 +1 @@ -(window.webpackJsonp=window.webpackJsonp||[]).push([[59],{496:function(t,n,s){"use strict";s.r(n);var e=s(4),o=Object(e.a)({},(function(){return(0,this._self._c)("ContentSlotsDistributor",{attrs:{"slot-key":this.$parent.slotKey}})}),[],!1,null,null,null);n.default=o.exports}}]); \ No newline at end of file +(window.webpackJsonp=window.webpackJsonp||[]).push([[59],{495:function(t,n,s){"use strict";s.r(n);var e=s(4),o=Object(e.a)({},(function(){return(0,this._self._c)("ContentSlotsDistributor",{attrs:{"slot-key":this.$parent.slotKey}})}),[],!1,null,null,null);n.default=o.exports}}]); \ No newline at end of file diff --git a/assets/js/60.597380b5.js b/assets/js/60.53f362ae.js similarity index 99% rename from assets/js/60.597380b5.js rename to assets/js/60.53f362ae.js index d5cc9cce0..2b6c195aa 100644 --- a/assets/js/60.597380b5.js +++ b/assets/js/60.53f362ae.js @@ -1 +1 @@ -(window.webpackJsonp=window.webpackJsonp||[]).push([[60],{497:function(e,t,r){"use strict";r.r(t);var s=r(4),o=Object(s.a)({},(function(){var e=this,t=e._self._c;return t("ContentSlotsDistributor",{attrs:{"slot-key":e.$parent.slotKey}},[t("h1",{attrs:{id:"status-and-error-handling"}},[t("a",{staticClass:"header-anchor",attrs:{href:"#status-and-error-handling"}},[e._v("#")]),e._v(" Status and error handling")]),e._v(" "),t("p",[e._v("The success of requests MUST be indicated using "),t("a",{attrs:{href:"https://tools.ietf.org/html/rfc7231#section-6",target:"_blank",rel:"noopener noreferrer"}},[e._v("HTTP status codes"),t("OutboundLink")],1),e._v(" according to "),t("a",{attrs:{href:"https://tools.ietf.org/html/rfc7231",target:"_blank",rel:"noopener noreferrer"}},[e._v("RFC 7231"),t("OutboundLink")],1),e._v(".")]),e._v(" "),t("p",[e._v("If the API responds with a status code between 100 and 399 the back-end indicates that the request has been handled successfully.")]),e._v(" "),t("p",[e._v("In general an error is communicated with a status code between 400 and 599. Client errors are defined as a client passing invalid data to the service and the service "),t("em",[e._v("correctly")]),e._v(' rejecting that data. Examples include invalid credentials, incorrect parameters, unknown versions, or similar. These are generally "4xx" HTTP error codes and are the result of a client passing incorrect or invalid data. Client errors do '),t("em",[e._v("not")]),e._v(" contribute to overall API availability.")]),e._v(" "),t("p",[e._v('Server errors are defined as the server failing to correctly return in response to a valid client request. These are generally "5xx" HTTP error codes. Server errors '),t("em",[e._v("do")]),e._v(" contribute to the overall API availability. Calls that fail due to rate limiting or quota failures MUST NOT count as server errors.")]),e._v(" "),t("h2",{attrs:{id:"json-error-object"}},[t("a",{staticClass:"header-anchor",attrs:{href:"#json-error-object"}},[e._v("#")]),e._v(" JSON error object")]),e._v(" "),t("p",[e._v("A JSON error object SHOULD be sent with all responses that have a status code between 400 and 599.")]),e._v(" "),t("div",{staticClass:"language-json extra-class"},[t("pre",{pre:!0,attrs:{class:"language-json"}},[t("code",[t("span",{pre:!0,attrs:{class:"token punctuation"}},[e._v("{")]),e._v("\n "),t("span",{pre:!0,attrs:{class:"token property"}},[e._v('"id"')]),t("span",{pre:!0,attrs:{class:"token operator"}},[e._v(":")]),e._v(" "),t("span",{pre:!0,attrs:{class:"token string"}},[e._v('"936DA01F-9ABD-4D9D-80C7-02AF85C822A8"')]),t("span",{pre:!0,attrs:{class:"token punctuation"}},[e._v(",")]),e._v("\n "),t("span",{pre:!0,attrs:{class:"token property"}},[e._v('"code"')]),t("span",{pre:!0,attrs:{class:"token operator"}},[e._v(":")]),e._v(" "),t("span",{pre:!0,attrs:{class:"token string"}},[e._v('"SampleError"')]),t("span",{pre:!0,attrs:{class:"token punctuation"}},[e._v(",")]),e._v("\n "),t("span",{pre:!0,attrs:{class:"token property"}},[e._v('"message"')]),t("span",{pre:!0,attrs:{class:"token operator"}},[e._v(":")]),e._v(" "),t("span",{pre:!0,attrs:{class:"token string"}},[e._v('"A sample error message."')]),t("span",{pre:!0,attrs:{class:"token punctuation"}},[e._v(",")]),e._v("\n "),t("span",{pre:!0,attrs:{class:"token property"}},[e._v('"url"')]),t("span",{pre:!0,attrs:{class:"token operator"}},[e._v(":")]),e._v(" "),t("span",{pre:!0,attrs:{class:"token string"}},[e._v('"http://www.openeo.org/docs/errors/SampleError"')]),e._v("\n"),t("span",{pre:!0,attrs:{class:"token punctuation"}},[e._v("}")]),e._v("\n")])])]),t("p",[e._v("Sending "),t("code",[e._v("code")]),e._v(" and "),t("code",[e._v("message")]),e._v(" is REQUIRED.")]),e._v(" "),t("ul",[t("li",[t("p",[e._v("A back-end MAY add a free-form "),t("code",[e._v("id")]),e._v(" (unique identifier) to the error response to be able to log and track errors with further non-disclosable details.")])]),e._v(" "),t("li",[t("p",[e._v("The "),t("code",[e._v("code")]),e._v(" is either one of the standardized textual openEO error codes below or a proprietary error code.")])]),e._v(" "),t("li",[t("p",[e._v("The "),t("code",[e._v("message")]),e._v(' explains the reason the server is rejecting the request. For "4xx" error codes the message explains how the client needs to modify the request.')]),e._v(" "),t("p",[e._v("By default the message MUST be sent in English language. Content Negotiation is used to localize the error messages: If an "),t("code",[e._v("Accept-Language")]),e._v(" header is sent by the client and a translation is available, the message should be translated accordingly and the "),t("code",[e._v("Content-Language")]),e._v(' header must be present in the response. See "'),t("a",{attrs:{href:"http://apiux.com/2013/04/25/how-to-localize-your-api/",target:"_blank",rel:"noopener noreferrer"}},[e._v("How to localize your API"),t("OutboundLink")],1),e._v('" for more information.')])]),e._v(" "),t("li",[t("p",[t("code",[e._v("url")]),e._v(" is an OPTIONAL attribute and contains a link to a resource that is explaining the error and potential solutions in-depth.")])])]),e._v(" "),t("h2",{attrs:{id:"standardized-status-codes"}},[t("a",{staticClass:"header-anchor",attrs:{href:"#standardized-status-codes"}},[e._v("#")]),e._v(" Standardized status codes")]),e._v(" "),t("p",[e._v("The openEO API usually uses the following HTTP status codes for successful requests:")]),e._v(" "),t("ul",[t("li",[t("strong",[e._v("200 OK")]),e._v(":\nIndicates a successful request "),t("strong",[e._v("with")]),e._v(" a response body being sent.")]),e._v(" "),t("li",[t("strong",[e._v("201 Created")]),e._v("\nIndicates a successful request that successfully created a new resource. Sends a "),t("code",[e._v("Location")]),e._v(" header to the newly created resource "),t("strong",[e._v("without")]),e._v(" a response body.")]),e._v(" "),t("li",[t("strong",[e._v("202 Accepted")]),e._v("\nIndicates a successful request that successfully queued the creation of a new resource, but it has not been created yet. The response is sent "),t("strong",[e._v("without")]),e._v(" a response body.")]),e._v(" "),t("li",[t("strong",[e._v("204 No Content")]),e._v(":\nIndicates a successful request "),t("strong",[e._v("without")]),e._v(" a response body being sent.")])]),e._v(" "),t("p",[e._v("The openEO API often uses the following HTTP status codes for failed requests:")]),e._v(" "),t("ul",[t("li",[t("p",[t("strong",[e._v("400 Bad Request")]),e._v(":\nThe back-end responds with this error code whenever the error has its origin on client side and no other HTTP status code in the 400 range is suitable.")])]),e._v(" "),t("li",[t("p",[t("strong",[e._v("401 Unauthorized")]),e._v(":\nThe client did not provide any authentication details for a resource requiring authentication or the provided authentication details are not correct.")])]),e._v(" "),t("li",[t("p",[t("strong",[e._v("403 Forbidden")]),e._v(":\nThe client did provided correct authentication details, but the privileges/permissions of the provided credentials do not allow to request the resource.")])]),e._v(" "),t("li",[t("p",[t("strong",[e._v("404 Not Found")]),e._v(":\nThe resource specified by the path does not exist, i.e. one of the resources belonging to the specified identifiers are not available at the back-end.\n"),t("em",[e._v("Note:")]),e._v(" Unsupported endpoints MUST use HTTP status code 501.")])]),e._v(" "),t("li",[t("p",[t("strong",[e._v("500 Internal Server Error")]),e._v(":\nThe error has its origin on server side and no other status code in the 500 range is suitable.")])]),e._v(" "),t("li",[t("p",[t("strong",[e._v("501 Not Implemented")]),e._v(":\nAn endpoint is specified in the openEO API, but is not supported.")])])]),e._v(" "),t("p",[e._v("If a HTTP status code in the 400 range is returned, the client SHOULD NOT repeat the request without modifications. For HTTP status code in the 500 range, the client MAY repeat the same request later.")]),e._v(" "),t("p",[e._v("All HTTP status codes defined in RFC 7231 in the 400 and 500 ranges can be used as openEO error code in addition to the most used status codes mentioned here. Responding with openEO error codes 400 and 500 SHOULD be avoided in favor of any more specific standardized or proprietary openEO error code.")]),e._v(" "),t("h2",{attrs:{id:"openeo-error-codes"}},[t("a",{staticClass:"header-anchor",attrs:{href:"#openeo-error-codes"}},[e._v("#")]),e._v(" openEO error codes")]),e._v(" "),t("p",[e._v("The following table of error codes is "),t("strong",[e._v("incomplete")]),e._v(". These error codes will evolve over time. If you are missing any common error, please contribute it by adding an "),t("a",{attrs:{href:"https://github.com/Open-EO/openeo-api/issues/new",target:"_blank",rel:"noopener noreferrer"}},[e._v("issue"),t("OutboundLink")],1),e._v(", creating a pull request or get in contact in our "),t("a",{attrs:{href:"https://openeo-chat.eodc.eu/channel/public",target:"_blank",rel:"noopener noreferrer"}},[e._v("chat room"),t("OutboundLink")],1),e._v(".")]),e._v(" "),t("ErrorCodes")],1)}),[],!1,null,null,null);t.default=o.exports}}]); \ No newline at end of file +(window.webpackJsonp=window.webpackJsonp||[]).push([[60],{496:function(e,t,r){"use strict";r.r(t);var s=r(4),o=Object(s.a)({},(function(){var e=this,t=e._self._c;return t("ContentSlotsDistributor",{attrs:{"slot-key":e.$parent.slotKey}},[t("h1",{attrs:{id:"status-and-error-handling"}},[t("a",{staticClass:"header-anchor",attrs:{href:"#status-and-error-handling"}},[e._v("#")]),e._v(" Status and error handling")]),e._v(" "),t("p",[e._v("The success of requests MUST be indicated using "),t("a",{attrs:{href:"https://tools.ietf.org/html/rfc7231#section-6",target:"_blank",rel:"noopener noreferrer"}},[e._v("HTTP status codes"),t("OutboundLink")],1),e._v(" according to "),t("a",{attrs:{href:"https://tools.ietf.org/html/rfc7231",target:"_blank",rel:"noopener noreferrer"}},[e._v("RFC 7231"),t("OutboundLink")],1),e._v(".")]),e._v(" "),t("p",[e._v("If the API responds with a status code between 100 and 399 the back-end indicates that the request has been handled successfully.")]),e._v(" "),t("p",[e._v("In general an error is communicated with a status code between 400 and 599. Client errors are defined as a client passing invalid data to the service and the service "),t("em",[e._v("correctly")]),e._v(' rejecting that data. Examples include invalid credentials, incorrect parameters, unknown versions, or similar. These are generally "4xx" HTTP error codes and are the result of a client passing incorrect or invalid data. Client errors do '),t("em",[e._v("not")]),e._v(" contribute to overall API availability.")]),e._v(" "),t("p",[e._v('Server errors are defined as the server failing to correctly return in response to a valid client request. These are generally "5xx" HTTP error codes. Server errors '),t("em",[e._v("do")]),e._v(" contribute to the overall API availability. Calls that fail due to rate limiting or quota failures MUST NOT count as server errors.")]),e._v(" "),t("h2",{attrs:{id:"json-error-object"}},[t("a",{staticClass:"header-anchor",attrs:{href:"#json-error-object"}},[e._v("#")]),e._v(" JSON error object")]),e._v(" "),t("p",[e._v("A JSON error object SHOULD be sent with all responses that have a status code between 400 and 599.")]),e._v(" "),t("div",{staticClass:"language-json extra-class"},[t("pre",{pre:!0,attrs:{class:"language-json"}},[t("code",[t("span",{pre:!0,attrs:{class:"token punctuation"}},[e._v("{")]),e._v("\n "),t("span",{pre:!0,attrs:{class:"token property"}},[e._v('"id"')]),t("span",{pre:!0,attrs:{class:"token operator"}},[e._v(":")]),e._v(" "),t("span",{pre:!0,attrs:{class:"token string"}},[e._v('"936DA01F-9ABD-4D9D-80C7-02AF85C822A8"')]),t("span",{pre:!0,attrs:{class:"token punctuation"}},[e._v(",")]),e._v("\n "),t("span",{pre:!0,attrs:{class:"token property"}},[e._v('"code"')]),t("span",{pre:!0,attrs:{class:"token operator"}},[e._v(":")]),e._v(" "),t("span",{pre:!0,attrs:{class:"token string"}},[e._v('"SampleError"')]),t("span",{pre:!0,attrs:{class:"token punctuation"}},[e._v(",")]),e._v("\n "),t("span",{pre:!0,attrs:{class:"token property"}},[e._v('"message"')]),t("span",{pre:!0,attrs:{class:"token operator"}},[e._v(":")]),e._v(" "),t("span",{pre:!0,attrs:{class:"token string"}},[e._v('"A sample error message."')]),t("span",{pre:!0,attrs:{class:"token punctuation"}},[e._v(",")]),e._v("\n "),t("span",{pre:!0,attrs:{class:"token property"}},[e._v('"url"')]),t("span",{pre:!0,attrs:{class:"token operator"}},[e._v(":")]),e._v(" "),t("span",{pre:!0,attrs:{class:"token string"}},[e._v('"http://www.openeo.org/docs/errors/SampleError"')]),e._v("\n"),t("span",{pre:!0,attrs:{class:"token punctuation"}},[e._v("}")]),e._v("\n")])])]),t("p",[e._v("Sending "),t("code",[e._v("code")]),e._v(" and "),t("code",[e._v("message")]),e._v(" is REQUIRED.")]),e._v(" "),t("ul",[t("li",[t("p",[e._v("A back-end MAY add a free-form "),t("code",[e._v("id")]),e._v(" (unique identifier) to the error response to be able to log and track errors with further non-disclosable details.")])]),e._v(" "),t("li",[t("p",[e._v("The "),t("code",[e._v("code")]),e._v(" is either one of the standardized textual openEO error codes below or a proprietary error code.")])]),e._v(" "),t("li",[t("p",[e._v("The "),t("code",[e._v("message")]),e._v(' explains the reason the server is rejecting the request. For "4xx" error codes the message explains how the client needs to modify the request.')]),e._v(" "),t("p",[e._v("By default the message MUST be sent in English language. Content Negotiation is used to localize the error messages: If an "),t("code",[e._v("Accept-Language")]),e._v(" header is sent by the client and a translation is available, the message should be translated accordingly and the "),t("code",[e._v("Content-Language")]),e._v(' header must be present in the response. See "'),t("a",{attrs:{href:"http://apiux.com/2013/04/25/how-to-localize-your-api/",target:"_blank",rel:"noopener noreferrer"}},[e._v("How to localize your API"),t("OutboundLink")],1),e._v('" for more information.')])]),e._v(" "),t("li",[t("p",[t("code",[e._v("url")]),e._v(" is an OPTIONAL attribute and contains a link to a resource that is explaining the error and potential solutions in-depth.")])])]),e._v(" "),t("h2",{attrs:{id:"standardized-status-codes"}},[t("a",{staticClass:"header-anchor",attrs:{href:"#standardized-status-codes"}},[e._v("#")]),e._v(" Standardized status codes")]),e._v(" "),t("p",[e._v("The openEO API usually uses the following HTTP status codes for successful requests:")]),e._v(" "),t("ul",[t("li",[t("strong",[e._v("200 OK")]),e._v(":\nIndicates a successful request "),t("strong",[e._v("with")]),e._v(" a response body being sent.")]),e._v(" "),t("li",[t("strong",[e._v("201 Created")]),e._v("\nIndicates a successful request that successfully created a new resource. Sends a "),t("code",[e._v("Location")]),e._v(" header to the newly created resource "),t("strong",[e._v("without")]),e._v(" a response body.")]),e._v(" "),t("li",[t("strong",[e._v("202 Accepted")]),e._v("\nIndicates a successful request that successfully queued the creation of a new resource, but it has not been created yet. The response is sent "),t("strong",[e._v("without")]),e._v(" a response body.")]),e._v(" "),t("li",[t("strong",[e._v("204 No Content")]),e._v(":\nIndicates a successful request "),t("strong",[e._v("without")]),e._v(" a response body being sent.")])]),e._v(" "),t("p",[e._v("The openEO API often uses the following HTTP status codes for failed requests:")]),e._v(" "),t("ul",[t("li",[t("p",[t("strong",[e._v("400 Bad Request")]),e._v(":\nThe back-end responds with this error code whenever the error has its origin on client side and no other HTTP status code in the 400 range is suitable.")])]),e._v(" "),t("li",[t("p",[t("strong",[e._v("401 Unauthorized")]),e._v(":\nThe client did not provide any authentication details for a resource requiring authentication or the provided authentication details are not correct.")])]),e._v(" "),t("li",[t("p",[t("strong",[e._v("403 Forbidden")]),e._v(":\nThe client did provided correct authentication details, but the privileges/permissions of the provided credentials do not allow to request the resource.")])]),e._v(" "),t("li",[t("p",[t("strong",[e._v("404 Not Found")]),e._v(":\nThe resource specified by the path does not exist, i.e. one of the resources belonging to the specified identifiers are not available at the back-end.\n"),t("em",[e._v("Note:")]),e._v(" Unsupported endpoints MUST use HTTP status code 501.")])]),e._v(" "),t("li",[t("p",[t("strong",[e._v("500 Internal Server Error")]),e._v(":\nThe error has its origin on server side and no other status code in the 500 range is suitable.")])]),e._v(" "),t("li",[t("p",[t("strong",[e._v("501 Not Implemented")]),e._v(":\nAn endpoint is specified in the openEO API, but is not supported.")])])]),e._v(" "),t("p",[e._v("If a HTTP status code in the 400 range is returned, the client SHOULD NOT repeat the request without modifications. For HTTP status code in the 500 range, the client MAY repeat the same request later.")]),e._v(" "),t("p",[e._v("All HTTP status codes defined in RFC 7231 in the 400 and 500 ranges can be used as openEO error code in addition to the most used status codes mentioned here. Responding with openEO error codes 400 and 500 SHOULD be avoided in favor of any more specific standardized or proprietary openEO error code.")]),e._v(" "),t("h2",{attrs:{id:"openeo-error-codes"}},[t("a",{staticClass:"header-anchor",attrs:{href:"#openeo-error-codes"}},[e._v("#")]),e._v(" openEO error codes")]),e._v(" "),t("p",[e._v("The following table of error codes is "),t("strong",[e._v("incomplete")]),e._v(". These error codes will evolve over time. If you are missing any common error, please contribute it by adding an "),t("a",{attrs:{href:"https://github.com/Open-EO/openeo-api/issues/new",target:"_blank",rel:"noopener noreferrer"}},[e._v("issue"),t("OutboundLink")],1),e._v(", creating a pull request or get in contact in our "),t("a",{attrs:{href:"https://openeo-chat.eodc.eu/channel/public",target:"_blank",rel:"noopener noreferrer"}},[e._v("chat room"),t("OutboundLink")],1),e._v(".")]),e._v(" "),t("ErrorCodes")],1)}),[],!1,null,null,null);t.default=o.exports}}]); \ No newline at end of file diff --git a/assets/js/63.c2f90289.js b/assets/js/63.ea862944.js similarity index 95% rename from assets/js/63.c2f90289.js rename to assets/js/63.ea862944.js index 0ecce7c8d..a34b5fcc5 100644 --- a/assets/js/63.c2f90289.js +++ b/assets/js/63.ea862944.js @@ -1 +1 @@ -(window.webpackJsonp=window.webpackJsonp||[]).push([[63],{502:function(e,t,r){"use strict";r.r(t);var n=r(4),o=Object(n.a)({},(function(){var e=this,t=e._self._c;return t("ContentSlotsDistributor",{attrs:{"slot-key":e.$parent.slotKey}},[t("h1",{attrs:{id:"user-defined-functions"}},[t("a",{staticClass:"header-anchor",attrs:{href:"#user-defined-functions"}},[e._v("#")]),e._v(" User-defined functions")]),e._v(" "),t("p",[e._v("The abbreviation "),t("strong",[e._v("UDF")]),e._v(" stands for "),t("strong",[e._v("user-defined function")]),e._v(". With this concept, users are able to upload custom code and have it executed e.g. for every pixel of a scene, allowing custom calculations on server-side data.")]),e._v(" "),t("p",[e._v("UDFs are currently developed and evaluated outside of the core API. More information regarding the current "),t("strong",[e._v("draft")]),e._v(" for UDFs can be found in a "),t("a",{attrs:{href:"https://github.com/Open-EO/openeo-udf",target:"_blank",rel:"noopener noreferrer"}},[e._v("separate repository"),t("OutboundLink")],1),e._v(". There is additional documentation available for the "),t("a",{attrs:{href:"https://open-eo.github.io/openeo-udf/",target:"_blank",rel:"noopener noreferrer"}},[e._v("UDF Framework"),t("OutboundLink")],1),e._v(" and the "),t("a",{attrs:{href:"https://open-eo.github.io/openeo-udf/api_docs/",target:"_blank",rel:"noopener noreferrer"}},[e._v("UDF API"),t("OutboundLink")],1),e._v(".")])])}),[],!1,null,null,null);t.default=o.exports}}]); \ No newline at end of file +(window.webpackJsonp=window.webpackJsonp||[]).push([[63],{501:function(e,t,r){"use strict";r.r(t);var n=r(4),o=Object(n.a)({},(function(){var e=this,t=e._self._c;return t("ContentSlotsDistributor",{attrs:{"slot-key":e.$parent.slotKey}},[t("h1",{attrs:{id:"user-defined-functions"}},[t("a",{staticClass:"header-anchor",attrs:{href:"#user-defined-functions"}},[e._v("#")]),e._v(" User-defined functions")]),e._v(" "),t("p",[e._v("The abbreviation "),t("strong",[e._v("UDF")]),e._v(" stands for "),t("strong",[e._v("user-defined function")]),e._v(". With this concept, users are able to upload custom code and have it executed e.g. for every pixel of a scene, allowing custom calculations on server-side data.")]),e._v(" "),t("p",[e._v("UDFs are currently developed and evaluated outside of the core API. More information regarding the current "),t("strong",[e._v("draft")]),e._v(" for UDFs can be found in a "),t("a",{attrs:{href:"https://github.com/Open-EO/openeo-udf",target:"_blank",rel:"noopener noreferrer"}},[e._v("separate repository"),t("OutboundLink")],1),e._v(". There is additional documentation available for the "),t("a",{attrs:{href:"https://open-eo.github.io/openeo-udf/",target:"_blank",rel:"noopener noreferrer"}},[e._v("UDF Framework"),t("OutboundLink")],1),e._v(" and the "),t("a",{attrs:{href:"https://open-eo.github.io/openeo-udf/api_docs/",target:"_blank",rel:"noopener noreferrer"}},[e._v("UDF API"),t("OutboundLink")],1),e._v(".")])])}),[],!1,null,null,null);t.default=o.exports}}]); \ No newline at end of file diff --git a/assets/js/64.e0fc30e5.js b/assets/js/64.796cc93f.js similarity index 98% rename from assets/js/64.e0fc30e5.js rename to assets/js/64.796cc93f.js index 83cf0ac1a..9693fc427 100644 --- a/assets/js/64.e0fc30e5.js +++ b/assets/js/64.796cc93f.js @@ -1 +1 @@ -(window.webpackJsonp=window.webpackJsonp||[]).push([[64],{501:function(e,t,r){"use strict";r.r(t);var a=r(4),n=Object(a.a)({},(function(){var e=this,t=e._self._c;return t("ContentSlotsDistributor",{attrs:{"slot-key":e.$parent.slotKey}},[t("h1",{attrs:{id:"getting-started-for-client-developers"}},[t("a",{staticClass:"header-anchor",attrs:{href:"#getting-started-for-client-developers"}},[e._v("#")]),e._v(" Getting started for client developers")]),e._v(" "),t("p",[e._v("For easy access to openEO back-ends it is essential to provide client libraries for users in their well-known programming languages or working environments. This can be either a "),t("em",[e._v("client library")]),e._v(" for a specific programming language that hides the technical details of the openEO API or an application with a user interface, e.g. a GIS software plugin or a web-based tool. All software written for openEO should follow the "),t("RouterLink",{attrs:{to:"/documentation/software-guidelines.html"}},[e._v("software development guidelines")]),e._v(".")],1),e._v(" "),t("h2",{attrs:{id:"client-library-developers"}},[t("a",{staticClass:"header-anchor",attrs:{href:"#client-library-developers"}},[e._v("#")]),e._v(" Client library developers")]),e._v(" "),t("p",[e._v("If your preferred programming language is not part of the "),t("RouterLink",{attrs:{to:"/software.html#clients"}},[e._v("available client libraries")]),e._v(" you may consider writing your own client library. Our client libraries are basically translating the openEO API into native concepts of the programming languages. Working with openEO should feel like being a "),t("a",{attrs:{href:"https://en.wikipedia.org/wiki/First-class_citizen",target:"_blank",rel:"noopener noreferrer"}},[e._v("first-class citizen"),t("OutboundLink")],1),e._v(" of the programming language.")],1),e._v(" "),t("p",[e._v("Get started by reading the "),t("RouterLink",{attrs:{to:"/documentation/0.4/developers/clients/library-guidelines.html"}},[e._v("guidelines to develop client libraries")]),e._v(", which have been written to ensure the client libraries provide a consistent feel and behavior across programming languages. You certainly need to understand the "),t("RouterLink",{attrs:{to:"/documentation/0.4/glossary.html"}},[e._v("glossary")]),e._v(" and the concepts behind "),t("RouterLink",{attrs:{to:"/documentation/0.4/developers/api/"}},[e._v("processes")]),e._v(" and "),t("RouterLink",{attrs:{to:"/documentation/0.4/developers/api/"}},[e._v("process graphs")]),e._v(". This helps you understand the "),t("RouterLink",{attrs:{to:"/documentation/0.4/developers/api/reference.html"}},[e._v("API specification")]),e._v(" and related documents.")],1),e._v(" "),t("p",[e._v("If you do not want to start from scratch, you could try to generate a client library stub from the "),t("a",{attrs:{href:"https://www.openapis.org/",target:"_blank",rel:"noopener noreferrer"}},[e._v("OpenAPI 3.0"),t("OutboundLink")],1),e._v("-based "),t("RouterLink",{attrs:{to:"/documentation/0.4/developers/api/reference.html"}},[e._v("API specification")]),e._v(" with the "),t("a",{attrs:{href:"https://github.com/OpenAPITools/openapi-generator",target:"_blank",rel:"noopener noreferrer"}},[e._v("OpenAPI Generator"),t("OutboundLink")],1),e._v(". Make sure the generated code complies to the client library guidelines mentioned above.")],1),e._v(" "),t("h2",{attrs:{id:"applications-and-software-plugins"}},[t("a",{staticClass:"header-anchor",attrs:{href:"#applications-and-software-plugins"}},[e._v("#")]),e._v(" Applications and Software plugins")]),e._v(" "),t("p",[e._v("Standalone applications and software plugins written in a certain programming language could use the "),t("RouterLink",{attrs:{to:"/software.html#clients"}},[e._v("existing client libraries")]),e._v(" to facilitate access to openEO back-ends. Web applications potentially could use the "),t("a",{attrs:{href:"https://github.com/Open-EO/openeo-js-client",target:"_blank",rel:"noopener noreferrer"}},[e._v("JavaScript client"),t("OutboundLink")],1),e._v(" to access openEO back-ends. Back-Ends may also provide standardized web interfaces such as OGC WMS or OGC WCS to access processed EO data.")],1)])}),[],!1,null,null,null);t.default=n.exports}}]); \ No newline at end of file +(window.webpackJsonp=window.webpackJsonp||[]).push([[64],{502:function(e,t,r){"use strict";r.r(t);var a=r(4),n=Object(a.a)({},(function(){var e=this,t=e._self._c;return t("ContentSlotsDistributor",{attrs:{"slot-key":e.$parent.slotKey}},[t("h1",{attrs:{id:"getting-started-for-client-developers"}},[t("a",{staticClass:"header-anchor",attrs:{href:"#getting-started-for-client-developers"}},[e._v("#")]),e._v(" Getting started for client developers")]),e._v(" "),t("p",[e._v("For easy access to openEO back-ends it is essential to provide client libraries for users in their well-known programming languages or working environments. This can be either a "),t("em",[e._v("client library")]),e._v(" for a specific programming language that hides the technical details of the openEO API or an application with a user interface, e.g. a GIS software plugin or a web-based tool. All software written for openEO should follow the "),t("RouterLink",{attrs:{to:"/documentation/software-guidelines.html"}},[e._v("software development guidelines")]),e._v(".")],1),e._v(" "),t("h2",{attrs:{id:"client-library-developers"}},[t("a",{staticClass:"header-anchor",attrs:{href:"#client-library-developers"}},[e._v("#")]),e._v(" Client library developers")]),e._v(" "),t("p",[e._v("If your preferred programming language is not part of the "),t("RouterLink",{attrs:{to:"/software.html#clients"}},[e._v("available client libraries")]),e._v(" you may consider writing your own client library. Our client libraries are basically translating the openEO API into native concepts of the programming languages. Working with openEO should feel like being a "),t("a",{attrs:{href:"https://en.wikipedia.org/wiki/First-class_citizen",target:"_blank",rel:"noopener noreferrer"}},[e._v("first-class citizen"),t("OutboundLink")],1),e._v(" of the programming language.")],1),e._v(" "),t("p",[e._v("Get started by reading the "),t("RouterLink",{attrs:{to:"/documentation/0.4/developers/clients/library-guidelines.html"}},[e._v("guidelines to develop client libraries")]),e._v(", which have been written to ensure the client libraries provide a consistent feel and behavior across programming languages. You certainly need to understand the "),t("RouterLink",{attrs:{to:"/documentation/0.4/glossary.html"}},[e._v("glossary")]),e._v(" and the concepts behind "),t("RouterLink",{attrs:{to:"/documentation/0.4/developers/api/"}},[e._v("processes")]),e._v(" and "),t("RouterLink",{attrs:{to:"/documentation/0.4/developers/api/"}},[e._v("process graphs")]),e._v(". This helps you understand the "),t("RouterLink",{attrs:{to:"/documentation/0.4/developers/api/reference.html"}},[e._v("API specification")]),e._v(" and related documents.")],1),e._v(" "),t("p",[e._v("If you do not want to start from scratch, you could try to generate a client library stub from the "),t("a",{attrs:{href:"https://www.openapis.org/",target:"_blank",rel:"noopener noreferrer"}},[e._v("OpenAPI 3.0"),t("OutboundLink")],1),e._v("-based "),t("RouterLink",{attrs:{to:"/documentation/0.4/developers/api/reference.html"}},[e._v("API specification")]),e._v(" with the "),t("a",{attrs:{href:"https://github.com/OpenAPITools/openapi-generator",target:"_blank",rel:"noopener noreferrer"}},[e._v("OpenAPI Generator"),t("OutboundLink")],1),e._v(". Make sure the generated code complies to the client library guidelines mentioned above.")],1),e._v(" "),t("h2",{attrs:{id:"applications-and-software-plugins"}},[t("a",{staticClass:"header-anchor",attrs:{href:"#applications-and-software-plugins"}},[e._v("#")]),e._v(" Applications and Software plugins")]),e._v(" "),t("p",[e._v("Standalone applications and software plugins written in a certain programming language could use the "),t("RouterLink",{attrs:{to:"/software.html#clients"}},[e._v("existing client libraries")]),e._v(" to facilitate access to openEO back-ends. Web applications potentially could use the "),t("a",{attrs:{href:"https://github.com/Open-EO/openeo-js-client",target:"_blank",rel:"noopener noreferrer"}},[e._v("JavaScript client"),t("OutboundLink")],1),e._v(" to access openEO back-ends. Back-Ends may also provide standardized web interfaces such as OGC WMS or OGC WCS to access processed EO data.")],1)])}),[],!1,null,null,null);t.default=n.exports}}]); \ No newline at end of file diff --git a/assets/js/69.16440ebe.js b/assets/js/69.e137d461.js similarity index 79% rename from assets/js/69.16440ebe.js rename to assets/js/69.e137d461.js index 22dca0513..596f3b18a 100644 --- a/assets/js/69.16440ebe.js +++ b/assets/js/69.e137d461.js @@ -1 +1 @@ -(window.webpackJsonp=window.webpackJsonp||[]).push([[69],{510:function(t,s,e){"use strict";e.r(s);var n=e(4),o=Object(n.a)({},(function(){var t=this._self._c;return t("ContentSlotsDistributor",{attrs:{"slot-key":this.$parent.slotKey}},[t("ProcessesSpec")],1)}),[],!1,null,null,null);s.default=o.exports}}]); \ No newline at end of file +(window.webpackJsonp=window.webpackJsonp||[]).push([[69],{507:function(t,s,e){"use strict";e.r(s);var n=e(4),o=Object(n.a)({},(function(){var t=this._self._c;return t("ContentSlotsDistributor",{attrs:{"slot-key":this.$parent.slotKey}},[t("ProcessesSpec")],1)}),[],!1,null,null,null);s.default=o.exports}}]); \ No newline at end of file diff --git a/assets/js/70.9e4eb65b.js b/assets/js/70.9a804daa.js similarity index 95% rename from assets/js/70.9e4eb65b.js rename to assets/js/70.9a804daa.js index 497855f4a..ccb0d5b5e 100644 --- a/assets/js/70.9e4eb65b.js +++ b/assets/js/70.9a804daa.js @@ -1 +1 @@ -(window.webpackJsonp=window.webpackJsonp||[]).push([[70],{509:function(e,t,r){"use strict";r.r(t);var n=r(4),o=Object(n.a)({},(function(){var e=this,t=e._self._c;return t("ContentSlotsDistributor",{attrs:{"slot-key":e.$parent.slotKey}},[t("h1",{attrs:{id:"user-defined-functions"}},[t("a",{staticClass:"header-anchor",attrs:{href:"#user-defined-functions"}},[e._v("#")]),e._v(" User-defined functions")]),e._v(" "),t("p",[e._v("The abbreviation "),t("strong",[e._v("UDF")]),e._v(" stands for "),t("strong",[e._v("user-defined function")]),e._v(". With this concept, users are able to upload custom code and have it executed e.g. for every pixel of a scene, allowing custom calculations on server-side data.")]),e._v(" "),t("p",[e._v("UDFs are currently developed and evaluated outside of the core API. More information regarding the current "),t("strong",[e._v("draft")]),e._v(" for UDFs can be found in a "),t("a",{attrs:{href:"https://github.com/Open-EO/openeo-udf",target:"_blank",rel:"noopener noreferrer"}},[e._v("separate repository"),t("OutboundLink")],1),e._v(". There is additional documentation available for the "),t("a",{attrs:{href:"https://open-eo.github.io/openeo-udf/",target:"_blank",rel:"noopener noreferrer"}},[e._v("UDF Framework"),t("OutboundLink")],1),e._v(" and the "),t("a",{attrs:{href:"https://open-eo.github.io/openeo-udf/api_docs/",target:"_blank",rel:"noopener noreferrer"}},[e._v("UDF API"),t("OutboundLink")],1),e._v(".")])])}),[],!1,null,null,null);t.default=o.exports}}]); \ No newline at end of file +(window.webpackJsonp=window.webpackJsonp||[]).push([[70],{510:function(e,t,r){"use strict";r.r(t);var n=r(4),o=Object(n.a)({},(function(){var e=this,t=e._self._c;return t("ContentSlotsDistributor",{attrs:{"slot-key":e.$parent.slotKey}},[t("h1",{attrs:{id:"user-defined-functions"}},[t("a",{staticClass:"header-anchor",attrs:{href:"#user-defined-functions"}},[e._v("#")]),e._v(" User-defined functions")]),e._v(" "),t("p",[e._v("The abbreviation "),t("strong",[e._v("UDF")]),e._v(" stands for "),t("strong",[e._v("user-defined function")]),e._v(". With this concept, users are able to upload custom code and have it executed e.g. for every pixel of a scene, allowing custom calculations on server-side data.")]),e._v(" "),t("p",[e._v("UDFs are currently developed and evaluated outside of the core API. More information regarding the current "),t("strong",[e._v("draft")]),e._v(" for UDFs can be found in a "),t("a",{attrs:{href:"https://github.com/Open-EO/openeo-udf",target:"_blank",rel:"noopener noreferrer"}},[e._v("separate repository"),t("OutboundLink")],1),e._v(". There is additional documentation available for the "),t("a",{attrs:{href:"https://open-eo.github.io/openeo-udf/",target:"_blank",rel:"noopener noreferrer"}},[e._v("UDF Framework"),t("OutboundLink")],1),e._v(" and the "),t("a",{attrs:{href:"https://open-eo.github.io/openeo-udf/api_docs/",target:"_blank",rel:"noopener noreferrer"}},[e._v("UDF API"),t("OutboundLink")],1),e._v(".")])])}),[],!1,null,null,null);t.default=o.exports}}]); \ No newline at end of file diff --git a/assets/js/71.dc4df3c4.js b/assets/js/71.add22aa1.js similarity index 98% rename from assets/js/71.dc4df3c4.js rename to assets/js/71.add22aa1.js index 5a775b6f0..fa745d94f 100644 --- a/assets/js/71.dc4df3c4.js +++ b/assets/js/71.add22aa1.js @@ -1 +1 @@ -(window.webpackJsonp=window.webpackJsonp||[]).push([[71],{508:function(t,e,o){"use strict";o.r(e);var n=o(4),r=Object(n.a)({},(function(){var t=this,e=t._self._c;return e("ContentSlotsDistributor",{attrs:{"slot-key":t.$parent.slotKey}},[e("h1",{attrs:{id:"introduction"}},[e("a",{staticClass:"header-anchor",attrs:{href:"#introduction"}},[t._v("#")]),t._v(" Introduction")]),t._v(" "),e("p",[t._v("First of all, a good idea is to get familiar with the terminology in openEO by reading the "),e("RouterLink",{attrs:{to:"/documentation/1.0/glossary.html"}},[t._v("glossary")]),t._v(".\nThere's also an in-depth "),e("RouterLink",{attrs:{to:"/documentation/1.0/datacubes.html"}},[t._v("introduction to datacubes")]),t._v(" and processing them with openEO.")],1),t._v(" "),e("p",[t._v("Currently, there are three official client libraries, a web-based interface for openEO and a QGIS plugin.")]),t._v(" "),e("p",[t._v("If you are "),e("strong",[t._v("unfamiliar")]),t._v(" with programming, you could start using the "),e("a",{attrs:{href:"https://editor.openeo.org",target:"_blank",rel:"noopener noreferrer"}},[t._v("web-based editor for openEO"),e("OutboundLink")],1),t._v(". It supports visual modelling of your algorithms and a simplified JavaScript based access to the openEO workflows and providers. openEO can also be used in QGIS through a "),e("RouterLink",{attrs:{to:"/documentation/1.0/qgis/"}},[t._v("QGIS plugin")]),t._v(".")],1),t._v(" "),e("p",[t._v("If you are "),e("strong",[t._v("familiar")]),t._v(" with programming, you could choose a client library for three programming languages:")]),t._v(" "),e("ul",[e("li",[e("RouterLink",{attrs:{to:"/documentation/1.0/javascript/"}},[t._v("JavaScript")]),t._v(" (client-side and server-side)")],1),t._v(" "),e("li",[e("RouterLink",{attrs:{to:"/documentation/1.0/python/"}},[t._v("Python")])],1),t._v(" "),e("li",[e("RouterLink",{attrs:{to:"/documentation/1.0/r/"}},[t._v("R")])],1)]),t._v(" "),e("p",[t._v("Follow the links above to find usage instructions for each of the client libraries.")]),t._v(" "),e("p",[t._v("For details about available processes, see the "),e("strong",[e("RouterLink",{attrs:{to:"/documentation/1.0/processes.html"}},[t._v("list of openEO processes")])],1),t._v(". The "),e("strong",[e("RouterLink",{attrs:{to:"/documentation/1.0/cookbook/"}},[t._v("openEO Cookbook")])],1),t._v(" describes common use-cases with code examples in all three languages.")]),t._v(" "),e("p",[t._v("The more advanced topic to run your own code on back-ends, is explained in the introduction to "),e("RouterLink",{attrs:{to:"/documentation/1.0/udfs.html"}},[t._v("openEO UDFs (user-defined functions)")]),t._v(".")],1),t._v(" "),e("div",{staticClass:"custom-block tip"},[e("p",{staticClass:"custom-block-title"},[t._v("Note")]),t._v(" "),e("p",[t._v("This is the documentation for the "),e("strong",[t._v("openEO API version 1.0")]),t._v(". If you are looking for other versions of openEO, please use the version switch at the top right of this page.")])]),t._v(" "),e("h2",{attrs:{id:"contribute"}},[e("a",{staticClass:"header-anchor",attrs:{href:"#contribute"}},[t._v("#")]),t._v(" Contribute")]),t._v(" "),e("p",[t._v("Didn't find your programming language? You can also access the "),e("RouterLink",{attrs:{to:"/documentation/1.0/developers/api/reference.html"}},[t._v("openEO API")]),t._v(" implementations directly or start "),e("RouterLink",{attrs:{to:"/documentation/1.0/developers/clients/getting-started.html"}},[t._v("implementing your own client library")]),t._v(".")],1),t._v(" "),e("p",[t._v("If you are missing any functionality in the API feel free to "),e("a",{attrs:{href:"https://github.com/Open-EO/openeo-api/issues",target:"_blank",rel:"noopener noreferrer"}},[t._v("open an issue"),e("OutboundLink")],1),t._v(" or actively start proposing API changes as Pull Requests.")]),t._v(" "),e("p",[t._v("Feel free to contact us for further assistance.")])])}),[],!1,null,null,null);e.default=r.exports}}]); \ No newline at end of file +(window.webpackJsonp=window.webpackJsonp||[]).push([[71],{509:function(t,e,o){"use strict";o.r(e);var n=o(4),r=Object(n.a)({},(function(){var t=this,e=t._self._c;return e("ContentSlotsDistributor",{attrs:{"slot-key":t.$parent.slotKey}},[e("h1",{attrs:{id:"introduction"}},[e("a",{staticClass:"header-anchor",attrs:{href:"#introduction"}},[t._v("#")]),t._v(" Introduction")]),t._v(" "),e("p",[t._v("First of all, a good idea is to get familiar with the terminology in openEO by reading the "),e("RouterLink",{attrs:{to:"/documentation/1.0/glossary.html"}},[t._v("glossary")]),t._v(".\nThere's also an in-depth "),e("RouterLink",{attrs:{to:"/documentation/1.0/datacubes.html"}},[t._v("introduction to datacubes")]),t._v(" and processing them with openEO.")],1),t._v(" "),e("p",[t._v("Currently, there are three official client libraries, a web-based interface for openEO and a QGIS plugin.")]),t._v(" "),e("p",[t._v("If you are "),e("strong",[t._v("unfamiliar")]),t._v(" with programming, you could start using the "),e("a",{attrs:{href:"https://editor.openeo.org",target:"_blank",rel:"noopener noreferrer"}},[t._v("web-based editor for openEO"),e("OutboundLink")],1),t._v(". It supports visual modelling of your algorithms and a simplified JavaScript based access to the openEO workflows and providers. openEO can also be used in QGIS through a "),e("RouterLink",{attrs:{to:"/documentation/1.0/qgis/"}},[t._v("QGIS plugin")]),t._v(".")],1),t._v(" "),e("p",[t._v("If you are "),e("strong",[t._v("familiar")]),t._v(" with programming, you could choose a client library for three programming languages:")]),t._v(" "),e("ul",[e("li",[e("RouterLink",{attrs:{to:"/documentation/1.0/javascript/"}},[t._v("JavaScript")]),t._v(" (client-side and server-side)")],1),t._v(" "),e("li",[e("RouterLink",{attrs:{to:"/documentation/1.0/python/"}},[t._v("Python")])],1),t._v(" "),e("li",[e("RouterLink",{attrs:{to:"/documentation/1.0/r/"}},[t._v("R")])],1)]),t._v(" "),e("p",[t._v("Follow the links above to find usage instructions for each of the client libraries.")]),t._v(" "),e("p",[t._v("For details about available processes, see the "),e("strong",[e("RouterLink",{attrs:{to:"/documentation/1.0/processes.html"}},[t._v("list of openEO processes")])],1),t._v(". The "),e("strong",[e("RouterLink",{attrs:{to:"/documentation/1.0/cookbook/"}},[t._v("openEO Cookbook")])],1),t._v(" describes common use-cases with code examples in all three languages.")]),t._v(" "),e("p",[t._v("The more advanced topic to run your own code on back-ends, is explained in the introduction to "),e("RouterLink",{attrs:{to:"/documentation/1.0/udfs.html"}},[t._v("openEO UDFs (user-defined functions)")]),t._v(".")],1),t._v(" "),e("div",{staticClass:"custom-block tip"},[e("p",{staticClass:"custom-block-title"},[t._v("Note")]),t._v(" "),e("p",[t._v("This is the documentation for the "),e("strong",[t._v("openEO API version 1.0")]),t._v(". If you are looking for other versions of openEO, please use the version switch at the top right of this page.")])]),t._v(" "),e("h2",{attrs:{id:"contribute"}},[e("a",{staticClass:"header-anchor",attrs:{href:"#contribute"}},[t._v("#")]),t._v(" Contribute")]),t._v(" "),e("p",[t._v("Didn't find your programming language? You can also access the "),e("RouterLink",{attrs:{to:"/documentation/1.0/developers/api/reference.html"}},[t._v("openEO API")]),t._v(" implementations directly or start "),e("RouterLink",{attrs:{to:"/documentation/1.0/developers/clients/getting-started.html"}},[t._v("implementing your own client library")]),t._v(".")],1),t._v(" "),e("p",[t._v("If you are missing any functionality in the API feel free to "),e("a",{attrs:{href:"https://github.com/Open-EO/openeo-api/issues",target:"_blank",rel:"noopener noreferrer"}},[t._v("open an issue"),e("OutboundLink")],1),t._v(" or actively start proposing API changes as Pull Requests.")]),t._v(" "),e("p",[t._v("Feel free to contact us for further assistance.")])])}),[],!1,null,null,null);e.default=r.exports}}]); \ No newline at end of file diff --git a/assets/js/73.c5f1150c.js b/assets/js/73.7ec9b686.js similarity index 90% rename from assets/js/73.c5f1150c.js rename to assets/js/73.7ec9b686.js index 10d5078c0..67dfd7ec3 100644 --- a/assets/js/73.c5f1150c.js +++ b/assets/js/73.7ec9b686.js @@ -1 +1 @@ -(window.webpackJsonp=window.webpackJsonp||[]).push([[73],{513:function(t,e,n){"use strict";n.r(e);var a=n(4),o=Object(a.a)({},(function(){var t=this,e=t._self._c;return e("ContentSlotsDistributor",{attrs:{"slot-key":t.$parent.slotKey}},[e("h1",{attrs:{id:"datacube-documentation"}},[e("a",{staticClass:"header-anchor",attrs:{href:"#datacube-documentation"}},[t._v("#")]),t._v(" Datacube Documentation")]),t._v(" "),e("p",[t._v("This documentation on datacubes is part of the openEO documentation.")]),t._v(" "),e("p",[t._v("The folder "),e("code",[t._v(".scripts")]),t._v(" contains script*s that output the figures contained in this directory.")])])}),[],!1,null,null,null);e.default=o.exports}}]); \ No newline at end of file +(window.webpackJsonp=window.webpackJsonp||[]).push([[73],{514:function(t,e,n){"use strict";n.r(e);var a=n(4),o=Object(a.a)({},(function(){var t=this,e=t._self._c;return e("ContentSlotsDistributor",{attrs:{"slot-key":t.$parent.slotKey}},[e("h1",{attrs:{id:"datacube-documentation"}},[e("a",{staticClass:"header-anchor",attrs:{href:"#datacube-documentation"}},[t._v("#")]),t._v(" Datacube Documentation")]),t._v(" "),e("p",[t._v("This documentation on datacubes is part of the openEO documentation.")]),t._v(" "),e("p",[t._v("The folder "),e("code",[t._v(".scripts")]),t._v(" contains script*s that output the figures contained in this directory.")])])}),[],!1,null,null,null);e.default=o.exports}}]); \ No newline at end of file diff --git a/assets/js/74.b946be4e.js b/assets/js/74.bf7013b2.js similarity index 97% rename from assets/js/74.b946be4e.js rename to assets/js/74.bf7013b2.js index 07617498a..e8c001dc1 100644 --- a/assets/js/74.b946be4e.js +++ b/assets/js/74.bf7013b2.js @@ -1 +1 @@ -(window.webpackJsonp=window.webpackJsonp||[]).push([[74],{519:function(e,t,n){"use strict";n.r(t);var o=n(4),a=Object(o.a)({},(function(){var e=this,t=e._self._c;return t("ContentSlotsDistributor",{attrs:{"slot-key":e.$parent.slotKey}},[t("h1",{attrs:{id:"introduction"}},[t("a",{staticClass:"header-anchor",attrs:{href:"#introduction"}},[e._v("#")]),e._v(" Introduction")]),e._v(" "),t("p",[e._v("The openEO API defines a "),t("RouterLink",{attrs:{to:"/documentation/1.0/developers/api/reference.html"}},[e._v("HTTP API")]),e._v(" that lets cloud back-ends with large Earth observation datasets communicate with front end analysis applications in an interoperable way.")],1),e._v(" "),t("p",[e._v("As an overview, the openEO API specifies how to")]),e._v(" "),t("ul",[t("li",[e._v("discover which Earth observation data and processes are available at cloud back-ends,")]),e._v(" "),t("li",[e._v("execute (chained) processes on back-ends,")]),e._v(" "),t("li",[e._v("run "),t("RouterLink",{attrs:{to:"/documentation/1.0/udfs.html"}},[e._v("user-defined functions")]),e._v(" (UDFs) on back-ends where UDFs can be exposed to the data in different ways,")],1),e._v(" "),t("li",[e._v("download (intermediate) results, and")]),e._v(" "),t("li",[e._v("manage user content including billing.")])]),e._v(" "),t("p",[e._v("The API is defined as an "),t("a",{attrs:{href:"https://github.com/OAI/OpenAPI-Specification/blob/master/versions/3.0.1.md",target:"_blank",rel:"noopener noreferrer"}},[e._v("OpenAPI 3.0"),t("OutboundLink")],1),e._v(" YAML file.")]),e._v(" "),t("p",[e._v("The API and processes are grouped into "),t("RouterLink",{attrs:{to:"/documentation/1.0/developers/profiles/"}},[e._v("compliance profiles")]),e._v(".")],1),e._v(" "),t("h2",{attrs:{id:"additional-information"}},[t("a",{staticClass:"header-anchor",attrs:{href:"#additional-information"}},[e._v("#")]),e._v(" Additional information")]),e._v(" "),t("ul",[t("li",[t("RouterLink",{attrs:{to:"/documentation/code-of-conduct.html"}},[e._v("Code of Conduct")])],1),e._v(" "),t("li",[t("RouterLink",{attrs:{to:"/documentation/software-guidelines.html"}},[e._v("Software Development Guidelines")])],1)])])}),[],!1,null,null,null);t.default=a.exports}}]); \ No newline at end of file +(window.webpackJsonp=window.webpackJsonp||[]).push([[74],{515:function(e,t,n){"use strict";n.r(t);var o=n(4),a=Object(o.a)({},(function(){var e=this,t=e._self._c;return t("ContentSlotsDistributor",{attrs:{"slot-key":e.$parent.slotKey}},[t("h1",{attrs:{id:"introduction"}},[t("a",{staticClass:"header-anchor",attrs:{href:"#introduction"}},[e._v("#")]),e._v(" Introduction")]),e._v(" "),t("p",[e._v("The openEO API defines a "),t("RouterLink",{attrs:{to:"/documentation/1.0/developers/api/reference.html"}},[e._v("HTTP API")]),e._v(" that lets cloud back-ends with large Earth observation datasets communicate with front end analysis applications in an interoperable way.")],1),e._v(" "),t("p",[e._v("As an overview, the openEO API specifies how to")]),e._v(" "),t("ul",[t("li",[e._v("discover which Earth observation data and processes are available at cloud back-ends,")]),e._v(" "),t("li",[e._v("execute (chained) processes on back-ends,")]),e._v(" "),t("li",[e._v("run "),t("RouterLink",{attrs:{to:"/documentation/1.0/udfs.html"}},[e._v("user-defined functions")]),e._v(" (UDFs) on back-ends where UDFs can be exposed to the data in different ways,")],1),e._v(" "),t("li",[e._v("download (intermediate) results, and")]),e._v(" "),t("li",[e._v("manage user content including billing.")])]),e._v(" "),t("p",[e._v("The API is defined as an "),t("a",{attrs:{href:"https://github.com/OAI/OpenAPI-Specification/blob/master/versions/3.0.1.md",target:"_blank",rel:"noopener noreferrer"}},[e._v("OpenAPI 3.0"),t("OutboundLink")],1),e._v(" YAML file.")]),e._v(" "),t("p",[e._v("The API and processes are grouped into "),t("RouterLink",{attrs:{to:"/documentation/1.0/developers/profiles/"}},[e._v("compliance profiles")]),e._v(".")],1),e._v(" "),t("h2",{attrs:{id:"additional-information"}},[t("a",{staticClass:"header-anchor",attrs:{href:"#additional-information"}},[e._v("#")]),e._v(" Additional information")]),e._v(" "),t("ul",[t("li",[t("RouterLink",{attrs:{to:"/documentation/code-of-conduct.html"}},[e._v("Code of Conduct")])],1),e._v(" "),t("li",[t("RouterLink",{attrs:{to:"/documentation/software-guidelines.html"}},[e._v("Software Development Guidelines")])],1)])])}),[],!1,null,null,null);t.default=a.exports}}]); \ No newline at end of file diff --git a/assets/js/75.cf1dcd2b.js b/assets/js/75.b42f4081.js similarity index 77% rename from assets/js/75.cf1dcd2b.js rename to assets/js/75.b42f4081.js index f3e6cdf42..0fad00e9a 100644 --- a/assets/js/75.cf1dcd2b.js +++ b/assets/js/75.b42f4081.js @@ -1 +1 @@ -(window.webpackJsonp=window.webpackJsonp||[]).push([[75],{514:function(t,n,s){"use strict";s.r(n);var e=s(4),o=Object(e.a)({},(function(){return(0,this._self._c)("ContentSlotsDistributor",{attrs:{"slot-key":this.$parent.slotKey}})}),[],!1,null,null,null);n.default=o.exports}}]); \ No newline at end of file +(window.webpackJsonp=window.webpackJsonp||[]).push([[75],{516:function(t,n,s){"use strict";s.r(n);var e=s(4),o=Object(e.a)({},(function(){return(0,this._self._c)("ContentSlotsDistributor",{attrs:{"slot-key":this.$parent.slotKey}})}),[],!1,null,null,null);n.default=o.exports}}]); \ No newline at end of file diff --git a/assets/js/76.1bb4f4bb.js b/assets/js/76.19c5ae96.js similarity index 95% rename from assets/js/76.1bb4f4bb.js rename to assets/js/76.19c5ae96.js index a0c2a9fd7..bf406afb1 100644 --- a/assets/js/76.1bb4f4bb.js +++ b/assets/js/76.19c5ae96.js @@ -1 +1 @@ -(window.webpackJsonp=window.webpackJsonp||[]).push([[76],{516:function(e,r,o){"use strict";o.r(r);var t=o(4),n=Object(t.a)({},(function(){var e=this,r=e._self._c;return r("ContentSlotsDistributor",{attrs:{"slot-key":e.$parent.slotKey}},[r("h1",{attrs:{id:"openeo-error-codes"}},[r("a",{staticClass:"header-anchor",attrs:{href:"#openeo-error-codes"}},[e._v("#")]),e._v(" openEO error codes")]),e._v(" "),r("p",[e._v("The general error handling in the openEO API is documented in the "),r("RouterLink",{attrs:{to:"/documentation/1.0/developers/api/reference.html#section/API-Principles/Error-Handling"}},[e._v("API documentation")]),e._v(".")],1),e._v(" "),r("p",[e._v("The following table of error codes is "),r("strong",[e._v("incomplete")]),e._v(". These error codes will evolve over time. If you are missing any common error, please contribute it by adding an "),r("a",{attrs:{href:"https://github.com/Open-EO/openeo-api/issues/new",target:"_blank",rel:"noopener noreferrer"}},[e._v("issue"),r("OutboundLink")],1),e._v(", creating a "),r("a",{attrs:{href:"https://github.com/Open-EO/openeo-api/pulls",target:"_blank",rel:"noopener noreferrer"}},[e._v("pull request"),r("OutboundLink")],1),e._v(" or get in "),r("RouterLink",{attrs:{to:"/contact.html"}},[e._v("contact")]),e._v(".")],1),e._v(" "),r("ErrorCodes")],1)}),[],!1,null,null,null);r.default=n.exports}}]); \ No newline at end of file +(window.webpackJsonp=window.webpackJsonp||[]).push([[76],{519:function(e,r,o){"use strict";o.r(r);var t=o(4),n=Object(t.a)({},(function(){var e=this,r=e._self._c;return r("ContentSlotsDistributor",{attrs:{"slot-key":e.$parent.slotKey}},[r("h1",{attrs:{id:"openeo-error-codes"}},[r("a",{staticClass:"header-anchor",attrs:{href:"#openeo-error-codes"}},[e._v("#")]),e._v(" openEO error codes")]),e._v(" "),r("p",[e._v("The general error handling in the openEO API is documented in the "),r("RouterLink",{attrs:{to:"/documentation/1.0/developers/api/reference.html#section/API-Principles/Error-Handling"}},[e._v("API documentation")]),e._v(".")],1),e._v(" "),r("p",[e._v("The following table of error codes is "),r("strong",[e._v("incomplete")]),e._v(". These error codes will evolve over time. If you are missing any common error, please contribute it by adding an "),r("a",{attrs:{href:"https://github.com/Open-EO/openeo-api/issues/new",target:"_blank",rel:"noopener noreferrer"}},[e._v("issue"),r("OutboundLink")],1),e._v(", creating a "),r("a",{attrs:{href:"https://github.com/Open-EO/openeo-api/pulls",target:"_blank",rel:"noopener noreferrer"}},[e._v("pull request"),r("OutboundLink")],1),e._v(" or get in "),r("RouterLink",{attrs:{to:"/contact.html"}},[e._v("contact")]),e._v(".")],1),e._v(" "),r("ErrorCodes")],1)}),[],!1,null,null,null);r.default=n.exports}}]); \ No newline at end of file diff --git a/assets/js/77.e758c278.js b/assets/js/77.129b221b.js similarity index 78% rename from assets/js/77.e758c278.js rename to assets/js/77.129b221b.js index 4da5b5609..03de76dcc 100644 --- a/assets/js/77.e758c278.js +++ b/assets/js/77.129b221b.js @@ -1 +1 @@ -(window.webpackJsonp=window.webpackJsonp||[]).push([[77],{517:function(t,n,s){"use strict";s.r(n);var e=s(4),o=Object(e.a)({},(function(){var t=this._self._c;return t("ContentSlotsDistributor",{attrs:{"slot-key":this.$parent.slotKey}},[t("ApiSpec")],1)}),[],!1,null,null,null);n.default=o.exports}}]); \ No newline at end of file +(window.webpackJsonp=window.webpackJsonp||[]).push([[77],{518:function(t,n,s){"use strict";s.r(n);var e=s(4),o=Object(e.a)({},(function(){var t=this._self._c;return t("ContentSlotsDistributor",{attrs:{"slot-key":this.$parent.slotKey}},[t("ApiSpec")],1)}),[],!1,null,null,null);n.default=o.exports}}]); \ No newline at end of file diff --git a/assets/js/78.3394d6c2.js b/assets/js/78.ac9a35ad.js similarity index 98% rename from assets/js/78.3394d6c2.js rename to assets/js/78.ac9a35ad.js index d6a5bfb15..5c08fc8f8 100644 --- a/assets/js/78.3394d6c2.js +++ b/assets/js/78.ac9a35ad.js @@ -1 +1 @@ -(window.webpackJsonp=window.webpackJsonp||[]).push([[78],{521:function(e,t,o){"use strict";o.r(t);var r=o(4),n=Object(r.a)({},(function(){var e=this,t=e._self._c;return t("ContentSlotsDistributor",{attrs:{"slot-key":e.$parent.slotKey}},[t("h1",{attrs:{id:"getting-started-for-service-back-end-providers"}},[t("a",{staticClass:"header-anchor",attrs:{href:"#getting-started-for-service-back-end-providers"}},[e._v("#")]),e._v(" Getting started for service (back-end) providers")]),e._v(" "),t("p",[e._v("As a back-end provider who wants to provide its datasets, processes and infrastructure to a broader audience through a standardized interface you may want to implement a driver for openEO.")]),e._v(" "),t("p",[e._v("First of all, you should go through the list of "),t("a",{attrs:{href:"https://github.com/Open-EO",target:"_blank",rel:"noopener noreferrer"}},[e._v("openEO repositories"),t("OutboundLink")],1),e._v(' and check whether there is already a back-end driver that suits your needs. In this case you don\'t need to develop your own driver, but "only" need to ingest your data, adopt your required processes and set up the infrastructure. Please follow the documentation for the individual driver you want to use.')]),e._v(" "),t("p",[e._v("If your preferred technology has no back-end driver yet, you may consider writing your own driver. All software written for openEO should follow the "),t("RouterLink",{attrs:{to:"/documentation/software-guidelines.html"}},[e._v("software development guidelines")]),e._v(".")],1),e._v(" "),t("p",[e._v("You certainly need to understand the "),t("RouterLink",{attrs:{to:"/documentation/1.0/glossary.html"}},[e._v("glossary")]),e._v(", the "),t("RouterLink",{attrs:{to:"/documentation/1.0/developers/arch.html"}},[e._v("architecture")]),e._v(" of openEO and the concepts behind "),t("RouterLink",{attrs:{to:"/documentation/1.0/developers/api/reference.html#section/Processes"}},[e._v("processes")]),e._v(" and "),t("RouterLink",{attrs:{to:"/documentation/1.0/developers/api/reference.html#section/Processes/Process-Graphs"}},[e._v("process graphs")]),e._v(". This helps you read and understand the "),t("RouterLink",{attrs:{to:"/documentation/1.0/developers/api/reference.html"}},[e._v("API specification")]),e._v(". Technical API related documents like "),t("RouterLink",{attrs:{to:"/documentation/1.0/developers/api/reference.html#section/Cross-Origin-Resource-Sharing-(CORS)"}},[e._v("CORS")]),e._v(" and "),t("RouterLink",{attrs:{to:"/documentation/1.0/developers/api/reference.html#section/API-Principles/Error-Handling"}},[e._v("error handing")]),e._v(" should be read, too.")],1),e._v(" "),t("p",[e._v("If you do not want to start from scratch, you could try to generate a server stub from the "),t("a",{attrs:{href:"https://www.openapis.org/",target:"_blank",rel:"noopener noreferrer"}},[e._v("OpenAPI 3.0"),t("OutboundLink")],1),e._v("-based "),t("RouterLink",{attrs:{to:"/documentation/1.0/developers/api/reference.html"}},[e._v("API specification")]),e._v(" with the "),t("a",{attrs:{href:"https://github.com/OpenAPITools/openapi-generator",target:"_blank",rel:"noopener noreferrer"}},[e._v("OpenAPI Generator"),t("OutboundLink")],1),e._v(".\nIf you are using Python to implement your driver you may reuse some common modules of the existing driver implementations:")],1),e._v(" "),t("ul",[t("li",[t("a",{attrs:{href:"https://github.com/Open-EO/openeo-python-driver",target:"_blank",rel:"noopener noreferrer"}},[e._v("Python Driver Commons"),t("OutboundLink")],1)])]),e._v(" "),t("p",[e._v("You can implement a back-end in iterations. It is recommended to start by implementing the "),t("RouterLink",{attrs:{to:"/documentation/1.0/developers/api/reference.html#tag/Capabilities"}},[e._v("Capabilities")]),e._v(" microservice. "),t("RouterLink",{attrs:{to:"/documentation/1.0/developers/api/reference.html#tag/EO-Data-Discovery"}},[e._v("EO Data Discovery")]),e._v(", "),t("RouterLink",{attrs:{to:"/documentation/1.0/developers/api/reference.html#tag/Process-Discovery"}},[e._v("Process Discovery")]),e._v(" are important for the client libraries to be available, too. Afterwards you should implement "),t("RouterLink",{attrs:{to:"/documentation/1.0/developers/api/reference.html#tag/Batch-Jobs"}},[e._v("Batch Job Management")]),e._v(" or "),t("RouterLink",{attrs:{to:"/documentation/1.0/developers/api/reference.html#/paths/~1result/post"}},[e._v("synchronous data processing")]),e._v(". All other microservices can be added later and are not strictly required to run openEO services. Keep in mind that you don't need to implement all endpoints in the first iteration and that you can specify in the Capabilities, which endpoints you are supporting.")],1),e._v(" "),t("p",[e._v("For example, you could start by implementing the following endpoints in the first iteration:")]),e._v(" "),t("ul",[t("li",[e._v("Well-Known Document: "),t("code",[e._v("GET /.well-known/openeo")])]),e._v(" "),t("li",[e._v("Capabilities: "),t("code",[e._v("GET /")]),e._v(" and "),t("code",[e._v("GET /file_formats")])]),e._v(" "),t("li",[e._v("Data discovery: "),t("code",[e._v("GET /collections")]),e._v(" and "),t("code",[e._v("GET /collections/{collection_id}")])]),e._v(" "),t("li",[e._v("Process discovery: "),t("code",[e._v("GET /processes")])]),e._v(" "),t("li",[e._v("Data processing: "),t("code",[e._v("POST /result")])]),e._v(" "),t("li",[e._v("Authentication (if required): "),t("code",[e._v("GET /credentials/basic")])])]),e._v(" "),t("p",[e._v("A more detailed recommendation about the endpoints and processes to implement can be found in the "),t("RouterLink",{attrs:{to:"/documentation/1.0/developers/profiles/"}},[e._v("API and Processes profiles")]),e._v(".")],1),e._v(" "),t("p",[e._v("Afterwards you can already start experimenting with your first process graphs and process EO data with our client libraries on your back-end.")]),e._v(" "),t("p",[t("em",[e._v("More information will follow soon, for example about back-end compliance testing.")])])])}),[],!1,null,null,null);t.default=n.exports}}]); \ No newline at end of file +(window.webpackJsonp=window.webpackJsonp||[]).push([[78],{520:function(e,t,o){"use strict";o.r(t);var r=o(4),n=Object(r.a)({},(function(){var e=this,t=e._self._c;return t("ContentSlotsDistributor",{attrs:{"slot-key":e.$parent.slotKey}},[t("h1",{attrs:{id:"getting-started-for-service-back-end-providers"}},[t("a",{staticClass:"header-anchor",attrs:{href:"#getting-started-for-service-back-end-providers"}},[e._v("#")]),e._v(" Getting started for service (back-end) providers")]),e._v(" "),t("p",[e._v("As a back-end provider who wants to provide its datasets, processes and infrastructure to a broader audience through a standardized interface you may want to implement a driver for openEO.")]),e._v(" "),t("p",[e._v("First of all, you should go through the list of "),t("a",{attrs:{href:"https://github.com/Open-EO",target:"_blank",rel:"noopener noreferrer"}},[e._v("openEO repositories"),t("OutboundLink")],1),e._v(' and check whether there is already a back-end driver that suits your needs. In this case you don\'t need to develop your own driver, but "only" need to ingest your data, adopt your required processes and set up the infrastructure. Please follow the documentation for the individual driver you want to use.')]),e._v(" "),t("p",[e._v("If your preferred technology has no back-end driver yet, you may consider writing your own driver. All software written for openEO should follow the "),t("RouterLink",{attrs:{to:"/documentation/software-guidelines.html"}},[e._v("software development guidelines")]),e._v(".")],1),e._v(" "),t("p",[e._v("You certainly need to understand the "),t("RouterLink",{attrs:{to:"/documentation/1.0/glossary.html"}},[e._v("glossary")]),e._v(", the "),t("RouterLink",{attrs:{to:"/documentation/1.0/developers/arch.html"}},[e._v("architecture")]),e._v(" of openEO and the concepts behind "),t("RouterLink",{attrs:{to:"/documentation/1.0/developers/api/reference.html#section/Processes"}},[e._v("processes")]),e._v(" and "),t("RouterLink",{attrs:{to:"/documentation/1.0/developers/api/reference.html#section/Processes/Process-Graphs"}},[e._v("process graphs")]),e._v(". This helps you read and understand the "),t("RouterLink",{attrs:{to:"/documentation/1.0/developers/api/reference.html"}},[e._v("API specification")]),e._v(". Technical API related documents like "),t("RouterLink",{attrs:{to:"/documentation/1.0/developers/api/reference.html#section/Cross-Origin-Resource-Sharing-(CORS)"}},[e._v("CORS")]),e._v(" and "),t("RouterLink",{attrs:{to:"/documentation/1.0/developers/api/reference.html#section/API-Principles/Error-Handling"}},[e._v("error handing")]),e._v(" should be read, too.")],1),e._v(" "),t("p",[e._v("If you do not want to start from scratch, you could try to generate a server stub from the "),t("a",{attrs:{href:"https://www.openapis.org/",target:"_blank",rel:"noopener noreferrer"}},[e._v("OpenAPI 3.0"),t("OutboundLink")],1),e._v("-based "),t("RouterLink",{attrs:{to:"/documentation/1.0/developers/api/reference.html"}},[e._v("API specification")]),e._v(" with the "),t("a",{attrs:{href:"https://github.com/OpenAPITools/openapi-generator",target:"_blank",rel:"noopener noreferrer"}},[e._v("OpenAPI Generator"),t("OutboundLink")],1),e._v(".\nIf you are using Python to implement your driver you may reuse some common modules of the existing driver implementations:")],1),e._v(" "),t("ul",[t("li",[t("a",{attrs:{href:"https://github.com/Open-EO/openeo-python-driver",target:"_blank",rel:"noopener noreferrer"}},[e._v("Python Driver Commons"),t("OutboundLink")],1)])]),e._v(" "),t("p",[e._v("You can implement a back-end in iterations. It is recommended to start by implementing the "),t("RouterLink",{attrs:{to:"/documentation/1.0/developers/api/reference.html#tag/Capabilities"}},[e._v("Capabilities")]),e._v(" microservice. "),t("RouterLink",{attrs:{to:"/documentation/1.0/developers/api/reference.html#tag/EO-Data-Discovery"}},[e._v("EO Data Discovery")]),e._v(", "),t("RouterLink",{attrs:{to:"/documentation/1.0/developers/api/reference.html#tag/Process-Discovery"}},[e._v("Process Discovery")]),e._v(" are important for the client libraries to be available, too. Afterwards you should implement "),t("RouterLink",{attrs:{to:"/documentation/1.0/developers/api/reference.html#tag/Batch-Jobs"}},[e._v("Batch Job Management")]),e._v(" or "),t("RouterLink",{attrs:{to:"/documentation/1.0/developers/api/reference.html#/paths/~1result/post"}},[e._v("synchronous data processing")]),e._v(". All other microservices can be added later and are not strictly required to run openEO services. Keep in mind that you don't need to implement all endpoints in the first iteration and that you can specify in the Capabilities, which endpoints you are supporting.")],1),e._v(" "),t("p",[e._v("For example, you could start by implementing the following endpoints in the first iteration:")]),e._v(" "),t("ul",[t("li",[e._v("Well-Known Document: "),t("code",[e._v("GET /.well-known/openeo")])]),e._v(" "),t("li",[e._v("Capabilities: "),t("code",[e._v("GET /")]),e._v(" and "),t("code",[e._v("GET /file_formats")])]),e._v(" "),t("li",[e._v("Data discovery: "),t("code",[e._v("GET /collections")]),e._v(" and "),t("code",[e._v("GET /collections/{collection_id}")])]),e._v(" "),t("li",[e._v("Process discovery: "),t("code",[e._v("GET /processes")])]),e._v(" "),t("li",[e._v("Data processing: "),t("code",[e._v("POST /result")])]),e._v(" "),t("li",[e._v("Authentication (if required): "),t("code",[e._v("GET /credentials/basic")])])]),e._v(" "),t("p",[e._v("A more detailed recommendation about the endpoints and processes to implement can be found in the "),t("RouterLink",{attrs:{to:"/documentation/1.0/developers/profiles/"}},[e._v("API and Processes profiles")]),e._v(".")],1),e._v(" "),t("p",[e._v("Afterwards you can already start experimenting with your first process graphs and process EO data with our client libraries on your back-end.")]),e._v(" "),t("p",[t("em",[e._v("More information will follow soon, for example about back-end compliance testing.")])])])}),[],!1,null,null,null);t.default=n.exports}}]); \ No newline at end of file diff --git a/assets/js/79.db0b8d8b.js b/assets/js/79.9744d354.js similarity index 99% rename from assets/js/79.db0b8d8b.js rename to assets/js/79.9744d354.js index ac068ad2a..51f9ea54e 100644 --- a/assets/js/79.db0b8d8b.js +++ b/assets/js/79.9744d354.js @@ -1 +1 @@ -(window.webpackJsonp=window.webpackJsonp||[]).push([[79],{520:function(e,a,t){"use strict";t.r(a);var o=t(4),s=Object(o.a)({},(function(){var e=this,a=e._self._c;return a("ContentSlotsDistributor",{attrs:{"slot-key":e.$parent.slotKey}},[a("h1",{attrs:{id:"performance-guide-for-openeo-backends"}},[a("a",{staticClass:"header-anchor",attrs:{href:"#performance-guide-for-openeo-backends"}},[e._v("#")]),e._v(" Performance guide for openEO backends")]),e._v(" "),a("h2",{attrs:{id:"openeo-api-vision-on-performance-scalability"}},[a("a",{staticClass:"header-anchor",attrs:{href:"#openeo-api-vision-on-performance-scalability"}},[e._v("#")]),e._v(" openEO API vision on performance & scalability")]),e._v(" "),a("p",[e._v("Given that the openEO API only defines a web service, it can in no way ensure the performance or scalability of an\nimplementation. What it can do however, is avoiding API definitions that prevent an implementation from being efficient.\nWhen openEO was designed, performance was one of the key design drivers, so here we try to explain how that is achieved.")]),e._v(" "),a("h3",{attrs:{id:"bringing-the-processing-to-the-data"}},[a("a",{staticClass:"header-anchor",attrs:{href:"#bringing-the-processing-to-the-data"}},[e._v("#")]),e._v(" Bringing the processing to the data")]),e._v(" "),a("p",[e._v("Two evolutions created the need for an API designed for performance and scalability: EO programmes like Copernicus that\npushed data volumes into the petabyte range, and a move towards ever larger cloud infrastructure and HPC processing capacity\nto analyze these volumes of data. OpenEO supports this by defining data access and processing into a single specification.\nAs a result, the openEO process graph allows the backend to choose any data access pattern that is optimal for\nthe processing that is to be executed, and the dataset that is to be read.")]),e._v(" "),a("p",[e._v("A popular example of such a case, is infrastructures that store the data on the same machines that do the processing.\nIn such a case, an openEO backend can choose to load and process the data directly on the machine that has the data stored.\nAnother example is adjusting and aligning the data chunks for the processing to the internal layout of the file format that\nstores the EO data. IO performance optimizations like this are only possible if the processing engine has deep knowledge\nof the data organization from storage system over networks to file formats.")]),e._v(" "),a("h3",{attrs:{id:"datacube-processing"}},[a("a",{staticClass:"header-anchor",attrs:{href:"#datacube-processing"}},[e._v("#")]),e._v(" Datacube processing")]),e._v(" "),a("p",[e._v("The datacube view that openEO uses as a model to represent the data as it is transformed by various processes also has\nimportant performance and scalability implications.")]),e._v(" "),a("p",[e._v("The easiest way to understand this is to contrast it with a more traditional 'product-based' view of building workflows.\nIn a product or file based workflow, a process operates on a set of input files and generates a set of output files. Many\nEO workflows have been written like this, but the consequence is that every process spends time on reading date into memory, and\nwriting it back to disk. Persistent storage is often the slowest component in a processing system, and thus these workflows\nspend a lot of time on IO. In the openEO specification, a process transforms one datacube into another datacube.\nBackend implementations are encouraged to avoid writing data to disk in between processing steps whenever possible. By\nkeeping the datacubes into memory, this avoids those costly IO operations.")]),e._v(" "),a("p",[e._v("Here it is important to note that openEO does not enforce or define how the datacube should look like on the backend. The\ndatacube can be a set of files, or arrays in memory distributed over a cluster. These choices are left to the\nbackend implementor, this guide only tries to highlight the possibilities.")]),e._v(" "),a("p",[e._v("For scalability, the openEO processes clearly define along which set of dimensions of the datacube they operate. When\na user writes a process graph, it should never instruct the backend to apply a black box algorithm or function on the\nentire datacube. For most algorithms, this is not necessary, and loading the complete datacube of a Copernicus mission at once\nis simply not possible. Hence, users run '"),a("a",{attrs:{href:"https://openeo.org/documentation/1.0/developers/api/reference.html#section/Processes/Process-Graphs",target:"_blank",rel:"noopener noreferrer"}},[e._v("user-defined (child) processes"),a("OutboundLink")],1),e._v("' over a 1-dimensional array, or even multidimensional arrays or 'chunks'\nof the datacube. Based on this information, the backend is able to define both a data access and processing strategy that is\noptimal for the given process graph.")]),e._v(" "),a("h2",{attrs:{id:"process-graph-execution"}},[a("a",{staticClass:"header-anchor",attrs:{href:"#process-graph-execution"}},[e._v("#")]),e._v(" Process graph execution")]),e._v(" "),a("p",[e._v("Here we go a bit more into detail about how a backend evaluates a process graph. Again, this is not normative or\nmandated by the specification, but rather an explanation of one way to achieve optimal performance.")]),e._v(" "),a("p",[e._v("In general, process graphs are first analyzed as a whole before the actual processing starts. The analysis phase serves\nto reveal the optimal processing strategy and parameters.")]),e._v(" "),a("p",[e._v("These are a few examples of things that can be derived from a process graph and subsequent optimizations:")]),e._v(" "),a("ul",[a("li",[a("strong",[e._v("Masking:")]),e._v(" when a raster dataset is masked with another raster or polygons, then often the loading of the datacube to\nwhich the mask is applied can be limited to unmasked values.")]),e._v(" "),a("li",[a("strong",[e._v("Vector filtering:")]),e._v(" various operations (aggregate_spatial, filter_spatial, mask_polygon) can restrict the datacube to a\nset of polygons, resulting in a rather sparse cube. Loading and processing of sparse cubes can be rather different from dense data cubes.")]),e._v(" "),a("li",[a("strong",[e._v("Resampling:")]),e._v(" resampling operations can allow data to be loaded from overviews rather than original resolution. Applying\nresampling and reprojection at load time can also be faster and save memory.")]),e._v(" "),a("li",[a("strong",[e._v("Multitemporal processing:")]),e._v(" many EO algorithms work over the temporal dimension rather than spatial dimensions. The\ntype of algorithm can be inferred from the process graph, allowing to adjust the processing strategy accordingly.")])]),e._v(" "),a("h2",{attrs:{id:"performance-faq"}},[a("a",{staticClass:"header-anchor",attrs:{href:"#performance-faq"}},[e._v("#")]),e._v(" Performance FAQ")]),e._v(" "),a("h3",{attrs:{id:"i-have-a-highly-optimized-workflow-can-openeo-expose-it"}},[a("a",{staticClass:"header-anchor",attrs:{href:"#i-have-a-highly-optimized-workflow-can-openeo-expose-it"}},[e._v("#")]),e._v(" I have a highly optimized workflow, can openEO expose it?")]),e._v(" "),a("p",[e._v("Basically openEO can expose anything as a custom 'process'. If your algorithm can not be expressed as an openEO process graph,\nthen you can just let your backend advertise your custom process. By doing this, you still benefit from a lot of the standardized\nfeatures in the openEO API, and most tools for openEO will also support working with custom processes. This is fairly similar\nto exposing your process in other standards such as OGC Processes.")]),e._v(" "),a("p",[e._v("We do expect however that it is much more likely that your workflow can still reuse a few standardized processes. For instance,\nif it can be run on a geographical bounding box, the filter_bbox process would be a standardized way to specify that. Or\nperhaps it can operate on any set of Sentinel-2 products, in which case you might fit in a load_collection to let your users\ncustomize the input data. So usually, while you might start from a fully custom process, you'll notice that openEO offers\nways to gradually standardize your workflow further in a stepwise manner.")]),e._v(" "),a("h3",{attrs:{id:"can-openeo-be-as-fast-as-a-hand-written-workflow"}},[a("a",{staticClass:"header-anchor",attrs:{href:"#can-openeo-be-as-fast-as-a-hand-written-workflow"}},[e._v("#")]),e._v(" Can openEO be as fast as a hand-written workflow?")]),e._v(" "),a("p",[e._v("This question depends on which backend implementation you compare to which workflow, so there is no generic answer.\nWe do note that for writing non-trivial workflows in a cloud environment, you require a combination of algorithmic programming skills\nand cloud engineering that usually requires a team of skilled persons spending (in total) multiple person months to years on the same workflow.\nSo if you know that many workflow patterns in the operational openEO backends have already been highly optimized, you may\nwant to consider if the potential of reducing processing cost with a few percentages justifies the effort.")]),e._v(" "),a("p",[e._v("Also consider that next to the openEO API, there's also a community of open source backend implementations. So if you have\nthe skills to optimize processing pipelines to perfection, why don't you consider contributing to a backend that matches your\npreferred technology stack?")])])}),[],!1,null,null,null);a.default=s.exports}}]); \ No newline at end of file +(window.webpackJsonp=window.webpackJsonp||[]).push([[79],{522:function(e,a,t){"use strict";t.r(a);var o=t(4),s=Object(o.a)({},(function(){var e=this,a=e._self._c;return a("ContentSlotsDistributor",{attrs:{"slot-key":e.$parent.slotKey}},[a("h1",{attrs:{id:"performance-guide-for-openeo-backends"}},[a("a",{staticClass:"header-anchor",attrs:{href:"#performance-guide-for-openeo-backends"}},[e._v("#")]),e._v(" Performance guide for openEO backends")]),e._v(" "),a("h2",{attrs:{id:"openeo-api-vision-on-performance-scalability"}},[a("a",{staticClass:"header-anchor",attrs:{href:"#openeo-api-vision-on-performance-scalability"}},[e._v("#")]),e._v(" openEO API vision on performance & scalability")]),e._v(" "),a("p",[e._v("Given that the openEO API only defines a web service, it can in no way ensure the performance or scalability of an\nimplementation. What it can do however, is avoiding API definitions that prevent an implementation from being efficient.\nWhen openEO was designed, performance was one of the key design drivers, so here we try to explain how that is achieved.")]),e._v(" "),a("h3",{attrs:{id:"bringing-the-processing-to-the-data"}},[a("a",{staticClass:"header-anchor",attrs:{href:"#bringing-the-processing-to-the-data"}},[e._v("#")]),e._v(" Bringing the processing to the data")]),e._v(" "),a("p",[e._v("Two evolutions created the need for an API designed for performance and scalability: EO programmes like Copernicus that\npushed data volumes into the petabyte range, and a move towards ever larger cloud infrastructure and HPC processing capacity\nto analyze these volumes of data. OpenEO supports this by defining data access and processing into a single specification.\nAs a result, the openEO process graph allows the backend to choose any data access pattern that is optimal for\nthe processing that is to be executed, and the dataset that is to be read.")]),e._v(" "),a("p",[e._v("A popular example of such a case, is infrastructures that store the data on the same machines that do the processing.\nIn such a case, an openEO backend can choose to load and process the data directly on the machine that has the data stored.\nAnother example is adjusting and aligning the data chunks for the processing to the internal layout of the file format that\nstores the EO data. IO performance optimizations like this are only possible if the processing engine has deep knowledge\nof the data organization from storage system over networks to file formats.")]),e._v(" "),a("h3",{attrs:{id:"datacube-processing"}},[a("a",{staticClass:"header-anchor",attrs:{href:"#datacube-processing"}},[e._v("#")]),e._v(" Datacube processing")]),e._v(" "),a("p",[e._v("The datacube view that openEO uses as a model to represent the data as it is transformed by various processes also has\nimportant performance and scalability implications.")]),e._v(" "),a("p",[e._v("The easiest way to understand this is to contrast it with a more traditional 'product-based' view of building workflows.\nIn a product or file based workflow, a process operates on a set of input files and generates a set of output files. Many\nEO workflows have been written like this, but the consequence is that every process spends time on reading date into memory, and\nwriting it back to disk. Persistent storage is often the slowest component in a processing system, and thus these workflows\nspend a lot of time on IO. In the openEO specification, a process transforms one datacube into another datacube.\nBackend implementations are encouraged to avoid writing data to disk in between processing steps whenever possible. By\nkeeping the datacubes into memory, this avoids those costly IO operations.")]),e._v(" "),a("p",[e._v("Here it is important to note that openEO does not enforce or define how the datacube should look like on the backend. The\ndatacube can be a set of files, or arrays in memory distributed over a cluster. These choices are left to the\nbackend implementor, this guide only tries to highlight the possibilities.")]),e._v(" "),a("p",[e._v("For scalability, the openEO processes clearly define along which set of dimensions of the datacube they operate. When\na user writes a process graph, it should never instruct the backend to apply a black box algorithm or function on the\nentire datacube. For most algorithms, this is not necessary, and loading the complete datacube of a Copernicus mission at once\nis simply not possible. Hence, users run '"),a("a",{attrs:{href:"https://openeo.org/documentation/1.0/developers/api/reference.html#section/Processes/Process-Graphs",target:"_blank",rel:"noopener noreferrer"}},[e._v("user-defined (child) processes"),a("OutboundLink")],1),e._v("' over a 1-dimensional array, or even multidimensional arrays or 'chunks'\nof the datacube. Based on this information, the backend is able to define both a data access and processing strategy that is\noptimal for the given process graph.")]),e._v(" "),a("h2",{attrs:{id:"process-graph-execution"}},[a("a",{staticClass:"header-anchor",attrs:{href:"#process-graph-execution"}},[e._v("#")]),e._v(" Process graph execution")]),e._v(" "),a("p",[e._v("Here we go a bit more into detail about how a backend evaluates a process graph. Again, this is not normative or\nmandated by the specification, but rather an explanation of one way to achieve optimal performance.")]),e._v(" "),a("p",[e._v("In general, process graphs are first analyzed as a whole before the actual processing starts. The analysis phase serves\nto reveal the optimal processing strategy and parameters.")]),e._v(" "),a("p",[e._v("These are a few examples of things that can be derived from a process graph and subsequent optimizations:")]),e._v(" "),a("ul",[a("li",[a("strong",[e._v("Masking:")]),e._v(" when a raster dataset is masked with another raster or polygons, then often the loading of the datacube to\nwhich the mask is applied can be limited to unmasked values.")]),e._v(" "),a("li",[a("strong",[e._v("Vector filtering:")]),e._v(" various operations (aggregate_spatial, filter_spatial, mask_polygon) can restrict the datacube to a\nset of polygons, resulting in a rather sparse cube. Loading and processing of sparse cubes can be rather different from dense data cubes.")]),e._v(" "),a("li",[a("strong",[e._v("Resampling:")]),e._v(" resampling operations can allow data to be loaded from overviews rather than original resolution. Applying\nresampling and reprojection at load time can also be faster and save memory.")]),e._v(" "),a("li",[a("strong",[e._v("Multitemporal processing:")]),e._v(" many EO algorithms work over the temporal dimension rather than spatial dimensions. The\ntype of algorithm can be inferred from the process graph, allowing to adjust the processing strategy accordingly.")])]),e._v(" "),a("h2",{attrs:{id:"performance-faq"}},[a("a",{staticClass:"header-anchor",attrs:{href:"#performance-faq"}},[e._v("#")]),e._v(" Performance FAQ")]),e._v(" "),a("h3",{attrs:{id:"i-have-a-highly-optimized-workflow-can-openeo-expose-it"}},[a("a",{staticClass:"header-anchor",attrs:{href:"#i-have-a-highly-optimized-workflow-can-openeo-expose-it"}},[e._v("#")]),e._v(" I have a highly optimized workflow, can openEO expose it?")]),e._v(" "),a("p",[e._v("Basically openEO can expose anything as a custom 'process'. If your algorithm can not be expressed as an openEO process graph,\nthen you can just let your backend advertise your custom process. By doing this, you still benefit from a lot of the standardized\nfeatures in the openEO API, and most tools for openEO will also support working with custom processes. This is fairly similar\nto exposing your process in other standards such as OGC Processes.")]),e._v(" "),a("p",[e._v("We do expect however that it is much more likely that your workflow can still reuse a few standardized processes. For instance,\nif it can be run on a geographical bounding box, the filter_bbox process would be a standardized way to specify that. Or\nperhaps it can operate on any set of Sentinel-2 products, in which case you might fit in a load_collection to let your users\ncustomize the input data. So usually, while you might start from a fully custom process, you'll notice that openEO offers\nways to gradually standardize your workflow further in a stepwise manner.")]),e._v(" "),a("h3",{attrs:{id:"can-openeo-be-as-fast-as-a-hand-written-workflow"}},[a("a",{staticClass:"header-anchor",attrs:{href:"#can-openeo-be-as-fast-as-a-hand-written-workflow"}},[e._v("#")]),e._v(" Can openEO be as fast as a hand-written workflow?")]),e._v(" "),a("p",[e._v("This question depends on which backend implementation you compare to which workflow, so there is no generic answer.\nWe do note that for writing non-trivial workflows in a cloud environment, you require a combination of algorithmic programming skills\nand cloud engineering that usually requires a team of skilled persons spending (in total) multiple person months to years on the same workflow.\nSo if you know that many workflow patterns in the operational openEO backends have already been highly optimized, you may\nwant to consider if the potential of reducing processing cost with a few percentages justifies the effort.")]),e._v(" "),a("p",[e._v("Also consider that next to the openEO API, there's also a community of open source backend implementations. So if you have\nthe skills to optimize processing pipelines to perfection, why don't you consider contributing to a backend that matches your\npreferred technology stack?")])])}),[],!1,null,null,null);a.default=s.exports}}]); \ No newline at end of file diff --git a/assets/js/80.34938e44.js b/assets/js/80.4db57826.js similarity index 99% rename from assets/js/80.34938e44.js rename to assets/js/80.4db57826.js index a2029eb0f..fdbf491e4 100644 --- a/assets/js/80.34938e44.js +++ b/assets/js/80.4db57826.js @@ -1 +1 @@ -(window.webpackJsonp=window.webpackJsonp||[]).push([[80],{522:function(e,o,t){"use strict";t.r(o);var a=t(4),r=Object(a.a)({},(function(){var e=this,o=e._self._c;return o("ContentSlotsDistributor",{attrs:{"slot-key":e.$parent.slotKey}},[o("h1",{attrs:{id:"getting-started-with-openeo-and-xarray-and-dask"}},[o("a",{staticClass:"header-anchor",attrs:{href:"#getting-started-with-openeo-and-xarray-and-dask"}},[e._v("#")]),e._v(" Getting started with openEO and Xarray and Dask")]),e._v(" "),o("p",[e._v("As a back-end provider who wants to provide its datasets, processes and infrastructure to a broader audience through a\nstandardized interface you may want to implement a driver for openEO.")]),e._v(" "),o("p",[e._v("First of all, you should read carefully the "),o("RouterLink",{attrs:{to:"/documentation/1.0/developers/backends/getting-started.html"}},[e._v("getting started guide for service providers")]),e._v(".")],1),e._v(" "),o("div",{staticClass:"custom-block tip"},[o("p",{staticClass:"custom-block-title"},[e._v("Note")]),e._v(" "),o("p",[e._v("The Xarray-Dask implementation for openEO is not a full-fledged out-of-the-box openEO back-end,\nbut can be part of the infrastructure for the data management and processing part.\nIn detail it can be used as data source for "),o("RouterLink",{attrs:{to:"/documentation/1.0/developers/api/reference.html#tag/EO-Data-Discovery"}},[e._v("EO Data Discovery")]),e._v(" and e.g.\nin combination with a Dask cluster as processing back-end for "),o("RouterLink",{attrs:{to:"/documentation/1.0/developers/api/reference.html#tag/Data-Processing"}},[e._v("Data Processing")]),e._v(".\nIn any case, a "),o("a",{attrs:{href:"#http-rest-interface"}},[e._v("HTTP REST interface must be available in front of process implementations to properly answer openEO requests")]),e._v(".")],1)]),e._v(" "),o("p",[e._v("There are two main components involved with openEO and Xarray:")]),e._v(" "),o("ol",[o("li",[o("a",{attrs:{href:"#process-graph-parser-for-python"}},[e._v("Process Graph Parser for Python")])]),e._v(" "),o("li",[o("a",{attrs:{href:"#python-processes-for-openeo"}},[e._v("Python Processes for openEO")])])]),e._v(" "),o("h2",{attrs:{id:"process-graph-parser-for-python"}},[o("a",{staticClass:"header-anchor",attrs:{href:"#process-graph-parser-for-python"}},[e._v("#")]),e._v(" Process Graph Parser for Python")]),e._v(" "),o("ul",[o("li",[e._v("Repository: "),o("a",{attrs:{href:"https://github.com/Open-EO/openeo-pg-parser-networkx",target:"_blank",rel:"noopener noreferrer"}},[e._v("openeo-pg-parser-networkx"),o("OutboundLink")],1)])]),e._v(" "),o("p",[e._v("This pg-parser parses OpenEO process graphs from raw JSON into fully traversible networkx graph objects.")]),e._v(" "),o("p",[e._v("The "),o("code",[e._v("ProcessRegistry")]),e._v(" can be imported from the pg-parser and includes "),o("code",[e._v("Process")]),e._v(" objects, that include a")]),e._v(" "),o("ul",[o("li",[e._v("spec: Process definition (e.g. https://github.com/Open-EO/openeo-processes)")]),e._v(" "),o("li",[e._v("implementation: Callable process implementation (https://github.com/Open-EO/openeo-processes-dask/tree/main/openeo_processes_dask/process_implementations)")]),e._v(" "),o("li",[e._v("namespace")])]),e._v(" "),o("p",[e._v("The "),o("code",[e._v("ProcessRegistry")]),e._v(" automatically maps from the name of a process to the "),o("code",[e._v("spec")]),e._v(" and to the "),o("code",[e._v("implementation")]),e._v(".\nEvery "),o("code",[e._v("Process")]),e._v(" in the "),o("code",[e._v("ProcessRegistry")]),e._v(" requires a "),o("code",[e._v("spec")]),e._v(", while "),o("code",[e._v("implementation")]),e._v(" and "),o("code",[e._v("namespace")]),e._v(" are optional.")]),e._v(" "),o("p",[e._v("An example on how to use the pg-parser can be found "),o("a",{attrs:{href:"https://github.com/Open-EO/openeo-pg-parser-networkx/blob/main/examples/01_minibackend_demo.ipynb",target:"_blank",rel:"noopener noreferrer"}},[e._v("here"),o("OutboundLink")],1),e._v(".")]),e._v(" "),o("h2",{attrs:{id:"python-processes-for-openeo"}},[o("a",{staticClass:"header-anchor",attrs:{href:"#python-processes-for-openeo"}},[e._v("#")]),e._v(" Python Processes for openEO")]),e._v(" "),o("ul",[o("li",[e._v("Repository: "),o("a",{attrs:{href:"https://github.com/Open-EO/openeo-processes-dask",target:"_blank",rel:"noopener noreferrer"}},[e._v("openeo-processes-dask"),o("OutboundLink")],1)])]),e._v(" "),o("p",[e._v("This package includes the implementations of openEO processes, using Xarray and Dask. Currently, the "),o("code",[e._v("load_collection")]),e._v(" and "),o("code",[e._v("save_result")]),e._v(" process are not included as these implementations can differ widely for different backends.")]),e._v(" "),o("p",[e._v("The "),o("code",[e._v("specs")]),e._v(" can be found in the "),o("code",[e._v("openeo-processes-dask")]),e._v(" as a submodule. That way, the specification and the implementation are stored close to each other.")]),e._v(" "),o("h2",{attrs:{id:"the-load-collection-and-save-result-process"}},[o("a",{staticClass:"header-anchor",attrs:{href:"#the-load-collection-and-save-result-process"}},[e._v("#")]),e._v(" The load_collection and save_result process")]),e._v(" "),o("p",[e._v("As mentioned before, the "),o("code",[e._v("load_collection")]),e._v(" and "),o("code",[e._v("save_result")]),e._v(" processes are back-end-specific and therefore not included in "),o("a",{attrs:{href:"https://github.com/Open-EO/openeo-processes-dask",target:"_blank",rel:"noopener noreferrer"}},[e._v("openeo-processes-dask"),o("OutboundLink")],1),e._v(". The "),o("a",{attrs:{href:"https://processes.openeo.org/#load_collection",target:"_blank",rel:"noopener noreferrer"}},[e._v("load_collection"),o("OutboundLink")],1),e._v(" process should return a "),o("code",[e._v("raster-cube")]),e._v(" object - to be compliant with the "),o("code",[e._v("openeo-processes-dask")]),e._v(" implementations, this should be realized by a "),o("code",[e._v("xarray.DataArray")]),e._v(" loaded with "),o("code",[e._v("dask")]),e._v(".")]),e._v(" "),o("h3",{attrs:{id:"connection-to-odc-and-stac"}},[o("a",{staticClass:"header-anchor",attrs:{href:"#connection-to-odc-and-stac"}},[e._v("#")]),e._v(" Connection to ODC and STAC")]),e._v(" "),o("p",[e._v("For testing purposes with "),o("code",[e._v("DataArrays")]),e._v(" - which can be loaded from one file - the "),o("code",[e._v("xarray.open_dataarray()")]),e._v(" function can be used to implement a basic version of "),o("code",[e._v("load_collection")]),e._v(".")]),e._v(" "),o("p",[e._v("Large data sets can be organised as "),o("code",[e._v("opendatacube Products")]),e._v(" or as "),o("code",[e._v("STAC Collections")]),e._v(".")]),e._v(" "),o("ul",[o("li",[o("p",[o("code",[e._v("opendatacube Products")]),e._v(": The implementation of "),o("code",[e._v("load_collection")]),e._v(" can include the "),o("code",[e._v("opendatacube")]),e._v(" function "),o("code",[e._v("datacube.Datacube.load()")]),e._v(". It is recommended to use the "),o("code",[e._v("dask_chunks")]),e._v(" parameter, when loading the data. The function returns a "),o("code",[e._v("xarray DataSet")]),e._v(", in order to be compliant with "),o("code",[e._v("openeo-processes-dask")]),e._v(", it can be converted to a "),o("code",[e._v("DataArray")]),e._v(" using the "),o("code",[e._v("Dataset.to_array(dim='bands')")]),e._v(" function. A sample "),o("code",[e._v("load_collection")]),e._v(" process using OpenDatacube "),o("a",{attrs:{href:"https://github.com/Open-EO/openeo_odc_driver/blob/c197387c10f8fef7d5573270a35961a278a18e1d/openeo_odc_driver/processing.py#L38",target:"_blank",rel:"noopener noreferrer"}},[e._v("can be found here"),o("OutboundLink")],1),e._v(".")])]),e._v(" "),o("li",[o("p",[o("code",[e._v("STAC Collections")]),e._v(": Alternatively, the "),o("code",[e._v("load_collection")]),e._v(" process can be implemented using the "),o("code",[e._v("odc.stac.load()")]),e._v(" function. To make use of "),o("code",[e._v("dask")]),e._v(", the "),o("code",[e._v("chunks")]),e._v(" parameter must be set. Just as in the previous case, the resulting "),o("code",[e._v("xarray DataSet")]),e._v(" can be converted to a "),o("code",[e._v("DataArray")]),e._v(" with "),o("code",[e._v("Dataset.to_array(dim='bands')")]),e._v(". A similar implementation is the one of the "),o("code",[e._v("load_stac")]),e._v(" process "),o("a",{attrs:{href:"https://github.com/Open-EO/openeo-processes-dask/blob/9267e4ccffbbbf755cb7b8a43ba80d9483398314/openeo_processes_dask/process_implementations/cubes/load.py#L83",target:"_blank",rel:"noopener noreferrer"}},[e._v("available here"),o("OutboundLink")],1),e._v(".")])])]),e._v(" "),o("h2",{attrs:{id:"openeo-client-side-processing"}},[o("a",{staticClass:"header-anchor",attrs:{href:"#openeo-client-side-processing"}},[e._v("#")]),e._v(" openEO Client Side Processing")]),e._v(" "),o("p",[e._v("The client-side processing functionality allows to test and use openEO with its processes locally, i.e. without any connection to an openEO back-end.\nIt relies on the projects "),o("a",{attrs:{href:"https://github.com/Open-EO/openeo-pg-parser-networkx",target:"_blank",rel:"noopener noreferrer"}},[e._v("openeo-pg-parser-networkx"),o("OutboundLink")],1),e._v(", which provides an openEO process graph parsing tool, and "),o("a",{attrs:{href:"https://github.com/Open-EO/openeo-processes-dask",target:"_blank",rel:"noopener noreferrer"}},[e._v("openeo-processes-dask"),o("OutboundLink")],1),e._v(", which provides an Xarray and Dask implementation of most openEO processes.")]),e._v(" "),o("p",[e._v("You can find more information and usage examples in the openEO Python client documentation "),o("a",{attrs:{href:"https://open-eo.github.io/openeo-python-client/cookbook/localprocessing.html",target:"_blank",rel:"noopener noreferrer"}},[e._v("available here"),o("OutboundLink")],1),e._v(".")]),e._v(" "),o("h2",{attrs:{id:"adding-a-new-process"}},[o("a",{staticClass:"header-anchor",attrs:{href:"#adding-a-new-process"}},[e._v("#")]),e._v(" Adding a new process")]),e._v(" "),o("p",[e._v("To add a new process, there are changes required in the "),o("a",{attrs:{href:"https://github.com/Open-EO/openeo-processes-dask",target:"_blank",rel:"noopener noreferrer"}},[e._v("openeo-processes-dask"),o("OutboundLink")],1),e._v(".")]),e._v(" "),o("ol",[o("li",[e._v("Add the process spec")]),e._v(" "),o("li",[e._v("Add the process implementation")])]),e._v(" "),o("p",[e._v("The HTTP rest interface should have a "),o("code",[e._v("processes")]),e._v(" endpoint that reflects the process specs from "),o("code",[e._v("openeo-processes-dask")]),e._v(".")]),e._v(" "),o("h3",{attrs:{id:"add-the-process-spec"}},[o("a",{staticClass:"header-anchor",attrs:{href:"#add-the-process-spec"}},[e._v("#")]),e._v(" Add the process spec")]),e._v(" "),o("p",[e._v("Currently, "),o("a",{attrs:{href:"https://github.com/Open-EO/openeo-processes-dask",target:"_blank",rel:"noopener noreferrer"}},[e._v("openeo-processes-dask"),o("OutboundLink")],1),e._v(" includes the process definitions as a "),o("code",[e._v("submodule")]),e._v(" in the "),o("code",[e._v("openeo-processes-dask/specs")]),e._v(". The submodule can be found under https://github.com/eodcgmbh/openeo-processes, which is a fork from https://github.com/Open-EO/openeo-processes to reflect which processes (with their implementations) are actually available in "),o("code",[e._v("openeo-processes-dask")]),e._v(".")]),e._v(" "),o("h3",{attrs:{id:"add-the-process-implementation"}},[o("a",{staticClass:"header-anchor",attrs:{href:"#add-the-process-implementation"}},[e._v("#")]),e._v(" Add the process implementation")]),e._v(" "),o("ol",[o("li",[e._v("Select a process from "),o("a",{attrs:{href:"https://processes.openeo.org/",target:"_blank",rel:"noopener noreferrer"}},[e._v("processes.openeo.org"),o("OutboundLink")],1),e._v(" which does not yet have an\nimplementation in "),o("a",{attrs:{href:"https://github.com/Open-EO/openeo-processes-dask",target:"_blank",rel:"noopener noreferrer"}},[e._v("openeo-processes-dask"),o("OutboundLink")],1),e._v(".")]),e._v(" "),o("li",[e._v("Clone "),o("a",{attrs:{href:"https://github.com/Open-EO/openeo-processes-dask",target:"_blank",rel:"noopener noreferrer"}},[e._v("openeo-processes-dask"),o("OutboundLink")],1),e._v(", checkout a new branch, and start implementing the missing process. Make sure you properly handle all parameters defined for this process. Add a test for your process in "),o("code",[e._v("openeo-processes-dask/tests")]),e._v(" ideally using dask. The "),o("code",[e._v("create_fake_rastercube")]),e._v(" from the "),o("code",[e._v("openeo-processes-dask/tests/mockdata")]),e._v(" can be used for testing, with the "),o("code",[e._v("backend")]),e._v(" parameter set to "),o("code",[e._v("numpy")]),e._v(" or "),o("code",[e._v("dask")]),e._v(".")]),e._v(" "),o("li",[e._v("Push your code and open a PR.")])]),e._v(" "),o("h2",{attrs:{id:"http-rest-interface"}},[o("a",{staticClass:"header-anchor",attrs:{href:"#http-rest-interface"}},[e._v("#")]),e._v(" HTTP REST Interface")]),e._v(" "),o("p",[e._v("The next step would be to set up a HTTP REST interface (i.e. an implementation of the openEO HTTP API) for the new openEO environment.\nIt must be available in front of the process implementations to properly answer openEO client requests.\nCurrently, the "),o("a",{attrs:{href:"https://openeo.eodc.eu/v1.0",target:"_blank",rel:"noopener noreferrer"}},[e._v("EODC"),o("OutboundLink")],1),e._v(" and "),o("a",{attrs:{href:"https://openeo.eurac.edu/",target:"_blank",rel:"noopener noreferrer"}},[e._v("Eurac Research"),o("OutboundLink")],1),e._v(" back-ends use Xarray and Dask and thus\nare the first implementations of back-ends to look at.")]),e._v(" "),o("ul",[o("li",[e._v("EODC is using a Python implementation, the "),o("a",{attrs:{href:"https://github.com/eodcgmbh/openeo-fastapi",target:"_blank",rel:"noopener noreferrer"}},[e._v("openeo-fastapi"),o("OutboundLink")],1),e._v(".")]),e._v(" "),o("li",[e._v("Eurac Research relies on a Java based implementation, the "),o("a",{attrs:{href:"https://github.com/Open-EO/openeo-spring-driver",target:"_blank",rel:"noopener noreferrer"}},[e._v("openeo-spring-driver"),o("OutboundLink")],1)])]),e._v(" "),o("p",[e._v("If you have any questions, please "),o("RouterLink",{attrs:{to:"/contact.html"}},[e._v("contact us")]),e._v(".")],1)])}),[],!1,null,null,null);o.default=r.exports}}]); \ No newline at end of file +(window.webpackJsonp=window.webpackJsonp||[]).push([[80],{521:function(e,o,t){"use strict";t.r(o);var a=t(4),r=Object(a.a)({},(function(){var e=this,o=e._self._c;return o("ContentSlotsDistributor",{attrs:{"slot-key":e.$parent.slotKey}},[o("h1",{attrs:{id:"getting-started-with-openeo-and-xarray-and-dask"}},[o("a",{staticClass:"header-anchor",attrs:{href:"#getting-started-with-openeo-and-xarray-and-dask"}},[e._v("#")]),e._v(" Getting started with openEO and Xarray and Dask")]),e._v(" "),o("p",[e._v("As a back-end provider who wants to provide its datasets, processes and infrastructure to a broader audience through a\nstandardized interface you may want to implement a driver for openEO.")]),e._v(" "),o("p",[e._v("First of all, you should read carefully the "),o("RouterLink",{attrs:{to:"/documentation/1.0/developers/backends/getting-started.html"}},[e._v("getting started guide for service providers")]),e._v(".")],1),e._v(" "),o("div",{staticClass:"custom-block tip"},[o("p",{staticClass:"custom-block-title"},[e._v("Note")]),e._v(" "),o("p",[e._v("The Xarray-Dask implementation for openEO is not a full-fledged out-of-the-box openEO back-end,\nbut can be part of the infrastructure for the data management and processing part.\nIn detail it can be used as data source for "),o("RouterLink",{attrs:{to:"/documentation/1.0/developers/api/reference.html#tag/EO-Data-Discovery"}},[e._v("EO Data Discovery")]),e._v(" and e.g.\nin combination with a Dask cluster as processing back-end for "),o("RouterLink",{attrs:{to:"/documentation/1.0/developers/api/reference.html#tag/Data-Processing"}},[e._v("Data Processing")]),e._v(".\nIn any case, a "),o("a",{attrs:{href:"#http-rest-interface"}},[e._v("HTTP REST interface must be available in front of process implementations to properly answer openEO requests")]),e._v(".")],1)]),e._v(" "),o("p",[e._v("There are two main components involved with openEO and Xarray:")]),e._v(" "),o("ol",[o("li",[o("a",{attrs:{href:"#process-graph-parser-for-python"}},[e._v("Process Graph Parser for Python")])]),e._v(" "),o("li",[o("a",{attrs:{href:"#python-processes-for-openeo"}},[e._v("Python Processes for openEO")])])]),e._v(" "),o("h2",{attrs:{id:"process-graph-parser-for-python"}},[o("a",{staticClass:"header-anchor",attrs:{href:"#process-graph-parser-for-python"}},[e._v("#")]),e._v(" Process Graph Parser for Python")]),e._v(" "),o("ul",[o("li",[e._v("Repository: "),o("a",{attrs:{href:"https://github.com/Open-EO/openeo-pg-parser-networkx",target:"_blank",rel:"noopener noreferrer"}},[e._v("openeo-pg-parser-networkx"),o("OutboundLink")],1)])]),e._v(" "),o("p",[e._v("This pg-parser parses OpenEO process graphs from raw JSON into fully traversible networkx graph objects.")]),e._v(" "),o("p",[e._v("The "),o("code",[e._v("ProcessRegistry")]),e._v(" can be imported from the pg-parser and includes "),o("code",[e._v("Process")]),e._v(" objects, that include a")]),e._v(" "),o("ul",[o("li",[e._v("spec: Process definition (e.g. https://github.com/Open-EO/openeo-processes)")]),e._v(" "),o("li",[e._v("implementation: Callable process implementation (https://github.com/Open-EO/openeo-processes-dask/tree/main/openeo_processes_dask/process_implementations)")]),e._v(" "),o("li",[e._v("namespace")])]),e._v(" "),o("p",[e._v("The "),o("code",[e._v("ProcessRegistry")]),e._v(" automatically maps from the name of a process to the "),o("code",[e._v("spec")]),e._v(" and to the "),o("code",[e._v("implementation")]),e._v(".\nEvery "),o("code",[e._v("Process")]),e._v(" in the "),o("code",[e._v("ProcessRegistry")]),e._v(" requires a "),o("code",[e._v("spec")]),e._v(", while "),o("code",[e._v("implementation")]),e._v(" and "),o("code",[e._v("namespace")]),e._v(" are optional.")]),e._v(" "),o("p",[e._v("An example on how to use the pg-parser can be found "),o("a",{attrs:{href:"https://github.com/Open-EO/openeo-pg-parser-networkx/blob/main/examples/01_minibackend_demo.ipynb",target:"_blank",rel:"noopener noreferrer"}},[e._v("here"),o("OutboundLink")],1),e._v(".")]),e._v(" "),o("h2",{attrs:{id:"python-processes-for-openeo"}},[o("a",{staticClass:"header-anchor",attrs:{href:"#python-processes-for-openeo"}},[e._v("#")]),e._v(" Python Processes for openEO")]),e._v(" "),o("ul",[o("li",[e._v("Repository: "),o("a",{attrs:{href:"https://github.com/Open-EO/openeo-processes-dask",target:"_blank",rel:"noopener noreferrer"}},[e._v("openeo-processes-dask"),o("OutboundLink")],1)])]),e._v(" "),o("p",[e._v("This package includes the implementations of openEO processes, using Xarray and Dask. Currently, the "),o("code",[e._v("load_collection")]),e._v(" and "),o("code",[e._v("save_result")]),e._v(" process are not included as these implementations can differ widely for different backends.")]),e._v(" "),o("p",[e._v("The "),o("code",[e._v("specs")]),e._v(" can be found in the "),o("code",[e._v("openeo-processes-dask")]),e._v(" as a submodule. That way, the specification and the implementation are stored close to each other.")]),e._v(" "),o("h2",{attrs:{id:"the-load-collection-and-save-result-process"}},[o("a",{staticClass:"header-anchor",attrs:{href:"#the-load-collection-and-save-result-process"}},[e._v("#")]),e._v(" The load_collection and save_result process")]),e._v(" "),o("p",[e._v("As mentioned before, the "),o("code",[e._v("load_collection")]),e._v(" and "),o("code",[e._v("save_result")]),e._v(" processes are back-end-specific and therefore not included in "),o("a",{attrs:{href:"https://github.com/Open-EO/openeo-processes-dask",target:"_blank",rel:"noopener noreferrer"}},[e._v("openeo-processes-dask"),o("OutboundLink")],1),e._v(". The "),o("a",{attrs:{href:"https://processes.openeo.org/#load_collection",target:"_blank",rel:"noopener noreferrer"}},[e._v("load_collection"),o("OutboundLink")],1),e._v(" process should return a "),o("code",[e._v("raster-cube")]),e._v(" object - to be compliant with the "),o("code",[e._v("openeo-processes-dask")]),e._v(" implementations, this should be realized by a "),o("code",[e._v("xarray.DataArray")]),e._v(" loaded with "),o("code",[e._v("dask")]),e._v(".")]),e._v(" "),o("h3",{attrs:{id:"connection-to-odc-and-stac"}},[o("a",{staticClass:"header-anchor",attrs:{href:"#connection-to-odc-and-stac"}},[e._v("#")]),e._v(" Connection to ODC and STAC")]),e._v(" "),o("p",[e._v("For testing purposes with "),o("code",[e._v("DataArrays")]),e._v(" - which can be loaded from one file - the "),o("code",[e._v("xarray.open_dataarray()")]),e._v(" function can be used to implement a basic version of "),o("code",[e._v("load_collection")]),e._v(".")]),e._v(" "),o("p",[e._v("Large data sets can be organised as "),o("code",[e._v("opendatacube Products")]),e._v(" or as "),o("code",[e._v("STAC Collections")]),e._v(".")]),e._v(" "),o("ul",[o("li",[o("p",[o("code",[e._v("opendatacube Products")]),e._v(": The implementation of "),o("code",[e._v("load_collection")]),e._v(" can include the "),o("code",[e._v("opendatacube")]),e._v(" function "),o("code",[e._v("datacube.Datacube.load()")]),e._v(". It is recommended to use the "),o("code",[e._v("dask_chunks")]),e._v(" parameter, when loading the data. The function returns a "),o("code",[e._v("xarray DataSet")]),e._v(", in order to be compliant with "),o("code",[e._v("openeo-processes-dask")]),e._v(", it can be converted to a "),o("code",[e._v("DataArray")]),e._v(" using the "),o("code",[e._v("Dataset.to_array(dim='bands')")]),e._v(" function. A sample "),o("code",[e._v("load_collection")]),e._v(" process using OpenDatacube "),o("a",{attrs:{href:"https://github.com/Open-EO/openeo_odc_driver/blob/c197387c10f8fef7d5573270a35961a278a18e1d/openeo_odc_driver/processing.py#L38",target:"_blank",rel:"noopener noreferrer"}},[e._v("can be found here"),o("OutboundLink")],1),e._v(".")])]),e._v(" "),o("li",[o("p",[o("code",[e._v("STAC Collections")]),e._v(": Alternatively, the "),o("code",[e._v("load_collection")]),e._v(" process can be implemented using the "),o("code",[e._v("odc.stac.load()")]),e._v(" function. To make use of "),o("code",[e._v("dask")]),e._v(", the "),o("code",[e._v("chunks")]),e._v(" parameter must be set. Just as in the previous case, the resulting "),o("code",[e._v("xarray DataSet")]),e._v(" can be converted to a "),o("code",[e._v("DataArray")]),e._v(" with "),o("code",[e._v("Dataset.to_array(dim='bands')")]),e._v(". A similar implementation is the one of the "),o("code",[e._v("load_stac")]),e._v(" process "),o("a",{attrs:{href:"https://github.com/Open-EO/openeo-processes-dask/blob/9267e4ccffbbbf755cb7b8a43ba80d9483398314/openeo_processes_dask/process_implementations/cubes/load.py#L83",target:"_blank",rel:"noopener noreferrer"}},[e._v("available here"),o("OutboundLink")],1),e._v(".")])])]),e._v(" "),o("h2",{attrs:{id:"openeo-client-side-processing"}},[o("a",{staticClass:"header-anchor",attrs:{href:"#openeo-client-side-processing"}},[e._v("#")]),e._v(" openEO Client Side Processing")]),e._v(" "),o("p",[e._v("The client-side processing functionality allows to test and use openEO with its processes locally, i.e. without any connection to an openEO back-end.\nIt relies on the projects "),o("a",{attrs:{href:"https://github.com/Open-EO/openeo-pg-parser-networkx",target:"_blank",rel:"noopener noreferrer"}},[e._v("openeo-pg-parser-networkx"),o("OutboundLink")],1),e._v(", which provides an openEO process graph parsing tool, and "),o("a",{attrs:{href:"https://github.com/Open-EO/openeo-processes-dask",target:"_blank",rel:"noopener noreferrer"}},[e._v("openeo-processes-dask"),o("OutboundLink")],1),e._v(", which provides an Xarray and Dask implementation of most openEO processes.")]),e._v(" "),o("p",[e._v("You can find more information and usage examples in the openEO Python client documentation "),o("a",{attrs:{href:"https://open-eo.github.io/openeo-python-client/cookbook/localprocessing.html",target:"_blank",rel:"noopener noreferrer"}},[e._v("available here"),o("OutboundLink")],1),e._v(".")]),e._v(" "),o("h2",{attrs:{id:"adding-a-new-process"}},[o("a",{staticClass:"header-anchor",attrs:{href:"#adding-a-new-process"}},[e._v("#")]),e._v(" Adding a new process")]),e._v(" "),o("p",[e._v("To add a new process, there are changes required in the "),o("a",{attrs:{href:"https://github.com/Open-EO/openeo-processes-dask",target:"_blank",rel:"noopener noreferrer"}},[e._v("openeo-processes-dask"),o("OutboundLink")],1),e._v(".")]),e._v(" "),o("ol",[o("li",[e._v("Add the process spec")]),e._v(" "),o("li",[e._v("Add the process implementation")])]),e._v(" "),o("p",[e._v("The HTTP rest interface should have a "),o("code",[e._v("processes")]),e._v(" endpoint that reflects the process specs from "),o("code",[e._v("openeo-processes-dask")]),e._v(".")]),e._v(" "),o("h3",{attrs:{id:"add-the-process-spec"}},[o("a",{staticClass:"header-anchor",attrs:{href:"#add-the-process-spec"}},[e._v("#")]),e._v(" Add the process spec")]),e._v(" "),o("p",[e._v("Currently, "),o("a",{attrs:{href:"https://github.com/Open-EO/openeo-processes-dask",target:"_blank",rel:"noopener noreferrer"}},[e._v("openeo-processes-dask"),o("OutboundLink")],1),e._v(" includes the process definitions as a "),o("code",[e._v("submodule")]),e._v(" in the "),o("code",[e._v("openeo-processes-dask/specs")]),e._v(". The submodule can be found under https://github.com/eodcgmbh/openeo-processes, which is a fork from https://github.com/Open-EO/openeo-processes to reflect which processes (with their implementations) are actually available in "),o("code",[e._v("openeo-processes-dask")]),e._v(".")]),e._v(" "),o("h3",{attrs:{id:"add-the-process-implementation"}},[o("a",{staticClass:"header-anchor",attrs:{href:"#add-the-process-implementation"}},[e._v("#")]),e._v(" Add the process implementation")]),e._v(" "),o("ol",[o("li",[e._v("Select a process from "),o("a",{attrs:{href:"https://processes.openeo.org/",target:"_blank",rel:"noopener noreferrer"}},[e._v("processes.openeo.org"),o("OutboundLink")],1),e._v(" which does not yet have an\nimplementation in "),o("a",{attrs:{href:"https://github.com/Open-EO/openeo-processes-dask",target:"_blank",rel:"noopener noreferrer"}},[e._v("openeo-processes-dask"),o("OutboundLink")],1),e._v(".")]),e._v(" "),o("li",[e._v("Clone "),o("a",{attrs:{href:"https://github.com/Open-EO/openeo-processes-dask",target:"_blank",rel:"noopener noreferrer"}},[e._v("openeo-processes-dask"),o("OutboundLink")],1),e._v(", checkout a new branch, and start implementing the missing process. Make sure you properly handle all parameters defined for this process. Add a test for your process in "),o("code",[e._v("openeo-processes-dask/tests")]),e._v(" ideally using dask. The "),o("code",[e._v("create_fake_rastercube")]),e._v(" from the "),o("code",[e._v("openeo-processes-dask/tests/mockdata")]),e._v(" can be used for testing, with the "),o("code",[e._v("backend")]),e._v(" parameter set to "),o("code",[e._v("numpy")]),e._v(" or "),o("code",[e._v("dask")]),e._v(".")]),e._v(" "),o("li",[e._v("Push your code and open a PR.")])]),e._v(" "),o("h2",{attrs:{id:"http-rest-interface"}},[o("a",{staticClass:"header-anchor",attrs:{href:"#http-rest-interface"}},[e._v("#")]),e._v(" HTTP REST Interface")]),e._v(" "),o("p",[e._v("The next step would be to set up a HTTP REST interface (i.e. an implementation of the openEO HTTP API) for the new openEO environment.\nIt must be available in front of the process implementations to properly answer openEO client requests.\nCurrently, the "),o("a",{attrs:{href:"https://openeo.eodc.eu/v1.0",target:"_blank",rel:"noopener noreferrer"}},[e._v("EODC"),o("OutboundLink")],1),e._v(" and "),o("a",{attrs:{href:"https://openeo.eurac.edu/",target:"_blank",rel:"noopener noreferrer"}},[e._v("Eurac Research"),o("OutboundLink")],1),e._v(" back-ends use Xarray and Dask and thus\nare the first implementations of back-ends to look at.")]),e._v(" "),o("ul",[o("li",[e._v("EODC is using a Python implementation, the "),o("a",{attrs:{href:"https://github.com/eodcgmbh/openeo-fastapi",target:"_blank",rel:"noopener noreferrer"}},[e._v("openeo-fastapi"),o("OutboundLink")],1),e._v(".")]),e._v(" "),o("li",[e._v("Eurac Research relies on a Java based implementation, the "),o("a",{attrs:{href:"https://github.com/Open-EO/openeo-spring-driver",target:"_blank",rel:"noopener noreferrer"}},[e._v("openeo-spring-driver"),o("OutboundLink")],1)])]),e._v(" "),o("p",[e._v("If you have any questions, please "),o("RouterLink",{attrs:{to:"/contact.html"}},[e._v("contact us")]),e._v(".")],1)])}),[],!1,null,null,null);o.default=r.exports}}]); \ No newline at end of file diff --git a/assets/js/83.2fdd1946.js b/assets/js/83.776adc2c.js similarity index 93% rename from assets/js/83.2fdd1946.js rename to assets/js/83.776adc2c.js index 30d63cd1f..e814ad25d 100644 --- a/assets/js/83.2fdd1946.js +++ b/assets/js/83.776adc2c.js @@ -1 +1 @@ -(window.webpackJsonp=window.webpackJsonp||[]).push([[83],{526:function(e,t,o){"use strict";o.r(t);var s=o(4),n=Object(s.a)({},(function(){var e=this,t=e._self._c;return t("ContentSlotsDistributor",{attrs:{"slot-key":e.$parent.slotKey}},[t("h1",{attrs:{id:"openeo-profiles"}},[t("a",{staticClass:"header-anchor",attrs:{href:"#openeo-profiles"}},[e._v("#")]),e._v(" openEO Profiles")]),e._v(" "),t("p",[e._v("We've defined requirements grouped into a set of profiles for the openEO API and the openEO Processes. This helps to classify the implementation status of an openEO instance and gives recommendations to implementors which functionality to prioritize.")]),e._v(" "),t("ul",[t("li",[t("RouterLink",{attrs:{to:"/documentation/1.0/developers/profiles/api.html"}},[e._v("API Profiles")])],1),e._v(" "),t("li",[t("RouterLink",{attrs:{to:"/documentation/1.0/developers/profiles/processes.html"}},[e._v("Process Profiles")])],1)])])}),[],!1,null,null,null);t.default=n.exports}}]); \ No newline at end of file +(window.webpackJsonp=window.webpackJsonp||[]).push([[83],{537:function(e,t,o){"use strict";o.r(t);var s=o(4),n=Object(s.a)({},(function(){var e=this,t=e._self._c;return t("ContentSlotsDistributor",{attrs:{"slot-key":e.$parent.slotKey}},[t("h1",{attrs:{id:"openeo-profiles"}},[t("a",{staticClass:"header-anchor",attrs:{href:"#openeo-profiles"}},[e._v("#")]),e._v(" openEO Profiles")]),e._v(" "),t("p",[e._v("We've defined requirements grouped into a set of profiles for the openEO API and the openEO Processes. This helps to classify the implementation status of an openEO instance and gives recommendations to implementors which functionality to prioritize.")]),e._v(" "),t("ul",[t("li",[t("RouterLink",{attrs:{to:"/documentation/1.0/developers/profiles/api.html"}},[e._v("API Profiles")])],1),e._v(" "),t("li",[t("RouterLink",{attrs:{to:"/documentation/1.0/developers/profiles/processes.html"}},[e._v("Process Profiles")])],1)])])}),[],!1,null,null,null);t.default=n.exports}}]); \ No newline at end of file diff --git a/assets/js/84.45a846f1.js b/assets/js/84.2d980e77.js similarity index 99% rename from assets/js/84.45a846f1.js rename to assets/js/84.2d980e77.js index 5f3f4cff5..badf2ddef 100644 --- a/assets/js/84.45a846f1.js +++ b/assets/js/84.2d980e77.js @@ -1 +1 @@ -(window.webpackJsonp=window.webpackJsonp||[]).push([[84],{527:function(e,t,a){"use strict";a.r(t);var o=a(4),r=Object(o.a)({},(function(){var e=this,t=e._self._c;return t("ContentSlotsDistributor",{attrs:{"slot-key":e.$parent.slotKey}},[t("h1",{attrs:{id:"glossary"}},[t("a",{staticClass:"header-anchor",attrs:{href:"#glossary"}},[e._v("#")]),e._v(" Glossary")]),e._v(" "),t("p",[e._v("This glossary introduces the major technical terms used in the openEO project.")]),e._v(" "),t("h2",{attrs:{id:"general-terms"}},[t("a",{staticClass:"header-anchor",attrs:{href:"#general-terms"}},[e._v("#")]),e._v(" General terms")]),e._v(" "),t("ul",[t("li",[t("strong",[e._v("EO")]),e._v(": Earth observation")]),e._v(" "),t("li",[t("strong",[e._v("API")]),e._v(": application programming interface ("),t("a",{attrs:{href:"https://en.wikipedia.org/wiki/Application_programming_interface",target:"_blank",rel:"noopener noreferrer"}},[e._v("wikipedia"),t("OutboundLink")],1),e._v("); a communication protocol between client and back-end")]),e._v(" "),t("li",[t("strong",[e._v("client")]),e._v(": software tool or environment that end-users directly interact with, e.g. R (RStudio), Python (Jupyter notebook), and JavaScript (web browser); R and Python are two major data science platforms; JavaScript is a major language for web development")]),e._v(" "),t("li",[t("strong",[e._v("(cloud) back-end")]),e._v(": server; computer infrastructure (one or more physical computers or virtual machines) used for storing EO data and processing it")]),e._v(" "),t("li",[t("strong",[e._v("big Earth observation cloud back-end")]),e._v(": server infrastructure where industry and researchers analyse large amounts of EO data")])]),e._v(" "),t("h2",{attrs:{id:"processes"}},[t("a",{staticClass:"header-anchor",attrs:{href:"#processes"}},[e._v("#")]),e._v(" Processes")]),e._v(" "),t("p",[e._v("A "),t("strong",[e._v("process")]),e._v(" is an operation that performs a specific task on a set of parameters and returns a result. An example is computing a statistical operation, such as mean or median, on selected EO data. A process is similar to a function or method in programming languages.")]),e._v(" "),t("p",[e._v("A "),t("strong",[e._v("pre-defined process")]),e._v(" is a process provided by the "),t("em",[e._v("back-end")]),e._v(", often one of the "),t("RouterLink",{attrs:{to:"/documentation/1.0/processes.html"}},[e._v("ones centrally defined by openEO")]),e._v(".")],1),e._v(" "),t("p",[e._v("A "),t("strong",[e._v("user-defined process")]),e._v(" is a process defined by the "),t("em",[e._v("user")]),e._v(". It can directly be part of another process graph or be stored as custom process on a back-end. Internally it is a "),t("em",[e._v("process graph")]),e._v(" with optional additional metadata.")]),e._v(" "),t("p",[e._v("A "),t("strong",[e._v("process graph")]),e._v(" chains specific process calls from the set of pre-defined and user-defined processes together. A process graph itself is a (user-defined) process again. Similarly to scripts in the context of programming, process graphs organize and automate the execution of one or more processes that could alternatively be executed individually.")]),e._v(" "),t("h2",{attrs:{id:"eo-data-collections"}},[t("a",{staticClass:"header-anchor",attrs:{href:"#eo-data-collections"}},[e._v("#")]),e._v(" EO data (Collections)")]),e._v(" "),t("p",[e._v("In our domain, different terms are used to describe EO data(sets). Within openEO, a "),t("strong",[e._v("granule")]),e._v(" (sometimes also called "),t("em",[e._v("item")]),e._v(" or "),t("em",[e._v("asset")]),e._v(" in the specification) typically refers to a limited area and a single overpass leading to a very short observation period (seconds) or a temporal aggregation of such data (e.g. for 16-day MODIS composites). A "),t("strong",[e._v("collection")]),e._v(" is a sequence of granules sharing the same product specification. It typically corresponds to the series of products derived from data acquired by a sensor on board a satellite and having the same mode of operation.")]),e._v(" "),t("p",[e._v("The "),t("a",{attrs:{href:"http://ceos.org/ourwork/workinggroups/wgiss/access/opensearch/",target:"_blank",rel:"noopener noreferrer"}},[e._v("CEOS OpenSearch Best Practice Document v1.2"),t("OutboundLink")],1),e._v(" lists the following synonyms used by other organizations:")]),e._v(" "),t("ul",[t("li",[t("strong",[e._v("granule")]),e._v(": dataset (ESA, ISO 19115), granule (NASA), product (ESA, CNES), scene (JAXA)")]),e._v(" "),t("li",[t("strong",[e._v("collection")]),e._v(": dataset series (ESA, ISO 19115), collection (CNES, NASA), dataset (JAXA), product (JAXA)")])]),e._v(" "),t("p",[e._v("In openEO, a back-end offers a set of collections to be processed. All collections can be requested using a client and are described using the "),t("a",{attrs:{href:"https://github.com/radiantearth/stac-spec",target:"_blank",rel:"noopener noreferrer"}},[e._v("STAC (SpatioTemporal Asset Catalog) metadata specification"),t("OutboundLink")],1),e._v(" as STAC collections. A user can load (a subset of) a collection using a special process, which returns a (spatial) datacube. All further processing is then applied to the datacube on the back-end.")]),e._v(" "),t("h2",{attrs:{id:"spatial-datacubes"}},[t("a",{staticClass:"header-anchor",attrs:{href:"#spatial-datacubes"}},[e._v("#")]),e._v(" Spatial datacubes")]),e._v(" "),t("p",[e._v("A spatiotemporal datacube is a multidimensional array with one or more spatial or temporal dimensions.\nIn the EO domain, it is common to be implicit about the temporal dimension and just refer to them as spatial datacubes in short.\nSpecial cases are raster and "),t("a",{attrs:{href:"https://r-spatial.org/r/2022/09/12/vdc.html",target:"_blank",rel:"noopener noreferrer"}},[e._v("vector datacubes"),t("OutboundLink")],1),e._v(".\nLearn more about datacubes in the "),t("a",{attrs:{href:"https://openeo.org/documentation/1.0/datacubes.html",target:"_blank",rel:"noopener noreferrer"}},[e._v("datacube documentation"),t("OutboundLink")],1),e._v(".")]),e._v(" "),t("h2",{attrs:{id:"vector-data"}},[t("a",{staticClass:"header-anchor",attrs:{href:"#vector-data"}},[e._v("#")]),e._v(" Vector data")]),e._v(" "),t("p",[e._v("In general, "),t("strong",[e._v("vector data")]),e._v(' represent specific things (also called "features") in a space, e.g. on the surface of the Earth.')]),e._v(" "),t("p",[e._v("A "),t("strong",[e._v("coordinate")]),e._v(" represents a specific point in space.")]),e._v(" "),t("p",[e._v("A "),t("strong",[e._v("feature")]),e._v(' is a thing that usually has a geometry (e.g. the outline of an agricultural field, a forest or an urban area) and it may have additional properties assigned (e.g. a name, a color or a population).\nIn rare cases features may not have a geometry, which is often referred to as an "empty geometry".')]),e._v(" "),t("p",[t("strong",[e._v("Geometries")]),e._v(" consist of one or more coordinates that may be connected and then form a specific type of geometry, e.g. two points can be connected to a straight line and four straight lines can be connected to rectangle.")]),e._v(" "),t("p",[e._v("Commonly used types of geometries are:")]),e._v(" "),t("ul",[t("li",[e._v("Point")]),e._v(" "),t("li",[e._v("LineString (connected straight line pieces)")]),e._v(" "),t("li",[e._v("Polygon (connected straight line pieces forming a closed ring, possibly with holes - for example a triangle or rectangle)")])]),e._v(" "),t("p",[e._v('Multiple geometries of the same type can be combined into a group of geometries, e.g. a so-called "multi point" or "multi polygon".')]),e._v(" "),t("p",[e._v("Features and geometries are specified by the OGC in the "),t("a",{attrs:{href:"https://www.ogc.org/standards/sfa",target:"_blank",rel:"noopener noreferrer"}},[e._v("Simple Feature Access specification"),t("OutboundLink")],1),e._v(" (and ISO 19125). See the specification for more details.")]),e._v(" "),t("h2",{attrs:{id:"user-defined-function-udf"}},[t("a",{staticClass:"header-anchor",attrs:{href:"#user-defined-function-udf"}},[e._v("#")]),e._v(" User-defined function (UDF)")]),e._v(" "),t("p",[e._v("The abbreviation "),t("strong",[e._v("UDF")]),e._v(" stands for "),t("strong",[e._v("user-defined function")]),e._v(". With this concept, users are able to upload custom code and have it executed e.g. for every pixel of a scene, or applied to a particular dimension or set of dimensions, allowing custom server-side calculations. See the section on "),t("RouterLink",{attrs:{to:"/documentation/1.0/udfs.html"}},[e._v("UDFs")]),e._v(" for more information.")],1),e._v(" "),t("h2",{attrs:{id:"data-processing-modes"}},[t("a",{staticClass:"header-anchor",attrs:{href:"#data-processing-modes"}},[e._v("#")]),e._v(" Data Processing modes")]),e._v(" "),t("p",[e._v("Processes can run in three different ways:")]),e._v(" "),t("ol",[t("li",[e._v("Results can be pre-computed by creating a "),t("em",[t("strong",[e._v("batch job")])]),e._v(". They are submitted to the back-end's processing system, but will remain inactive until explicitly put into the processing queue. They will run only once and store results after execution. Results can be downloaded. Batch jobs are typically time consuming and user interaction is not possible although log files are generated for them. This is the only mode that allows to get an estimate about time, volume and costs beforehand.")]),e._v(" "),t("li",[e._v("A more dynamic way of processing and accessing data is to create a "),t("strong",[e._v("secondary web service")]),e._v(". They allow web-based access using different protocols such as "),t("a",{attrs:{href:"http://www.opengeospatial.org/standards/wms",target:"_blank",rel:"noopener noreferrer"}},[e._v("OGC WMS"),t("OutboundLink")],1),e._v(" (Open Geospatial Consortium Web Map Service), "),t("a",{attrs:{href:"http://www.opengeospatial.org/standards/wcs",target:"_blank",rel:"noopener noreferrer"}},[e._v("OGC WCS"),t("OutboundLink")],1),e._v(" (Web Coverage Service) or "),t("a",{attrs:{href:"https://wiki.openstreetmap.org/wiki/Slippy_map_tilenames",target:"_blank",rel:"noopener noreferrer"}},[e._v("XYZ tiles"),t("OutboundLink")],1),e._v(". These protocols usually allow users to change the viewing extent or level of detail (zoom level). Therefore, computations often run "),t("em",[e._v("on demand")]),e._v(" so that the requested data is calculated during the request. Back-ends should make sure to cache processed data to avoid additional/high costs and reduce waiting times for the user.")]),e._v(" "),t("li",[e._v("Processes can also be executed "),t("strong",[e._v("on-demand")]),e._v(" (i.e. synchronously). Results are delivered with the request itself and no job is created. Only lightweight computations, for example previews, should be executed using this approach as timeouts are to be expected for "),t("a",{attrs:{href:"https://www.pubnub.com/blog/2014-12-01-http-long-polling/",target:"_blank",rel:"noopener noreferrer"}},[e._v("long-polling HTTP requests"),t("OutboundLink")],1),e._v(".")])])])}),[],!1,null,null,null);t.default=r.exports}}]); \ No newline at end of file +(window.webpackJsonp=window.webpackJsonp||[]).push([[84],{526:function(e,t,a){"use strict";a.r(t);var o=a(4),r=Object(o.a)({},(function(){var e=this,t=e._self._c;return t("ContentSlotsDistributor",{attrs:{"slot-key":e.$parent.slotKey}},[t("h1",{attrs:{id:"glossary"}},[t("a",{staticClass:"header-anchor",attrs:{href:"#glossary"}},[e._v("#")]),e._v(" Glossary")]),e._v(" "),t("p",[e._v("This glossary introduces the major technical terms used in the openEO project.")]),e._v(" "),t("h2",{attrs:{id:"general-terms"}},[t("a",{staticClass:"header-anchor",attrs:{href:"#general-terms"}},[e._v("#")]),e._v(" General terms")]),e._v(" "),t("ul",[t("li",[t("strong",[e._v("EO")]),e._v(": Earth observation")]),e._v(" "),t("li",[t("strong",[e._v("API")]),e._v(": application programming interface ("),t("a",{attrs:{href:"https://en.wikipedia.org/wiki/Application_programming_interface",target:"_blank",rel:"noopener noreferrer"}},[e._v("wikipedia"),t("OutboundLink")],1),e._v("); a communication protocol between client and back-end")]),e._v(" "),t("li",[t("strong",[e._v("client")]),e._v(": software tool or environment that end-users directly interact with, e.g. R (RStudio), Python (Jupyter notebook), and JavaScript (web browser); R and Python are two major data science platforms; JavaScript is a major language for web development")]),e._v(" "),t("li",[t("strong",[e._v("(cloud) back-end")]),e._v(": server; computer infrastructure (one or more physical computers or virtual machines) used for storing EO data and processing it")]),e._v(" "),t("li",[t("strong",[e._v("big Earth observation cloud back-end")]),e._v(": server infrastructure where industry and researchers analyse large amounts of EO data")])]),e._v(" "),t("h2",{attrs:{id:"processes"}},[t("a",{staticClass:"header-anchor",attrs:{href:"#processes"}},[e._v("#")]),e._v(" Processes")]),e._v(" "),t("p",[e._v("A "),t("strong",[e._v("process")]),e._v(" is an operation that performs a specific task on a set of parameters and returns a result. An example is computing a statistical operation, such as mean or median, on selected EO data. A process is similar to a function or method in programming languages.")]),e._v(" "),t("p",[e._v("A "),t("strong",[e._v("pre-defined process")]),e._v(" is a process provided by the "),t("em",[e._v("back-end")]),e._v(", often one of the "),t("RouterLink",{attrs:{to:"/documentation/1.0/processes.html"}},[e._v("ones centrally defined by openEO")]),e._v(".")],1),e._v(" "),t("p",[e._v("A "),t("strong",[e._v("user-defined process")]),e._v(" is a process defined by the "),t("em",[e._v("user")]),e._v(". It can directly be part of another process graph or be stored as custom process on a back-end. Internally it is a "),t("em",[e._v("process graph")]),e._v(" with optional additional metadata.")]),e._v(" "),t("p",[e._v("A "),t("strong",[e._v("process graph")]),e._v(" chains specific process calls from the set of pre-defined and user-defined processes together. A process graph itself is a (user-defined) process again. Similarly to scripts in the context of programming, process graphs organize and automate the execution of one or more processes that could alternatively be executed individually.")]),e._v(" "),t("h2",{attrs:{id:"eo-data-collections"}},[t("a",{staticClass:"header-anchor",attrs:{href:"#eo-data-collections"}},[e._v("#")]),e._v(" EO data (Collections)")]),e._v(" "),t("p",[e._v("In our domain, different terms are used to describe EO data(sets). Within openEO, a "),t("strong",[e._v("granule")]),e._v(" (sometimes also called "),t("em",[e._v("item")]),e._v(" or "),t("em",[e._v("asset")]),e._v(" in the specification) typically refers to a limited area and a single overpass leading to a very short observation period (seconds) or a temporal aggregation of such data (e.g. for 16-day MODIS composites). A "),t("strong",[e._v("collection")]),e._v(" is a sequence of granules sharing the same product specification. It typically corresponds to the series of products derived from data acquired by a sensor on board a satellite and having the same mode of operation.")]),e._v(" "),t("p",[e._v("The "),t("a",{attrs:{href:"http://ceos.org/ourwork/workinggroups/wgiss/access/opensearch/",target:"_blank",rel:"noopener noreferrer"}},[e._v("CEOS OpenSearch Best Practice Document v1.2"),t("OutboundLink")],1),e._v(" lists the following synonyms used by other organizations:")]),e._v(" "),t("ul",[t("li",[t("strong",[e._v("granule")]),e._v(": dataset (ESA, ISO 19115), granule (NASA), product (ESA, CNES), scene (JAXA)")]),e._v(" "),t("li",[t("strong",[e._v("collection")]),e._v(": dataset series (ESA, ISO 19115), collection (CNES, NASA), dataset (JAXA), product (JAXA)")])]),e._v(" "),t("p",[e._v("In openEO, a back-end offers a set of collections to be processed. All collections can be requested using a client and are described using the "),t("a",{attrs:{href:"https://github.com/radiantearth/stac-spec",target:"_blank",rel:"noopener noreferrer"}},[e._v("STAC (SpatioTemporal Asset Catalog) metadata specification"),t("OutboundLink")],1),e._v(" as STAC collections. A user can load (a subset of) a collection using a special process, which returns a (spatial) datacube. All further processing is then applied to the datacube on the back-end.")]),e._v(" "),t("h2",{attrs:{id:"spatial-datacubes"}},[t("a",{staticClass:"header-anchor",attrs:{href:"#spatial-datacubes"}},[e._v("#")]),e._v(" Spatial datacubes")]),e._v(" "),t("p",[e._v("A spatiotemporal datacube is a multidimensional array with one or more spatial or temporal dimensions.\nIn the EO domain, it is common to be implicit about the temporal dimension and just refer to them as spatial datacubes in short.\nSpecial cases are raster and "),t("a",{attrs:{href:"https://r-spatial.org/r/2022/09/12/vdc.html",target:"_blank",rel:"noopener noreferrer"}},[e._v("vector datacubes"),t("OutboundLink")],1),e._v(".\nLearn more about datacubes in the "),t("a",{attrs:{href:"https://openeo.org/documentation/1.0/datacubes.html",target:"_blank",rel:"noopener noreferrer"}},[e._v("datacube documentation"),t("OutboundLink")],1),e._v(".")]),e._v(" "),t("h2",{attrs:{id:"vector-data"}},[t("a",{staticClass:"header-anchor",attrs:{href:"#vector-data"}},[e._v("#")]),e._v(" Vector data")]),e._v(" "),t("p",[e._v("In general, "),t("strong",[e._v("vector data")]),e._v(' represent specific things (also called "features") in a space, e.g. on the surface of the Earth.')]),e._v(" "),t("p",[e._v("A "),t("strong",[e._v("coordinate")]),e._v(" represents a specific point in space.")]),e._v(" "),t("p",[e._v("A "),t("strong",[e._v("feature")]),e._v(' is a thing that usually has a geometry (e.g. the outline of an agricultural field, a forest or an urban area) and it may have additional properties assigned (e.g. a name, a color or a population).\nIn rare cases features may not have a geometry, which is often referred to as an "empty geometry".')]),e._v(" "),t("p",[t("strong",[e._v("Geometries")]),e._v(" consist of one or more coordinates that may be connected and then form a specific type of geometry, e.g. two points can be connected to a straight line and four straight lines can be connected to rectangle.")]),e._v(" "),t("p",[e._v("Commonly used types of geometries are:")]),e._v(" "),t("ul",[t("li",[e._v("Point")]),e._v(" "),t("li",[e._v("LineString (connected straight line pieces)")]),e._v(" "),t("li",[e._v("Polygon (connected straight line pieces forming a closed ring, possibly with holes - for example a triangle or rectangle)")])]),e._v(" "),t("p",[e._v('Multiple geometries of the same type can be combined into a group of geometries, e.g. a so-called "multi point" or "multi polygon".')]),e._v(" "),t("p",[e._v("Features and geometries are specified by the OGC in the "),t("a",{attrs:{href:"https://www.ogc.org/standards/sfa",target:"_blank",rel:"noopener noreferrer"}},[e._v("Simple Feature Access specification"),t("OutboundLink")],1),e._v(" (and ISO 19125). See the specification for more details.")]),e._v(" "),t("h2",{attrs:{id:"user-defined-function-udf"}},[t("a",{staticClass:"header-anchor",attrs:{href:"#user-defined-function-udf"}},[e._v("#")]),e._v(" User-defined function (UDF)")]),e._v(" "),t("p",[e._v("The abbreviation "),t("strong",[e._v("UDF")]),e._v(" stands for "),t("strong",[e._v("user-defined function")]),e._v(". With this concept, users are able to upload custom code and have it executed e.g. for every pixel of a scene, or applied to a particular dimension or set of dimensions, allowing custom server-side calculations. See the section on "),t("RouterLink",{attrs:{to:"/documentation/1.0/udfs.html"}},[e._v("UDFs")]),e._v(" for more information.")],1),e._v(" "),t("h2",{attrs:{id:"data-processing-modes"}},[t("a",{staticClass:"header-anchor",attrs:{href:"#data-processing-modes"}},[e._v("#")]),e._v(" Data Processing modes")]),e._v(" "),t("p",[e._v("Processes can run in three different ways:")]),e._v(" "),t("ol",[t("li",[e._v("Results can be pre-computed by creating a "),t("em",[t("strong",[e._v("batch job")])]),e._v(". They are submitted to the back-end's processing system, but will remain inactive until explicitly put into the processing queue. They will run only once and store results after execution. Results can be downloaded. Batch jobs are typically time consuming and user interaction is not possible although log files are generated for them. This is the only mode that allows to get an estimate about time, volume and costs beforehand.")]),e._v(" "),t("li",[e._v("A more dynamic way of processing and accessing data is to create a "),t("strong",[e._v("secondary web service")]),e._v(". They allow web-based access using different protocols such as "),t("a",{attrs:{href:"http://www.opengeospatial.org/standards/wms",target:"_blank",rel:"noopener noreferrer"}},[e._v("OGC WMS"),t("OutboundLink")],1),e._v(" (Open Geospatial Consortium Web Map Service), "),t("a",{attrs:{href:"http://www.opengeospatial.org/standards/wcs",target:"_blank",rel:"noopener noreferrer"}},[e._v("OGC WCS"),t("OutboundLink")],1),e._v(" (Web Coverage Service) or "),t("a",{attrs:{href:"https://wiki.openstreetmap.org/wiki/Slippy_map_tilenames",target:"_blank",rel:"noopener noreferrer"}},[e._v("XYZ tiles"),t("OutboundLink")],1),e._v(". These protocols usually allow users to change the viewing extent or level of detail (zoom level). Therefore, computations often run "),t("em",[e._v("on demand")]),e._v(" so that the requested data is calculated during the request. Back-ends should make sure to cache processed data to avoid additional/high costs and reduce waiting times for the user.")]),e._v(" "),t("li",[e._v("Processes can also be executed "),t("strong",[e._v("on-demand")]),e._v(" (i.e. synchronously). Results are delivered with the request itself and no job is created. Only lightweight computations, for example previews, should be executed using this approach as timeouts are to be expected for "),t("a",{attrs:{href:"https://www.pubnub.com/blog/2014-12-01-http-long-polling/",target:"_blank",rel:"noopener noreferrer"}},[e._v("long-polling HTTP requests"),t("OutboundLink")],1),e._v(".")])])])}),[],!1,null,null,null);t.default=r.exports}}]); \ No newline at end of file diff --git a/assets/js/85.287bcd71.js b/assets/js/85.0ed84483.js similarity index 79% rename from assets/js/85.287bcd71.js rename to assets/js/85.0ed84483.js index d38538354..e7de704a7 100644 --- a/assets/js/85.287bcd71.js +++ b/assets/js/85.0ed84483.js @@ -1 +1 @@ -(window.webpackJsonp=window.webpackJsonp||[]).push([[85],{530:function(t,s,e){"use strict";e.r(s);var n=e(4),o=Object(n.a)({},(function(){var t=this._self._c;return t("ContentSlotsDistributor",{attrs:{"slot-key":this.$parent.slotKey}},[t("ProcessesSpec")],1)}),[],!1,null,null,null);s.default=o.exports}}]); \ No newline at end of file +(window.webpackJsonp=window.webpackJsonp||[]).push([[85],{528:function(t,s,e){"use strict";e.r(s);var n=e(4),o=Object(n.a)({},(function(){var t=this._self._c;return t("ContentSlotsDistributor",{attrs:{"slot-key":this.$parent.slotKey}},[t("ProcessesSpec")],1)}),[],!1,null,null,null);s.default=o.exports}}]); \ No newline at end of file diff --git a/assets/js/86.888a3275.js b/assets/js/86.de66f566.js similarity index 99% rename from assets/js/86.888a3275.js rename to assets/js/86.de66f566.js index 641b30400..0d4c91e49 100644 --- a/assets/js/86.888a3275.js +++ b/assets/js/86.de66f566.js @@ -1 +1 @@ -(window.webpackJsonp=window.webpackJsonp||[]).push([[86],{531:function(t,a,s){"use strict";s.r(a);var e=s(4),n=Object(e.a)({},(function(){var t=this,a=t._self._c;return a("ContentSlotsDistributor",{attrs:{"slot-key":t.$parent.slotKey}},[a("h1",{attrs:{id:"get-started-with-the-openeo-python-client-client-side-processing"}},[a("a",{staticClass:"header-anchor",attrs:{href:"#get-started-with-the-openeo-python-client-client-side-processing"}},[t._v("#")]),t._v(" Get started with the openEO Python Client Client Side Processing")]),t._v(" "),a("h2",{attrs:{id:"background"}},[a("a",{staticClass:"header-anchor",attrs:{href:"#background"}},[t._v("#")]),t._v(" Background")]),t._v(" "),a("p",[t._v("The client-side processing functionality allows to test and use openEO with its processes locally, i.e. without any connection to an openEO back-end.\nIt relies on the projects "),a("a",{attrs:{href:"https://github.com/Open-EO/openeo-pg-parser-networkx%3E",target:"_blank",rel:"noopener noreferrer"}},[t._v("openeo-pg-parser-networkx"),a("OutboundLink")],1),t._v(", which provides an openEO process graph parsing tool, and "),a("a",{attrs:{href:"https://github.com/Open-EO/openeo-processes-dask",target:"_blank",rel:"noopener noreferrer"}},[t._v("openeo-processes-dask"),a("OutboundLink")],1),t._v(", which provides an Xarray and Dask implementation of most openEO processes.")]),t._v(" "),a("h2",{attrs:{id:"installation"}},[a("a",{staticClass:"header-anchor",attrs:{href:"#installation"}},[t._v("#")]),t._v(" Installation")]),t._v(" "),a("div",{staticClass:"custom-block warning"},[a("p",{staticClass:"custom-block-title"},[t._v("Important")]),t._v(" "),a("p",[t._v("This feature requires "),a("code",[t._v("Python>=3.9")]),t._v(".")])]),t._v(" "),a("p",[t._v("The openEO Python client library can easily be installed with a tool like "),a("code",[t._v("pip")]),t._v(", for example:")]),t._v(" "),a("div",{staticClass:"language-shell script extra-class"},[a("pre",{pre:!0,attrs:{class:"language-shell"}},[a("code",[t._v("pip "),a("span",{pre:!0,attrs:{class:"token function"}},[t._v("install")]),t._v(" openeo"),a("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),t._v("localprocessing"),a("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),t._v("\n")])])]),a("h2",{attrs:{id:"usage"}},[a("a",{staticClass:"header-anchor",attrs:{href:"#usage"}},[t._v("#")]),t._v(" Usage")]),t._v(" "),a("p",[t._v("Every openEO process graph relies on data which is typically provided by a cloud infrastructure (the openEO back-end).\nThe client-side processing adds the possibility to read and use local netCDFs, geoTIFFs, ZARR files, and remote STAC Collections or Items for your experiments.")]),t._v(" "),a("h3",{attrs:{id:"stac-collections-and-items"}},[a("a",{staticClass:"header-anchor",attrs:{href:"#stac-collections-and-items"}},[t._v("#")]),t._v(" STAC Collections and Items")]),t._v(" "),a("div",{staticClass:"custom-block warning"},[a("p",{staticClass:"custom-block-title"},[t._v("Important")]),t._v(" "),a("p",[t._v("The provided examples using STAC rely on third party STAC Catalogs, we can't guarantee that the urls will remain valid.")])]),t._v(" "),a("p",[t._v("With the "),a("code",[t._v("load_stac")]),t._v(" process it's possible to load and use data provided by remote or local STAC Collections or Items.\nThe following code snippet loads Sentinel-2 L2A data from a public STAC Catalog, using specific spatial and temporal extent, band name and also properties for cloud coverage.")]),t._v(" "),a("div",{staticClass:"language-python extra-class"},[a("pre",{pre:!0,attrs:{class:"language-python"}},[a("code",[a("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("from")]),t._v(" openeo"),a("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),t._v("local "),a("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("import")]),t._v(" LocalConnection\nlocal_conn "),a("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" LocalConnection"),a("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),a("span",{pre:!0,attrs:{class:"token string"}},[t._v('"./"')]),a("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n\nurl "),a("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),a("span",{pre:!0,attrs:{class:"token string"}},[t._v('"https://earth-search.aws.element84.com/v1/collections/sentinel-2-l2a"')]),t._v("\nspatial_extent "),a("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),a("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("{")]),a("span",{pre:!0,attrs:{class:"token string"}},[t._v('"west"')]),a("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(":")]),t._v(" "),a("span",{pre:!0,attrs:{class:"token number"}},[t._v("11")]),a("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),a("span",{pre:!0,attrs:{class:"token string"}},[t._v('"east"')]),a("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(":")]),t._v(" "),a("span",{pre:!0,attrs:{class:"token number"}},[t._v("12")]),a("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),a("span",{pre:!0,attrs:{class:"token string"}},[t._v('"south"')]),a("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(":")]),t._v(" "),a("span",{pre:!0,attrs:{class:"token number"}},[t._v("46")]),a("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),a("span",{pre:!0,attrs:{class:"token string"}},[t._v('"north"')]),a("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(":")]),t._v(" "),a("span",{pre:!0,attrs:{class:"token number"}},[t._v("47")]),a("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("}")]),t._v("\ntemporal_extent "),a("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),a("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),a("span",{pre:!0,attrs:{class:"token string"}},[t._v('"2019-01-01"')]),a("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),a("span",{pre:!0,attrs:{class:"token string"}},[t._v('"2019-06-15"')]),a("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),t._v("\nbands "),a("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),a("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),a("span",{pre:!0,attrs:{class:"token string"}},[t._v('"red"')]),a("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),t._v("\nproperties "),a("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),a("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("{")]),a("span",{pre:!0,attrs:{class:"token string"}},[t._v('"eo:cloud_cover"')]),a("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(":")]),t._v(" "),a("span",{pre:!0,attrs:{class:"token builtin"}},[t._v("dict")]),a("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("lt"),a("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),a("span",{pre:!0,attrs:{class:"token number"}},[t._v("50")]),a("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),a("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("}")]),t._v("\ns2_cube "),a("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" local_conn"),a("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),t._v("load_stac"),a("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("url"),a("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v("url"),a("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n spatial_extent"),a("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v("spatial_extent"),a("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n temporal_extent"),a("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v("temporal_extent"),a("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n bands"),a("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v("bands"),a("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n properties"),a("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v("properties"),a("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n"),a("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\ns2_cube"),a("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),t._v("execute"),a("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),a("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n")])])]),a("p",[t._v("When calling the "),a("code",[t._v(".execute()")]),t._v(" method on a "),a("code",[t._v("Datacube")]),t._v(" created from a "),a("code",[t._v("LocalConnection")]),t._v(", an "),a("code",[t._v("xarray.DataArray")]),t._v(" object containing dask arrays is returned:")]),t._v(" "),a("div",{staticClass:"language- extra-class"},[a("pre",{pre:!0,attrs:{class:"language-text"}},[a("code",[t._v(" >>> s2_cube.execute()\n \n dask.array\n Coordinates: (12/53)\n * time (time) datetime64[ns] 2019-01-02...\n id (time) >> # Check if the data is loaded correctly\n>>> s2_datacube.execute()\n\ndask.array\nCoordinates:\n * t (t) datetime64[ns] 2022-06-02 2022-06-05 ... 2022-06-27 2022-06-30\n * x (x) float64 6.75e+05 6.75e+05 6.75e+05 ... 6.843e+05 6.843e+05\n * y (y) float64 5.155e+06 5.155e+06 5.155e+06 ... 5.148e+06 5.148e+06\n crs |S1 ...\n * bands (bands) object 'B04' 'B03' 'B02' 'B08' 'SCL'\nAttributes:\n Conventions: CF-1.9\n institution: openEO platform - Geotrellis backend: 0.9.5a1\n description:\n title:\n")])])]),a("p",[t._v("As you can see in the previous example, we are using a call to "),a("code",[t._v(".execute()")]),t._v(" which will execute locally the generated openEO process graph.\nIn this case, the process graph consist only in a single "),a("code",[t._v("load_collection")]),t._v(", which performs lazy loading of the data. With this first step you can check if the data is being read correctly by openEO.")]),t._v(" "),a("p",[t._v("Looking at the metadata of this netCDF sample, we can see that it contains the bands B04, B03, B02, B08 and SCL.\nAdditionally, we also see that it is composed by more than one element in time and that it covers the month of June 2022.")]),t._v(" "),a("p",[t._v("We can now do a simple processing for demo purposes, let's compute the median NDVI in time and visualize the result:")]),t._v(" "),a("div",{staticClass:"language-python extra-class"},[a("pre",{pre:!0,attrs:{class:"language-python"}},[a("code",[t._v("b04 "),a("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" s2_datacube"),a("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),t._v("band"),a("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),a("span",{pre:!0,attrs:{class:"token string"}},[t._v('"B04"')]),a("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\nb08 "),a("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" s2_datacube"),a("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),t._v("band"),a("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),a("span",{pre:!0,attrs:{class:"token string"}},[t._v('"B08"')]),a("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\nndvi "),a("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),a("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("b08 "),a("span",{pre:!0,attrs:{class:"token operator"}},[t._v("-")]),t._v(" b04"),a("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v(" "),a("span",{pre:!0,attrs:{class:"token operator"}},[t._v("/")]),t._v(" "),a("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("b08 "),a("span",{pre:!0,attrs:{class:"token operator"}},[t._v("+")]),t._v(" b04"),a("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\nndvi_median "),a("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" ndvi"),a("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),t._v("reduce_dimension"),a("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("dimension"),a("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),a("span",{pre:!0,attrs:{class:"token string"}},[t._v('"t"')]),a("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" reducer"),a("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),a("span",{pre:!0,attrs:{class:"token string"}},[t._v('"median"')]),a("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\nresult_ndvi "),a("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" ndvi_median"),a("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),t._v("execute"),a("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),a("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\nresult_ndvi"),a("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),t._v("plot"),a("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),t._v("imshow"),a("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("cmap"),a("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),a("span",{pre:!0,attrs:{class:"token string"}},[t._v('"Greens"')]),a("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n")])])]),a("p",[t._v("We can perform the same example using data provided by STAC Collection:")]),t._v(" "),a("div",{staticClass:"language-python extra-class"},[a("pre",{pre:!0,attrs:{class:"language-python"}},[a("code",[a("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("from")]),t._v(" openeo"),a("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),t._v("local "),a("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("import")]),t._v(" LocalConnection\nlocal_conn "),a("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" LocalConnection"),a("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),a("span",{pre:!0,attrs:{class:"token string"}},[t._v('"./"')]),a("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n\nurl "),a("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),a("span",{pre:!0,attrs:{class:"token string"}},[t._v('"https://earth-search.aws.element84.com/v1/collections/sentinel-2-l2a"')]),t._v("\nspatial_extent "),a("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),a("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("{")]),a("span",{pre:!0,attrs:{class:"token string"}},[t._v('"east"')]),a("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(":")]),t._v(" "),a("span",{pre:!0,attrs:{class:"token number"}},[t._v("11.40")]),a("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),a("span",{pre:!0,attrs:{class:"token string"}},[t._v('"north"')]),a("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(":")]),t._v(" "),a("span",{pre:!0,attrs:{class:"token number"}},[t._v("46.52")]),a("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),a("span",{pre:!0,attrs:{class:"token string"}},[t._v('"south"')]),a("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(":")]),t._v(" "),a("span",{pre:!0,attrs:{class:"token number"}},[t._v("46.46")]),a("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),a("span",{pre:!0,attrs:{class:"token string"}},[t._v('"west"')]),a("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(":")]),t._v(" "),a("span",{pre:!0,attrs:{class:"token number"}},[t._v("11.25")]),a("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("}")]),t._v("\ntemporal_extent "),a("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),a("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),a("span",{pre:!0,attrs:{class:"token string"}},[t._v('"2022-06-01"')]),a("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),a("span",{pre:!0,attrs:{class:"token string"}},[t._v('"2022-06-30"')]),a("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),t._v("\nbands "),a("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),a("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),a("span",{pre:!0,attrs:{class:"token string"}},[t._v('"red"')]),a("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),a("span",{pre:!0,attrs:{class:"token string"}},[t._v('"nir"')]),a("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),t._v("\nproperties "),a("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),a("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("{")]),a("span",{pre:!0,attrs:{class:"token string"}},[t._v('"eo:cloud_cover"')]),a("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(":")]),t._v(" "),a("span",{pre:!0,attrs:{class:"token builtin"}},[t._v("dict")]),a("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("lt"),a("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),a("span",{pre:!0,attrs:{class:"token number"}},[t._v("80")]),a("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),a("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("}")]),t._v("\ns2_datacube "),a("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" local_conn"),a("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),t._v("load_stac"),a("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("\n url"),a("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v("url"),a("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n spatial_extent"),a("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v("spatial_extent"),a("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n temporal_extent"),a("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v("temporal_extent"),a("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n bands"),a("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v("bands"),a("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n properties"),a("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v("properties"),a("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n"),a("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n\nb04 "),a("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" s2_datacube"),a("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),t._v("band"),a("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),a("span",{pre:!0,attrs:{class:"token string"}},[t._v('"red"')]),a("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\nb08 "),a("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" s2_datacube"),a("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),t._v("band"),a("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),a("span",{pre:!0,attrs:{class:"token string"}},[t._v('"nir"')]),a("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\nndvi "),a("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),a("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("b08 "),a("span",{pre:!0,attrs:{class:"token operator"}},[t._v("-")]),t._v(" b04"),a("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v(" "),a("span",{pre:!0,attrs:{class:"token operator"}},[t._v("/")]),t._v(" "),a("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("b08 "),a("span",{pre:!0,attrs:{class:"token operator"}},[t._v("+")]),t._v(" b04"),a("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\nndvi_median "),a("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" ndvi"),a("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),t._v("reduce_dimension"),a("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("dimension"),a("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),a("span",{pre:!0,attrs:{class:"token string"}},[t._v('"time"')]),a("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" reducer"),a("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),a("span",{pre:!0,attrs:{class:"token string"}},[t._v('"median"')]),a("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\nresult_ndvi "),a("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" ndvi_median"),a("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),t._v("execute"),a("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),a("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n")])])]),a("h2",{attrs:{id:"client-side-processing-example-notebooks"}},[a("a",{staticClass:"header-anchor",attrs:{href:"#client-side-processing-example-notebooks"}},[t._v("#")]),t._v(" Client-Side Processing Example Notebooks")]),t._v(" "),a("ul",[a("li",[a("a",{attrs:{href:"https://github.com/Open-EO/openeo-python-client/tree/master/examples/notebooks/Client_Side_Processing",target:"_blank",rel:"noopener noreferrer"}},[t._v("From the openEO Python Client repo"),a("OutboundLink")],1)]),t._v(" "),a("li",[a("a",{attrs:{href:"https://github.com/EO-College/cubes-and-clouds/blob/main/lectures/3.1_data_processing/exercises/_alternatives/31_data_processing_stac.ipynb",target:"_blank",rel:"noopener noreferrer"}},[t._v("From the Cubes and Clouds repo"),a("OutboundLink")],1)])]),t._v(" "),a("h2",{attrs:{id:"additional-information"}},[a("a",{staticClass:"header-anchor",attrs:{href:"#additional-information"}},[t._v("#")]),t._v(" Additional Information")]),t._v(" "),a("p",[t._v("Additional information and resources about the openEO Python Client Library:")]),t._v(" "),a("ul",[a("li",[a("a",{attrs:{href:"https://open-eo.github.io/openeo-python-client/",target:"_blank",rel:"noopener noreferrer"}},[t._v("Official openEO Python Client Library Documentation"),a("OutboundLink")],1)]),t._v(" "),a("li",[a("a",{attrs:{href:"https://github.com/Open-EO/openeo-python-client/tree/master/examples",target:"_blank",rel:"noopener noreferrer"}},[t._v("Example Python scripts"),a("OutboundLink")],1)]),t._v(" "),a("li",[a("a",{attrs:{href:"https://github.com/Open-EO/openeo-python-client/tree/master/examples/notebooks",target:"_blank",rel:"noopener noreferrer"}},[t._v("Example Jupyter Notebooks"),a("OutboundLink")],1)]),t._v(" "),a("li",[a("a",{attrs:{href:"https://github.com/Open-EO/openeo-python-client",target:"_blank",rel:"noopener noreferrer"}},[t._v("Repository on GitHub"),a("OutboundLink")],1)])])])}),[],!1,null,null,null);a.default=n.exports}}]); \ No newline at end of file +(window.webpackJsonp=window.webpackJsonp||[]).push([[86],{529:function(t,a,s){"use strict";s.r(a);var e=s(4),n=Object(e.a)({},(function(){var t=this,a=t._self._c;return a("ContentSlotsDistributor",{attrs:{"slot-key":t.$parent.slotKey}},[a("h1",{attrs:{id:"get-started-with-the-openeo-python-client-client-side-processing"}},[a("a",{staticClass:"header-anchor",attrs:{href:"#get-started-with-the-openeo-python-client-client-side-processing"}},[t._v("#")]),t._v(" Get started with the openEO Python Client Client Side Processing")]),t._v(" "),a("h2",{attrs:{id:"background"}},[a("a",{staticClass:"header-anchor",attrs:{href:"#background"}},[t._v("#")]),t._v(" Background")]),t._v(" "),a("p",[t._v("The client-side processing functionality allows to test and use openEO with its processes locally, i.e. without any connection to an openEO back-end.\nIt relies on the projects "),a("a",{attrs:{href:"https://github.com/Open-EO/openeo-pg-parser-networkx%3E",target:"_blank",rel:"noopener noreferrer"}},[t._v("openeo-pg-parser-networkx"),a("OutboundLink")],1),t._v(", which provides an openEO process graph parsing tool, and "),a("a",{attrs:{href:"https://github.com/Open-EO/openeo-processes-dask",target:"_blank",rel:"noopener noreferrer"}},[t._v("openeo-processes-dask"),a("OutboundLink")],1),t._v(", which provides an Xarray and Dask implementation of most openEO processes.")]),t._v(" "),a("h2",{attrs:{id:"installation"}},[a("a",{staticClass:"header-anchor",attrs:{href:"#installation"}},[t._v("#")]),t._v(" Installation")]),t._v(" "),a("div",{staticClass:"custom-block warning"},[a("p",{staticClass:"custom-block-title"},[t._v("Important")]),t._v(" "),a("p",[t._v("This feature requires "),a("code",[t._v("Python>=3.9")]),t._v(".")])]),t._v(" "),a("p",[t._v("The openEO Python client library can easily be installed with a tool like "),a("code",[t._v("pip")]),t._v(", for example:")]),t._v(" "),a("div",{staticClass:"language-shell script extra-class"},[a("pre",{pre:!0,attrs:{class:"language-shell"}},[a("code",[t._v("pip "),a("span",{pre:!0,attrs:{class:"token function"}},[t._v("install")]),t._v(" openeo"),a("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),t._v("localprocessing"),a("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),t._v("\n")])])]),a("h2",{attrs:{id:"usage"}},[a("a",{staticClass:"header-anchor",attrs:{href:"#usage"}},[t._v("#")]),t._v(" Usage")]),t._v(" "),a("p",[t._v("Every openEO process graph relies on data which is typically provided by a cloud infrastructure (the openEO back-end).\nThe client-side processing adds the possibility to read and use local netCDFs, geoTIFFs, ZARR files, and remote STAC Collections or Items for your experiments.")]),t._v(" "),a("h3",{attrs:{id:"stac-collections-and-items"}},[a("a",{staticClass:"header-anchor",attrs:{href:"#stac-collections-and-items"}},[t._v("#")]),t._v(" STAC Collections and Items")]),t._v(" "),a("div",{staticClass:"custom-block warning"},[a("p",{staticClass:"custom-block-title"},[t._v("Important")]),t._v(" "),a("p",[t._v("The provided examples using STAC rely on third party STAC Catalogs, we can't guarantee that the urls will remain valid.")])]),t._v(" "),a("p",[t._v("With the "),a("code",[t._v("load_stac")]),t._v(" process it's possible to load and use data provided by remote or local STAC Collections or Items.\nThe following code snippet loads Sentinel-2 L2A data from a public STAC Catalog, using specific spatial and temporal extent, band name and also properties for cloud coverage.")]),t._v(" "),a("div",{staticClass:"language-python extra-class"},[a("pre",{pre:!0,attrs:{class:"language-python"}},[a("code",[a("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("from")]),t._v(" openeo"),a("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),t._v("local "),a("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("import")]),t._v(" LocalConnection\nlocal_conn "),a("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" LocalConnection"),a("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),a("span",{pre:!0,attrs:{class:"token string"}},[t._v('"./"')]),a("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n\nurl "),a("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),a("span",{pre:!0,attrs:{class:"token string"}},[t._v('"https://earth-search.aws.element84.com/v1/collections/sentinel-2-l2a"')]),t._v("\nspatial_extent "),a("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),a("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("{")]),a("span",{pre:!0,attrs:{class:"token string"}},[t._v('"west"')]),a("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(":")]),t._v(" "),a("span",{pre:!0,attrs:{class:"token number"}},[t._v("11")]),a("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),a("span",{pre:!0,attrs:{class:"token string"}},[t._v('"east"')]),a("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(":")]),t._v(" "),a("span",{pre:!0,attrs:{class:"token number"}},[t._v("12")]),a("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),a("span",{pre:!0,attrs:{class:"token string"}},[t._v('"south"')]),a("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(":")]),t._v(" "),a("span",{pre:!0,attrs:{class:"token number"}},[t._v("46")]),a("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),a("span",{pre:!0,attrs:{class:"token string"}},[t._v('"north"')]),a("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(":")]),t._v(" "),a("span",{pre:!0,attrs:{class:"token number"}},[t._v("47")]),a("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("}")]),t._v("\ntemporal_extent "),a("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),a("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),a("span",{pre:!0,attrs:{class:"token string"}},[t._v('"2019-01-01"')]),a("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),a("span",{pre:!0,attrs:{class:"token string"}},[t._v('"2019-06-15"')]),a("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),t._v("\nbands "),a("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),a("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),a("span",{pre:!0,attrs:{class:"token string"}},[t._v('"red"')]),a("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),t._v("\nproperties "),a("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),a("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("{")]),a("span",{pre:!0,attrs:{class:"token string"}},[t._v('"eo:cloud_cover"')]),a("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(":")]),t._v(" "),a("span",{pre:!0,attrs:{class:"token builtin"}},[t._v("dict")]),a("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("lt"),a("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),a("span",{pre:!0,attrs:{class:"token number"}},[t._v("50")]),a("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),a("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("}")]),t._v("\ns2_cube "),a("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" local_conn"),a("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),t._v("load_stac"),a("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("url"),a("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v("url"),a("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n spatial_extent"),a("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v("spatial_extent"),a("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n temporal_extent"),a("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v("temporal_extent"),a("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n bands"),a("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v("bands"),a("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n properties"),a("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v("properties"),a("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n"),a("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\ns2_cube"),a("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),t._v("execute"),a("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),a("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n")])])]),a("p",[t._v("When calling the "),a("code",[t._v(".execute()")]),t._v(" method on a "),a("code",[t._v("Datacube")]),t._v(" created from a "),a("code",[t._v("LocalConnection")]),t._v(", an "),a("code",[t._v("xarray.DataArray")]),t._v(" object containing dask arrays is returned:")]),t._v(" "),a("div",{staticClass:"language- extra-class"},[a("pre",{pre:!0,attrs:{class:"language-text"}},[a("code",[t._v(" >>> s2_cube.execute()\n \n dask.array\n Coordinates: (12/53)\n * time (time) datetime64[ns] 2019-01-02...\n id (time) >> # Check if the data is loaded correctly\n>>> s2_datacube.execute()\n\ndask.array\nCoordinates:\n * t (t) datetime64[ns] 2022-06-02 2022-06-05 ... 2022-06-27 2022-06-30\n * x (x) float64 6.75e+05 6.75e+05 6.75e+05 ... 6.843e+05 6.843e+05\n * y (y) float64 5.155e+06 5.155e+06 5.155e+06 ... 5.148e+06 5.148e+06\n crs |S1 ...\n * bands (bands) object 'B04' 'B03' 'B02' 'B08' 'SCL'\nAttributes:\n Conventions: CF-1.9\n institution: openEO platform - Geotrellis backend: 0.9.5a1\n description:\n title:\n")])])]),a("p",[t._v("As you can see in the previous example, we are using a call to "),a("code",[t._v(".execute()")]),t._v(" which will execute locally the generated openEO process graph.\nIn this case, the process graph consist only in a single "),a("code",[t._v("load_collection")]),t._v(", which performs lazy loading of the data. With this first step you can check if the data is being read correctly by openEO.")]),t._v(" "),a("p",[t._v("Looking at the metadata of this netCDF sample, we can see that it contains the bands B04, B03, B02, B08 and SCL.\nAdditionally, we also see that it is composed by more than one element in time and that it covers the month of June 2022.")]),t._v(" "),a("p",[t._v("We can now do a simple processing for demo purposes, let's compute the median NDVI in time and visualize the result:")]),t._v(" "),a("div",{staticClass:"language-python extra-class"},[a("pre",{pre:!0,attrs:{class:"language-python"}},[a("code",[t._v("b04 "),a("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" s2_datacube"),a("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),t._v("band"),a("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),a("span",{pre:!0,attrs:{class:"token string"}},[t._v('"B04"')]),a("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\nb08 "),a("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" s2_datacube"),a("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),t._v("band"),a("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),a("span",{pre:!0,attrs:{class:"token string"}},[t._v('"B08"')]),a("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\nndvi "),a("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),a("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("b08 "),a("span",{pre:!0,attrs:{class:"token operator"}},[t._v("-")]),t._v(" b04"),a("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v(" "),a("span",{pre:!0,attrs:{class:"token operator"}},[t._v("/")]),t._v(" "),a("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("b08 "),a("span",{pre:!0,attrs:{class:"token operator"}},[t._v("+")]),t._v(" b04"),a("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\nndvi_median "),a("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" ndvi"),a("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),t._v("reduce_dimension"),a("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("dimension"),a("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),a("span",{pre:!0,attrs:{class:"token string"}},[t._v('"t"')]),a("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" reducer"),a("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),a("span",{pre:!0,attrs:{class:"token string"}},[t._v('"median"')]),a("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\nresult_ndvi "),a("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" ndvi_median"),a("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),t._v("execute"),a("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),a("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\nresult_ndvi"),a("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),t._v("plot"),a("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),t._v("imshow"),a("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("cmap"),a("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),a("span",{pre:!0,attrs:{class:"token string"}},[t._v('"Greens"')]),a("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n")])])]),a("p",[t._v("We can perform the same example using data provided by STAC Collection:")]),t._v(" "),a("div",{staticClass:"language-python extra-class"},[a("pre",{pre:!0,attrs:{class:"language-python"}},[a("code",[a("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("from")]),t._v(" openeo"),a("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),t._v("local "),a("span",{pre:!0,attrs:{class:"token keyword"}},[t._v("import")]),t._v(" LocalConnection\nlocal_conn "),a("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" LocalConnection"),a("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),a("span",{pre:!0,attrs:{class:"token string"}},[t._v('"./"')]),a("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n\nurl "),a("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),a("span",{pre:!0,attrs:{class:"token string"}},[t._v('"https://earth-search.aws.element84.com/v1/collections/sentinel-2-l2a"')]),t._v("\nspatial_extent "),a("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),a("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("{")]),a("span",{pre:!0,attrs:{class:"token string"}},[t._v('"east"')]),a("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(":")]),t._v(" "),a("span",{pre:!0,attrs:{class:"token number"}},[t._v("11.40")]),a("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),a("span",{pre:!0,attrs:{class:"token string"}},[t._v('"north"')]),a("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(":")]),t._v(" "),a("span",{pre:!0,attrs:{class:"token number"}},[t._v("46.52")]),a("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),a("span",{pre:!0,attrs:{class:"token string"}},[t._v('"south"')]),a("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(":")]),t._v(" "),a("span",{pre:!0,attrs:{class:"token number"}},[t._v("46.46")]),a("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),a("span",{pre:!0,attrs:{class:"token string"}},[t._v('"west"')]),a("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(":")]),t._v(" "),a("span",{pre:!0,attrs:{class:"token number"}},[t._v("11.25")]),a("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("}")]),t._v("\ntemporal_extent "),a("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),a("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),a("span",{pre:!0,attrs:{class:"token string"}},[t._v('"2022-06-01"')]),a("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),a("span",{pre:!0,attrs:{class:"token string"}},[t._v('"2022-06-30"')]),a("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),t._v("\nbands "),a("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),a("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("[")]),a("span",{pre:!0,attrs:{class:"token string"}},[t._v('"red"')]),a("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" "),a("span",{pre:!0,attrs:{class:"token string"}},[t._v('"nir"')]),a("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("]")]),t._v("\nproperties "),a("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),a("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("{")]),a("span",{pre:!0,attrs:{class:"token string"}},[t._v('"eo:cloud_cover"')]),a("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(":")]),t._v(" "),a("span",{pre:!0,attrs:{class:"token builtin"}},[t._v("dict")]),a("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("lt"),a("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),a("span",{pre:!0,attrs:{class:"token number"}},[t._v("80")]),a("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),a("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("}")]),t._v("\ns2_datacube "),a("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" local_conn"),a("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),t._v("load_stac"),a("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("\n url"),a("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v("url"),a("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n spatial_extent"),a("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v("spatial_extent"),a("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n temporal_extent"),a("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v("temporal_extent"),a("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n bands"),a("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v("bands"),a("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n properties"),a("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v("properties"),a("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v("\n"),a("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n\nb04 "),a("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" s2_datacube"),a("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),t._v("band"),a("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),a("span",{pre:!0,attrs:{class:"token string"}},[t._v('"red"')]),a("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\nb08 "),a("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" s2_datacube"),a("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),t._v("band"),a("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),a("span",{pre:!0,attrs:{class:"token string"}},[t._v('"nir"')]),a("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\nndvi "),a("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" "),a("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("b08 "),a("span",{pre:!0,attrs:{class:"token operator"}},[t._v("-")]),t._v(" b04"),a("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v(" "),a("span",{pre:!0,attrs:{class:"token operator"}},[t._v("/")]),t._v(" "),a("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("b08 "),a("span",{pre:!0,attrs:{class:"token operator"}},[t._v("+")]),t._v(" b04"),a("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\nndvi_median "),a("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" ndvi"),a("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),t._v("reduce_dimension"),a("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),t._v("dimension"),a("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),a("span",{pre:!0,attrs:{class:"token string"}},[t._v('"time"')]),a("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(",")]),t._v(" reducer"),a("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),a("span",{pre:!0,attrs:{class:"token string"}},[t._v('"median"')]),a("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\nresult_ndvi "),a("span",{pre:!0,attrs:{class:"token operator"}},[t._v("=")]),t._v(" ndvi_median"),a("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(".")]),t._v("execute"),a("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v("(")]),a("span",{pre:!0,attrs:{class:"token punctuation"}},[t._v(")")]),t._v("\n")])])]),a("h2",{attrs:{id:"client-side-processing-example-notebooks"}},[a("a",{staticClass:"header-anchor",attrs:{href:"#client-side-processing-example-notebooks"}},[t._v("#")]),t._v(" Client-Side Processing Example Notebooks")]),t._v(" "),a("ul",[a("li",[a("a",{attrs:{href:"https://github.com/Open-EO/openeo-python-client/tree/master/examples/notebooks/Client_Side_Processing",target:"_blank",rel:"noopener noreferrer"}},[t._v("From the openEO Python Client repo"),a("OutboundLink")],1)]),t._v(" "),a("li",[a("a",{attrs:{href:"https://github.com/EO-College/cubes-and-clouds/blob/main/lectures/3.1_data_processing/exercises/_alternatives/31_data_processing_stac.ipynb",target:"_blank",rel:"noopener noreferrer"}},[t._v("From the Cubes and Clouds repo"),a("OutboundLink")],1)])]),t._v(" "),a("h2",{attrs:{id:"additional-information"}},[a("a",{staticClass:"header-anchor",attrs:{href:"#additional-information"}},[t._v("#")]),t._v(" Additional Information")]),t._v(" "),a("p",[t._v("Additional information and resources about the openEO Python Client Library:")]),t._v(" "),a("ul",[a("li",[a("a",{attrs:{href:"https://open-eo.github.io/openeo-python-client/",target:"_blank",rel:"noopener noreferrer"}},[t._v("Official openEO Python Client Library Documentation"),a("OutboundLink")],1)]),t._v(" "),a("li",[a("a",{attrs:{href:"https://github.com/Open-EO/openeo-python-client/tree/master/examples",target:"_blank",rel:"noopener noreferrer"}},[t._v("Example Python scripts"),a("OutboundLink")],1)]),t._v(" "),a("li",[a("a",{attrs:{href:"https://github.com/Open-EO/openeo-python-client/tree/master/examples/notebooks",target:"_blank",rel:"noopener noreferrer"}},[t._v("Example Jupyter Notebooks"),a("OutboundLink")],1)]),t._v(" "),a("li",[a("a",{attrs:{href:"https://github.com/Open-EO/openeo-python-client",target:"_blank",rel:"noopener noreferrer"}},[t._v("Repository on GitHub"),a("OutboundLink")],1)])])])}),[],!1,null,null,null);a.default=n.exports}}]); \ No newline at end of file diff --git a/assets/js/87.d0ccee79.js b/assets/js/87.ca238b9d.js similarity index 99% rename from assets/js/87.d0ccee79.js rename to assets/js/87.ca238b9d.js index dbdf48e48..45aeda13f 100644 --- a/assets/js/87.d0ccee79.js +++ b/assets/js/87.ca238b9d.js @@ -1 +1 @@ -(window.webpackJsonp=window.webpackJsonp||[]).push([[87],{535:function(e,t,s){"use strict";s.r(t);var n=s(4),a=Object(n.a)({},(function(){var e=this,t=e._self._c;return t("ContentSlotsDistributor",{attrs:{"slot-key":e.$parent.slotKey}},[t("h1",{attrs:{id:"user-defined-functions"}},[t("a",{staticClass:"header-anchor",attrs:{href:"#user-defined-functions"}},[e._v("#")]),e._v(" User-defined functions")]),e._v(" "),t("p",[e._v("The abbreviation "),t("strong",[e._v("UDF")]),e._v(" stands for "),t("strong",[e._v("user-defined function")]),e._v(". With this concept, users are able to upload custom code and have it executed e.g. for every pixel of a scene, allowing custom calculations on server-side data that are not (easily) covered with "),t("RouterLink",{attrs:{to:"/documentation/1.0/processes.html"}},[e._v("pre-defined processes")]),e._v(" or user-defined processes. While openEO UDFs are in principle language-agnostic, we currently implement UDFs for Python and R.")],1),e._v(" "),t("h2",{attrs:{id:"users"}},[t("a",{staticClass:"header-anchor",attrs:{href:"#users"}},[e._v("#")]),e._v(" Users")]),e._v(" "),t("p",[e._v("You can run UDFs with any client (including JavaScript and Web Editor), but the code you can execute on the server will be limited to Python and R.\nAll openEO clients allow to run UDFs via the pre-defined process "),t("RouterLink",{attrs:{to:"/documentation/1.0/processes.html#run_udf"}},[t("code",[e._v("run_udf")])]),e._v(" if the back-end implements UDFs. You can check the "),t("a",{attrs:{href:"https://hub.openeo.org",target:"_blank",rel:"noopener noreferrer"}},[e._v("openEO Hub"),t("OutboundLink")],1),e._v(" for back-ends that support user-defined functions. There's also "),t("RouterLink",{attrs:{to:"/documentation/1.0/processes.html#run_udf_externally"}},[t("code",[e._v("run_udf_externally")])]),e._v(" if you want to host UDFs yourself (see back-end instructions below), but the process is still experimental and not widely supported yet. If we refer to "),t("code",[e._v("run_udf")]),e._v(" below and the back-end supports it, you can also use "),t("code",[e._v("run_udf_externally")]),e._v(" without it being explicitly mentioned.")],1),e._v(" "),t("p",[e._v("As data cubes can be very large, the back-end may only be able to run your code on a smaller chunk of the whole cube. So you need to help the server a bit, by designing your code to work on smaller piece of data. This can be done by using data cube processes that run the UDF on smaller chunks of the data. There are a number of pre-defined processes that can run UDFs on such chunks, for example:")]),e._v(" "),t("ul",[t("li",[t("RouterLink",{attrs:{to:"/documentation/1.0/processes.html#aggregate_spatial"}},[t("code",[e._v("aggregate_spatial")])]),e._v(": Reduces pixels within geometries to a single value using an UDF")],1),e._v(" "),t("li",[t("RouterLink",{attrs:{to:"/documentation/1.0/processes.html#apply"}},[t("code",[e._v("apply")])]),e._v(": Applies an UDF to each pixel (it might also be slow to make the chunks too small though)")],1),e._v(" "),t("li",[t("RouterLink",{attrs:{to:"/documentation/1.0/processes.html#apply_dimension"}},[t("code",[e._v("apply_dimension")])]),e._v(": Applies an UDF to all pixels along a dimension, without changing the number of values")],1),e._v(" "),t("li",[t("RouterLink",{attrs:{to:"/documentation/1.0/processes.html#apply_neighborhood"}},[t("code",[e._v("apply_neighborhood")])]),e._v(": Applies an UDF to all pixels in a multidimensional neighborhood")],1),e._v(" "),t("li",[t("RouterLink",{attrs:{to:"/documentation/1.0/processes.html#merge_cubes"}},[t("code",[e._v("merge_cubes")])]),e._v(": Reduces overlapping pixels of the data cubes to a single value")],1),e._v(" "),t("li",[t("RouterLink",{attrs:{to:"/documentation/1.0/processes.html#reduce_dimension"}},[t("code",[e._v("reduce_dimension")])]),e._v(": Reduces values along a dimension using an UDF")],1)]),e._v(" "),t("p",[e._v("There are more processes that accept and run a sub-process. Each of them can also be used to run UDFs.")]),e._v(" "),t("div",{staticClass:"custom-block tip"},[t("p",{staticClass:"custom-block-title"},[e._v("Note")]),e._v(" "),t("p",[e._v("Not all functions will require you to write a UDF. For instance, if you want to take the absolute value of your data cube, you can simply "),t("RouterLink",{attrs:{to:"/documentation/1.0/processes.html#apply"}},[t("code",[e._v("apply")])]),e._v(" the predefined "),t("RouterLink",{attrs:{to:"/documentation/1.0/processes.html#absolute"}},[t("code",[e._v("absolute")])]),e._v(") process. In fact, it is recommended to try and use predefined functions first, as they can be more efficiently implemented.")],1)]),e._v(" "),t("p",[e._v("The following chapters have further information on UDF usage in the openEO clients:")]),e._v(" "),t("h3",{attrs:{id:"javascript"}},[t("a",{staticClass:"header-anchor",attrs:{href:"#javascript"}},[e._v("#")]),e._v(" JavaScript")]),e._v(" "),t("p",[e._v("The easiest way to run UDFs in the JavaScript client is to use the "),t("a",{attrs:{href:"https://open-eo.github.io/openeo-js-client/latest/Builder.html",target:"_blank",rel:"noopener noreferrer"}},[e._v("process builder"),t("OutboundLink")],1),e._v(". You can use the builder to execute the "),t("code",[e._v("run_udf")]),e._v(" process. A simple example:")]),e._v(" "),t("div",{staticClass:"language-javascript extra-class"},[t("pre",{pre:!0,attrs:{class:"language-javascript"}},[t("code",[t("span",{pre:!0,attrs:{class:"token comment"}},[e._v("// Connect to the back-end first and store the connection in the variable `con`...")]),e._v("\n\n"),t("span",{pre:!0,attrs:{class:"token comment"}},[e._v("// Discover UDF runtimes")]),e._v("\nconsole"),t("span",{pre:!0,attrs:{class:"token punctuation"}},[e._v(".")]),t("span",{pre:!0,attrs:{class:"token function"}},[e._v("log")]),t("span",{pre:!0,attrs:{class:"token punctuation"}},[e._v("(")]),t("span",{pre:!0,attrs:{class:"token keyword"}},[e._v("await")]),e._v(" con"),t("span",{pre:!0,attrs:{class:"token punctuation"}},[e._v(".")]),t("span",{pre:!0,attrs:{class:"token function"}},[e._v("listUdfRuntimes")]),t("span",{pre:!0,attrs:{class:"token punctuation"}},[e._v("(")]),t("span",{pre:!0,attrs:{class:"token punctuation"}},[e._v(")")]),t("span",{pre:!0,attrs:{class:"token punctuation"}},[e._v(")")]),t("span",{pre:!0,attrs:{class:"token punctuation"}},[e._v(";")]),e._v("\n\n"),t("span",{pre:!0,attrs:{class:"token comment"}},[e._v("// Upload a UDF file to the server as udf.py, the source can only be a local path in a NodeJS environment")]),e._v("\n"),t("span",{pre:!0,attrs:{class:"token keyword"}},[e._v("await")]),e._v(" con"),t("span",{pre:!0,attrs:{class:"token punctuation"}},[e._v(".")]),t("span",{pre:!0,attrs:{class:"token function"}},[e._v("uploadFile")]),t("span",{pre:!0,attrs:{class:"token punctuation"}},[e._v("(")]),t("span",{pre:!0,attrs:{class:"token string"}},[e._v("'/home/user/myudf.py'")]),t("span",{pre:!0,attrs:{class:"token punctuation"}},[e._v(",")]),e._v(" "),t("span",{pre:!0,attrs:{class:"token string"}},[e._v("'udf.py'")]),t("span",{pre:!0,attrs:{class:"token punctuation"}},[e._v(")")]),t("span",{pre:!0,attrs:{class:"token punctuation"}},[e._v(";")]),e._v("\n\n"),t("span",{pre:!0,attrs:{class:"token comment"}},[e._v("// Create a process builder")]),e._v("\n"),t("span",{pre:!0,attrs:{class:"token keyword"}},[e._v("var")]),e._v(" builder "),t("span",{pre:!0,attrs:{class:"token operator"}},[e._v("=")]),e._v(" "),t("span",{pre:!0,attrs:{class:"token keyword"}},[e._v("await")]),e._v(" con"),t("span",{pre:!0,attrs:{class:"token punctuation"}},[e._v(".")]),t("span",{pre:!0,attrs:{class:"token function"}},[e._v("buildProcess")]),t("span",{pre:!0,attrs:{class:"token punctuation"}},[e._v("(")]),t("span",{pre:!0,attrs:{class:"token punctuation"}},[e._v(")")]),t("span",{pre:!0,attrs:{class:"token punctuation"}},[e._v(";")]),e._v("\n\n"),t("span",{pre:!0,attrs:{class:"token comment"}},[e._v("// Load some data from the back-end")]),e._v("\n"),t("span",{pre:!0,attrs:{class:"token keyword"}},[e._v("var")]),e._v(" datacube "),t("span",{pre:!0,attrs:{class:"token operator"}},[e._v("=")]),e._v(" builder"),t("span",{pre:!0,attrs:{class:"token punctuation"}},[e._v(".")]),t("span",{pre:!0,attrs:{class:"token function"}},[e._v("load_collection")]),t("span",{pre:!0,attrs:{class:"token punctuation"}},[e._v("(")]),t("span",{pre:!0,attrs:{class:"token string"}},[e._v('"Sentinel-2"')]),t("span",{pre:!0,attrs:{class:"token punctuation"}},[e._v(",")]),e._v(" "),t("span",{pre:!0,attrs:{class:"token keyword"}},[e._v("null")]),t("span",{pre:!0,attrs:{class:"token punctuation"}},[e._v(",")]),e._v(" "),t("span",{pre:!0,attrs:{class:"token punctuation"}},[e._v("[")]),t("span",{pre:!0,attrs:{class:"token string"}},[e._v('"2018"')]),t("span",{pre:!0,attrs:{class:"token punctuation"}},[e._v(",")]),e._v(" "),t("span",{pre:!0,attrs:{class:"token string"}},[e._v('"2019"')]),t("span",{pre:!0,attrs:{class:"token punctuation"}},[e._v("]")]),t("span",{pre:!0,attrs:{class:"token punctuation"}},[e._v(")")]),t("span",{pre:!0,attrs:{class:"token punctuation"}},[e._v(";")]),e._v("\n\n"),t("span",{pre:!0,attrs:{class:"token comment"}},[e._v("// Create a sub-process that runs a UDF")]),e._v("\n"),t("span",{pre:!0,attrs:{class:"token keyword"}},[e._v("var")]),e._v(" "),t("span",{pre:!0,attrs:{class:"token function-variable function"}},[e._v("udfProcess")]),e._v(" "),t("span",{pre:!0,attrs:{class:"token operator"}},[e._v("=")]),e._v(" "),t("span",{pre:!0,attrs:{class:"token keyword"}},[e._v("function")]),t("span",{pre:!0,attrs:{class:"token punctuation"}},[e._v("(")]),t("span",{pre:!0,attrs:{class:"token parameter"}},[e._v("data")]),t("span",{pre:!0,attrs:{class:"token punctuation"}},[e._v(")")]),e._v(" "),t("span",{pre:!0,attrs:{class:"token punctuation"}},[e._v("{")]),e._v("\n\t"),t("span",{pre:!0,attrs:{class:"token comment"}},[e._v("// This assumes that a file udf.py with the Python UDF code has been uploaded to the server before, you can also directly insert the UDF code instead. ")]),e._v("\n\t"),t("span",{pre:!0,attrs:{class:"token comment"}},[e._v("// You need to replace `Python` and `3.7` with the respective runtime identifier and version as returned in UDF discovery")]),e._v("\n\t"),t("span",{pre:!0,attrs:{class:"token keyword"}},[e._v("return")]),e._v(" "),t("span",{pre:!0,attrs:{class:"token keyword"}},[e._v("this")]),t("span",{pre:!0,attrs:{class:"token punctuation"}},[e._v(".")]),t("span",{pre:!0,attrs:{class:"token function"}},[e._v("run_udf")]),t("span",{pre:!0,attrs:{class:"token punctuation"}},[e._v("(")]),e._v("data"),t("span",{pre:!0,attrs:{class:"token punctuation"}},[e._v(",")]),e._v(" "),t("span",{pre:!0,attrs:{class:"token string"}},[e._v('"udf.py"')]),t("span",{pre:!0,attrs:{class:"token punctuation"}},[e._v(",")]),e._v(" "),t("span",{pre:!0,attrs:{class:"token string"}},[e._v('"Python"')]),t("span",{pre:!0,attrs:{class:"token punctuation"}},[e._v(")")]),t("span",{pre:!0,attrs:{class:"token punctuation"}},[e._v(";")]),e._v("\n"),t("span",{pre:!0,attrs:{class:"token punctuation"}},[e._v("}")]),t("span",{pre:!0,attrs:{class:"token punctuation"}},[e._v(";")]),e._v("\n\n"),t("span",{pre:!0,attrs:{class:"token comment"}},[e._v("// Call the UDF as part of the reduce_dimension process to reduce the bands to a single value")]),e._v("\ndatacube "),t("span",{pre:!0,attrs:{class:"token operator"}},[e._v("=")]),e._v(" builder"),t("span",{pre:!0,attrs:{class:"token punctuation"}},[e._v(".")]),t("span",{pre:!0,attrs:{class:"token function"}},[e._v("reduce_dimension")]),t("span",{pre:!0,attrs:{class:"token punctuation"}},[e._v("(")]),e._v("datacube"),t("span",{pre:!0,attrs:{class:"token punctuation"}},[e._v(",")]),e._v(" udfProcess"),t("span",{pre:!0,attrs:{class:"token punctuation"}},[e._v(",")]),e._v(" "),t("span",{pre:!0,attrs:{class:"token string"}},[e._v('"bands"')]),t("span",{pre:!0,attrs:{class:"token punctuation"}},[e._v(")")]),t("span",{pre:!0,attrs:{class:"token punctuation"}},[e._v(";")]),e._v("\n\n"),t("span",{pre:!0,attrs:{class:"token comment"}},[e._v("// Further process the data cube or save it using save_result...")]),e._v("\n")])])]),t("h3",{attrs:{id:"python"}},[t("a",{staticClass:"header-anchor",attrs:{href:"#python"}},[e._v("#")]),e._v(" Python")]),e._v(" "),t("p",[e._v("The Python client has "),t("a",{attrs:{href:"https://open-eo.github.io/openeo-python-client/udf.html",target:"_blank",rel:"noopener noreferrer"}},[e._v("separate documentation on UDFs"),t("OutboundLink")],1),e._v(".")]),e._v(" "),t("h3",{attrs:{id:"qgis"}},[t("a",{staticClass:"header-anchor",attrs:{href:"#qgis"}},[e._v("#")]),e._v(" QGIS")]),e._v(" "),t("p",[e._v("QGIS doesn't natively support running UDFs yet, but you can use copy and paste user-defined processes that include UDFs.")]),e._v(" "),t("h3",{attrs:{id:"r"}},[t("a",{staticClass:"header-anchor",attrs:{href:"#r"}},[e._v("#")]),e._v(" R")]),e._v(" "),t("p",[e._v("There's no dedicated UDF documentation for R yet, but you can have a look at the "),t("a",{attrs:{href:"https://github.com/Open-EO/openeo-r-udf#usage",target:"_blank",rel:"noopener noreferrer"}},[e._v("getting started guide and examples in the UDF server repository"),t("OutboundLink")],1),e._v(" for now.")]),e._v(" "),t("h3",{attrs:{id:"web-editor"}},[t("a",{staticClass:"header-anchor",attrs:{href:"#web-editor"}},[e._v("#")]),e._v(" Web Editor")]),e._v(" "),t("p",[e._v("Running UDFs in the Web Editor just requires you to drag the "),t("code",[e._v("run_udf")]),e._v(" process into the model builder. Afterwards you can edit the process parameters to your needs. You have to set the environment / programming language to run the UDF with and then you can either directly program a UDF in the code editor or select an UDF file you have previously uploaded to the user workspace.")]),e._v(" "),t("h2",{attrs:{id:"back-ends"}},[t("a",{staticClass:"header-anchor",attrs:{href:"#back-ends"}},[e._v("#")]),e._v(" Back-ends")]),e._v(" "),t("p",[e._v("If you'd like to offer user-defined functions for your users, you need to implement either the process "),t("RouterLink",{attrs:{to:"/documentation/1.0/processes.html#run_udf"}},[t("code",[e._v("run_udf")])]),e._v(" or "),t("RouterLink",{attrs:{to:"/documentation/1.0/processes.html#run_udf_externally"}},[t("code",[e._v("run_udf_externally")])]),e._v(" (or both). Both usually require you to access UDF servers via the "),t("a",{attrs:{href:"https://open-eo.github.io/openeo-udf/api_docs/",target:"_blank",rel:"noopener noreferrer"}},[e._v("UDF API"),t("OutboundLink")],1),e._v(". For the process "),t("code",[e._v("run_udf")]),e._v(" you may bypass the API and exchange data directly between the openEO back-end and the openEO UDF servers for performance reasons.")],1),e._v(" "),t("p",[t("code",[e._v("run_udf")]),e._v(" allows users to run their code on your infrastructure. This can be done using one of the UDF server implementations in "),t("a",{attrs:{href:"https://github.com/Open-EO/openeo-udf",target:"_blank",rel:"noopener noreferrer"}},[e._v("Python"),t("OutboundLink")],1),e._v(" or "),t("a",{attrs:{href:"https://github.com/Open-EO/openeo-r-udf",target:"_blank",rel:"noopener noreferrer"}},[e._v("R"),t("OutboundLink")],1),e._v(". Please note that both UDF servers are "),t("strong",[e._v("drafts")]),e._v(" and still need work to improve performance and make them secure! This is not yet an out-of-the-box solution for running UDFs securely and fast.")])])}),[],!1,null,null,null);t.default=a.exports}}]); \ No newline at end of file +(window.webpackJsonp=window.webpackJsonp||[]).push([[87],{533:function(e,t,s){"use strict";s.r(t);var n=s(4),a=Object(n.a)({},(function(){var e=this,t=e._self._c;return t("ContentSlotsDistributor",{attrs:{"slot-key":e.$parent.slotKey}},[t("h1",{attrs:{id:"user-defined-functions"}},[t("a",{staticClass:"header-anchor",attrs:{href:"#user-defined-functions"}},[e._v("#")]),e._v(" User-defined functions")]),e._v(" "),t("p",[e._v("The abbreviation "),t("strong",[e._v("UDF")]),e._v(" stands for "),t("strong",[e._v("user-defined function")]),e._v(". With this concept, users are able to upload custom code and have it executed e.g. for every pixel of a scene, allowing custom calculations on server-side data that are not (easily) covered with "),t("RouterLink",{attrs:{to:"/documentation/1.0/processes.html"}},[e._v("pre-defined processes")]),e._v(" or user-defined processes. While openEO UDFs are in principle language-agnostic, we currently implement UDFs for Python and R.")],1),e._v(" "),t("h2",{attrs:{id:"users"}},[t("a",{staticClass:"header-anchor",attrs:{href:"#users"}},[e._v("#")]),e._v(" Users")]),e._v(" "),t("p",[e._v("You can run UDFs with any client (including JavaScript and Web Editor), but the code you can execute on the server will be limited to Python and R.\nAll openEO clients allow to run UDFs via the pre-defined process "),t("RouterLink",{attrs:{to:"/documentation/1.0/processes.html#run_udf"}},[t("code",[e._v("run_udf")])]),e._v(" if the back-end implements UDFs. You can check the "),t("a",{attrs:{href:"https://hub.openeo.org",target:"_blank",rel:"noopener noreferrer"}},[e._v("openEO Hub"),t("OutboundLink")],1),e._v(" for back-ends that support user-defined functions. There's also "),t("RouterLink",{attrs:{to:"/documentation/1.0/processes.html#run_udf_externally"}},[t("code",[e._v("run_udf_externally")])]),e._v(" if you want to host UDFs yourself (see back-end instructions below), but the process is still experimental and not widely supported yet. If we refer to "),t("code",[e._v("run_udf")]),e._v(" below and the back-end supports it, you can also use "),t("code",[e._v("run_udf_externally")]),e._v(" without it being explicitly mentioned.")],1),e._v(" "),t("p",[e._v("As data cubes can be very large, the back-end may only be able to run your code on a smaller chunk of the whole cube. So you need to help the server a bit, by designing your code to work on smaller piece of data. This can be done by using data cube processes that run the UDF on smaller chunks of the data. There are a number of pre-defined processes that can run UDFs on such chunks, for example:")]),e._v(" "),t("ul",[t("li",[t("RouterLink",{attrs:{to:"/documentation/1.0/processes.html#aggregate_spatial"}},[t("code",[e._v("aggregate_spatial")])]),e._v(": Reduces pixels within geometries to a single value using an UDF")],1),e._v(" "),t("li",[t("RouterLink",{attrs:{to:"/documentation/1.0/processes.html#apply"}},[t("code",[e._v("apply")])]),e._v(": Applies an UDF to each pixel (it might also be slow to make the chunks too small though)")],1),e._v(" "),t("li",[t("RouterLink",{attrs:{to:"/documentation/1.0/processes.html#apply_dimension"}},[t("code",[e._v("apply_dimension")])]),e._v(": Applies an UDF to all pixels along a dimension, without changing the number of values")],1),e._v(" "),t("li",[t("RouterLink",{attrs:{to:"/documentation/1.0/processes.html#apply_neighborhood"}},[t("code",[e._v("apply_neighborhood")])]),e._v(": Applies an UDF to all pixels in a multidimensional neighborhood")],1),e._v(" "),t("li",[t("RouterLink",{attrs:{to:"/documentation/1.0/processes.html#merge_cubes"}},[t("code",[e._v("merge_cubes")])]),e._v(": Reduces overlapping pixels of the data cubes to a single value")],1),e._v(" "),t("li",[t("RouterLink",{attrs:{to:"/documentation/1.0/processes.html#reduce_dimension"}},[t("code",[e._v("reduce_dimension")])]),e._v(": Reduces values along a dimension using an UDF")],1)]),e._v(" "),t("p",[e._v("There are more processes that accept and run a sub-process. Each of them can also be used to run UDFs.")]),e._v(" "),t("div",{staticClass:"custom-block tip"},[t("p",{staticClass:"custom-block-title"},[e._v("Note")]),e._v(" "),t("p",[e._v("Not all functions will require you to write a UDF. For instance, if you want to take the absolute value of your data cube, you can simply "),t("RouterLink",{attrs:{to:"/documentation/1.0/processes.html#apply"}},[t("code",[e._v("apply")])]),e._v(" the predefined "),t("RouterLink",{attrs:{to:"/documentation/1.0/processes.html#absolute"}},[t("code",[e._v("absolute")])]),e._v(") process. In fact, it is recommended to try and use predefined functions first, as they can be more efficiently implemented.")],1)]),e._v(" "),t("p",[e._v("The following chapters have further information on UDF usage in the openEO clients:")]),e._v(" "),t("h3",{attrs:{id:"javascript"}},[t("a",{staticClass:"header-anchor",attrs:{href:"#javascript"}},[e._v("#")]),e._v(" JavaScript")]),e._v(" "),t("p",[e._v("The easiest way to run UDFs in the JavaScript client is to use the "),t("a",{attrs:{href:"https://open-eo.github.io/openeo-js-client/latest/Builder.html",target:"_blank",rel:"noopener noreferrer"}},[e._v("process builder"),t("OutboundLink")],1),e._v(". You can use the builder to execute the "),t("code",[e._v("run_udf")]),e._v(" process. A simple example:")]),e._v(" "),t("div",{staticClass:"language-javascript extra-class"},[t("pre",{pre:!0,attrs:{class:"language-javascript"}},[t("code",[t("span",{pre:!0,attrs:{class:"token comment"}},[e._v("// Connect to the back-end first and store the connection in the variable `con`...")]),e._v("\n\n"),t("span",{pre:!0,attrs:{class:"token comment"}},[e._v("// Discover UDF runtimes")]),e._v("\nconsole"),t("span",{pre:!0,attrs:{class:"token punctuation"}},[e._v(".")]),t("span",{pre:!0,attrs:{class:"token function"}},[e._v("log")]),t("span",{pre:!0,attrs:{class:"token punctuation"}},[e._v("(")]),t("span",{pre:!0,attrs:{class:"token keyword"}},[e._v("await")]),e._v(" con"),t("span",{pre:!0,attrs:{class:"token punctuation"}},[e._v(".")]),t("span",{pre:!0,attrs:{class:"token function"}},[e._v("listUdfRuntimes")]),t("span",{pre:!0,attrs:{class:"token punctuation"}},[e._v("(")]),t("span",{pre:!0,attrs:{class:"token punctuation"}},[e._v(")")]),t("span",{pre:!0,attrs:{class:"token punctuation"}},[e._v(")")]),t("span",{pre:!0,attrs:{class:"token punctuation"}},[e._v(";")]),e._v("\n\n"),t("span",{pre:!0,attrs:{class:"token comment"}},[e._v("// Upload a UDF file to the server as udf.py, the source can only be a local path in a NodeJS environment")]),e._v("\n"),t("span",{pre:!0,attrs:{class:"token keyword"}},[e._v("await")]),e._v(" con"),t("span",{pre:!0,attrs:{class:"token punctuation"}},[e._v(".")]),t("span",{pre:!0,attrs:{class:"token function"}},[e._v("uploadFile")]),t("span",{pre:!0,attrs:{class:"token punctuation"}},[e._v("(")]),t("span",{pre:!0,attrs:{class:"token string"}},[e._v("'/home/user/myudf.py'")]),t("span",{pre:!0,attrs:{class:"token punctuation"}},[e._v(",")]),e._v(" "),t("span",{pre:!0,attrs:{class:"token string"}},[e._v("'udf.py'")]),t("span",{pre:!0,attrs:{class:"token punctuation"}},[e._v(")")]),t("span",{pre:!0,attrs:{class:"token punctuation"}},[e._v(";")]),e._v("\n\n"),t("span",{pre:!0,attrs:{class:"token comment"}},[e._v("// Create a process builder")]),e._v("\n"),t("span",{pre:!0,attrs:{class:"token keyword"}},[e._v("var")]),e._v(" builder "),t("span",{pre:!0,attrs:{class:"token operator"}},[e._v("=")]),e._v(" "),t("span",{pre:!0,attrs:{class:"token keyword"}},[e._v("await")]),e._v(" con"),t("span",{pre:!0,attrs:{class:"token punctuation"}},[e._v(".")]),t("span",{pre:!0,attrs:{class:"token function"}},[e._v("buildProcess")]),t("span",{pre:!0,attrs:{class:"token punctuation"}},[e._v("(")]),t("span",{pre:!0,attrs:{class:"token punctuation"}},[e._v(")")]),t("span",{pre:!0,attrs:{class:"token punctuation"}},[e._v(";")]),e._v("\n\n"),t("span",{pre:!0,attrs:{class:"token comment"}},[e._v("// Load some data from the back-end")]),e._v("\n"),t("span",{pre:!0,attrs:{class:"token keyword"}},[e._v("var")]),e._v(" datacube "),t("span",{pre:!0,attrs:{class:"token operator"}},[e._v("=")]),e._v(" builder"),t("span",{pre:!0,attrs:{class:"token punctuation"}},[e._v(".")]),t("span",{pre:!0,attrs:{class:"token function"}},[e._v("load_collection")]),t("span",{pre:!0,attrs:{class:"token punctuation"}},[e._v("(")]),t("span",{pre:!0,attrs:{class:"token string"}},[e._v('"Sentinel-2"')]),t("span",{pre:!0,attrs:{class:"token punctuation"}},[e._v(",")]),e._v(" "),t("span",{pre:!0,attrs:{class:"token keyword"}},[e._v("null")]),t("span",{pre:!0,attrs:{class:"token punctuation"}},[e._v(",")]),e._v(" "),t("span",{pre:!0,attrs:{class:"token punctuation"}},[e._v("[")]),t("span",{pre:!0,attrs:{class:"token string"}},[e._v('"2018"')]),t("span",{pre:!0,attrs:{class:"token punctuation"}},[e._v(",")]),e._v(" "),t("span",{pre:!0,attrs:{class:"token string"}},[e._v('"2019"')]),t("span",{pre:!0,attrs:{class:"token punctuation"}},[e._v("]")]),t("span",{pre:!0,attrs:{class:"token punctuation"}},[e._v(")")]),t("span",{pre:!0,attrs:{class:"token punctuation"}},[e._v(";")]),e._v("\n\n"),t("span",{pre:!0,attrs:{class:"token comment"}},[e._v("// Create a sub-process that runs a UDF")]),e._v("\n"),t("span",{pre:!0,attrs:{class:"token keyword"}},[e._v("var")]),e._v(" "),t("span",{pre:!0,attrs:{class:"token function-variable function"}},[e._v("udfProcess")]),e._v(" "),t("span",{pre:!0,attrs:{class:"token operator"}},[e._v("=")]),e._v(" "),t("span",{pre:!0,attrs:{class:"token keyword"}},[e._v("function")]),t("span",{pre:!0,attrs:{class:"token punctuation"}},[e._v("(")]),t("span",{pre:!0,attrs:{class:"token parameter"}},[e._v("data")]),t("span",{pre:!0,attrs:{class:"token punctuation"}},[e._v(")")]),e._v(" "),t("span",{pre:!0,attrs:{class:"token punctuation"}},[e._v("{")]),e._v("\n\t"),t("span",{pre:!0,attrs:{class:"token comment"}},[e._v("// This assumes that a file udf.py with the Python UDF code has been uploaded to the server before, you can also directly insert the UDF code instead. ")]),e._v("\n\t"),t("span",{pre:!0,attrs:{class:"token comment"}},[e._v("// You need to replace `Python` and `3.7` with the respective runtime identifier and version as returned in UDF discovery")]),e._v("\n\t"),t("span",{pre:!0,attrs:{class:"token keyword"}},[e._v("return")]),e._v(" "),t("span",{pre:!0,attrs:{class:"token keyword"}},[e._v("this")]),t("span",{pre:!0,attrs:{class:"token punctuation"}},[e._v(".")]),t("span",{pre:!0,attrs:{class:"token function"}},[e._v("run_udf")]),t("span",{pre:!0,attrs:{class:"token punctuation"}},[e._v("(")]),e._v("data"),t("span",{pre:!0,attrs:{class:"token punctuation"}},[e._v(",")]),e._v(" "),t("span",{pre:!0,attrs:{class:"token string"}},[e._v('"udf.py"')]),t("span",{pre:!0,attrs:{class:"token punctuation"}},[e._v(",")]),e._v(" "),t("span",{pre:!0,attrs:{class:"token string"}},[e._v('"Python"')]),t("span",{pre:!0,attrs:{class:"token punctuation"}},[e._v(")")]),t("span",{pre:!0,attrs:{class:"token punctuation"}},[e._v(";")]),e._v("\n"),t("span",{pre:!0,attrs:{class:"token punctuation"}},[e._v("}")]),t("span",{pre:!0,attrs:{class:"token punctuation"}},[e._v(";")]),e._v("\n\n"),t("span",{pre:!0,attrs:{class:"token comment"}},[e._v("// Call the UDF as part of the reduce_dimension process to reduce the bands to a single value")]),e._v("\ndatacube "),t("span",{pre:!0,attrs:{class:"token operator"}},[e._v("=")]),e._v(" builder"),t("span",{pre:!0,attrs:{class:"token punctuation"}},[e._v(".")]),t("span",{pre:!0,attrs:{class:"token function"}},[e._v("reduce_dimension")]),t("span",{pre:!0,attrs:{class:"token punctuation"}},[e._v("(")]),e._v("datacube"),t("span",{pre:!0,attrs:{class:"token punctuation"}},[e._v(",")]),e._v(" udfProcess"),t("span",{pre:!0,attrs:{class:"token punctuation"}},[e._v(",")]),e._v(" "),t("span",{pre:!0,attrs:{class:"token string"}},[e._v('"bands"')]),t("span",{pre:!0,attrs:{class:"token punctuation"}},[e._v(")")]),t("span",{pre:!0,attrs:{class:"token punctuation"}},[e._v(";")]),e._v("\n\n"),t("span",{pre:!0,attrs:{class:"token comment"}},[e._v("// Further process the data cube or save it using save_result...")]),e._v("\n")])])]),t("h3",{attrs:{id:"python"}},[t("a",{staticClass:"header-anchor",attrs:{href:"#python"}},[e._v("#")]),e._v(" Python")]),e._v(" "),t("p",[e._v("The Python client has "),t("a",{attrs:{href:"https://open-eo.github.io/openeo-python-client/udf.html",target:"_blank",rel:"noopener noreferrer"}},[e._v("separate documentation on UDFs"),t("OutboundLink")],1),e._v(".")]),e._v(" "),t("h3",{attrs:{id:"qgis"}},[t("a",{staticClass:"header-anchor",attrs:{href:"#qgis"}},[e._v("#")]),e._v(" QGIS")]),e._v(" "),t("p",[e._v("QGIS doesn't natively support running UDFs yet, but you can use copy and paste user-defined processes that include UDFs.")]),e._v(" "),t("h3",{attrs:{id:"r"}},[t("a",{staticClass:"header-anchor",attrs:{href:"#r"}},[e._v("#")]),e._v(" R")]),e._v(" "),t("p",[e._v("There's no dedicated UDF documentation for R yet, but you can have a look at the "),t("a",{attrs:{href:"https://github.com/Open-EO/openeo-r-udf#usage",target:"_blank",rel:"noopener noreferrer"}},[e._v("getting started guide and examples in the UDF server repository"),t("OutboundLink")],1),e._v(" for now.")]),e._v(" "),t("h3",{attrs:{id:"web-editor"}},[t("a",{staticClass:"header-anchor",attrs:{href:"#web-editor"}},[e._v("#")]),e._v(" Web Editor")]),e._v(" "),t("p",[e._v("Running UDFs in the Web Editor just requires you to drag the "),t("code",[e._v("run_udf")]),e._v(" process into the model builder. Afterwards you can edit the process parameters to your needs. You have to set the environment / programming language to run the UDF with and then you can either directly program a UDF in the code editor or select an UDF file you have previously uploaded to the user workspace.")]),e._v(" "),t("h2",{attrs:{id:"back-ends"}},[t("a",{staticClass:"header-anchor",attrs:{href:"#back-ends"}},[e._v("#")]),e._v(" Back-ends")]),e._v(" "),t("p",[e._v("If you'd like to offer user-defined functions for your users, you need to implement either the process "),t("RouterLink",{attrs:{to:"/documentation/1.0/processes.html#run_udf"}},[t("code",[e._v("run_udf")])]),e._v(" or "),t("RouterLink",{attrs:{to:"/documentation/1.0/processes.html#run_udf_externally"}},[t("code",[e._v("run_udf_externally")])]),e._v(" (or both). Both usually require you to access UDF servers via the "),t("a",{attrs:{href:"https://open-eo.github.io/openeo-udf/api_docs/",target:"_blank",rel:"noopener noreferrer"}},[e._v("UDF API"),t("OutboundLink")],1),e._v(". For the process "),t("code",[e._v("run_udf")]),e._v(" you may bypass the API and exchange data directly between the openEO back-end and the openEO UDF servers for performance reasons.")],1),e._v(" "),t("p",[t("code",[e._v("run_udf")]),e._v(" allows users to run their code on your infrastructure. This can be done using one of the UDF server implementations in "),t("a",{attrs:{href:"https://github.com/Open-EO/openeo-udf",target:"_blank",rel:"noopener noreferrer"}},[e._v("Python"),t("OutboundLink")],1),e._v(" or "),t("a",{attrs:{href:"https://github.com/Open-EO/openeo-r-udf",target:"_blank",rel:"noopener noreferrer"}},[e._v("R"),t("OutboundLink")],1),e._v(". Please note that both UDF servers are "),t("strong",[e._v("drafts")]),e._v(" and still need work to improve performance and make them secure! This is not yet an out-of-the-box solution for running UDFs securely and fast.")])])}),[],!1,null,null,null);t.default=a.exports}}]); \ No newline at end of file diff --git a/assets/js/88.92a50275.js b/assets/js/88.98123f03.js similarity index 97% rename from assets/js/88.92a50275.js rename to assets/js/88.98123f03.js index 2b10bb7af..b414210ba 100644 --- a/assets/js/88.92a50275.js +++ b/assets/js/88.98123f03.js @@ -1 +1 @@ -(window.webpackJsonp=window.webpackJsonp||[]).push([[88],{536:function(e,t,o){"use strict";o.r(t);var n=o(4),r=Object(n.a)({},(function(){var e=this,t=e._self._c;return t("ContentSlotsDistributor",{attrs:{"slot-key":e.$parent.slotKey}},[t("h1",{attrs:{id:"contributor-code-of-conduct"}},[t("a",{staticClass:"header-anchor",attrs:{href:"#contributor-code-of-conduct"}},[e._v("#")]),e._v(" Contributor Code of Conduct")]),e._v(" "),t("p",[e._v("As contributors and maintainers of this project, we pledge to respect all people who\ncontribute through reporting issues, posting feature requests, updating documentation,\nsubmitting pull requests or patches, and other activities.")]),e._v(" "),t("p",[e._v("We are committed to making participation in this project a harassment-free experience for\neveryone, regardless of level of experience, gender, gender identity and expression,\nsexual orientation, disability, personal appearance, body size, race, ethnicity, age, or religion.")]),e._v(" "),t("p",[e._v("Examples of unacceptable behavior by participants include the use of sexual language or\nimagery, derogatory comments or personal attacks, trolling, public or private harassment,\ninsults, or other unprofessional conduct.")]),e._v(" "),t("p",[e._v("Project maintainers have the right and responsibility to remove, edit, or reject comments,\ncommits, code, wiki edits, issues, and other contributions that are not aligned to this\nCode of Conduct. Project maintainers who do not follow the Code of Conduct may be removed\nfrom the project team.")]),e._v(" "),t("p",[e._v("Instances of abusive, harassing, or otherwise unacceptable behavior may be reported by\nopening an issue or contacting one or more of the project maintainers.")]),e._v(" "),t("p",[e._v("This Code of Conduct is adapted from the "),t("a",{attrs:{href:"http://contributor-covenant.org",target:"_blank",rel:"noopener noreferrer"}},[e._v("Contributor Covenant"),t("OutboundLink")],1),e._v(", version 1.0.0, available at\n"),t("a",{attrs:{href:"http://contributor-covenant.org/version/1/0/0/",target:"_blank",rel:"noopener noreferrer"}},[e._v("http://contributor-covenant.org/version/1/0/0/"),t("OutboundLink")],1),e._v(".")])])}),[],!1,null,null,null);t.default=r.exports}}]); \ No newline at end of file +(window.webpackJsonp=window.webpackJsonp||[]).push([[88],{534:function(e,t,o){"use strict";o.r(t);var n=o(4),r=Object(n.a)({},(function(){var e=this,t=e._self._c;return t("ContentSlotsDistributor",{attrs:{"slot-key":e.$parent.slotKey}},[t("h1",{attrs:{id:"contributor-code-of-conduct"}},[t("a",{staticClass:"header-anchor",attrs:{href:"#contributor-code-of-conduct"}},[e._v("#")]),e._v(" Contributor Code of Conduct")]),e._v(" "),t("p",[e._v("As contributors and maintainers of this project, we pledge to respect all people who\ncontribute through reporting issues, posting feature requests, updating documentation,\nsubmitting pull requests or patches, and other activities.")]),e._v(" "),t("p",[e._v("We are committed to making participation in this project a harassment-free experience for\neveryone, regardless of level of experience, gender, gender identity and expression,\nsexual orientation, disability, personal appearance, body size, race, ethnicity, age, or religion.")]),e._v(" "),t("p",[e._v("Examples of unacceptable behavior by participants include the use of sexual language or\nimagery, derogatory comments or personal attacks, trolling, public or private harassment,\ninsults, or other unprofessional conduct.")]),e._v(" "),t("p",[e._v("Project maintainers have the right and responsibility to remove, edit, or reject comments,\ncommits, code, wiki edits, issues, and other contributions that are not aligned to this\nCode of Conduct. Project maintainers who do not follow the Code of Conduct may be removed\nfrom the project team.")]),e._v(" "),t("p",[e._v("Instances of abusive, harassing, or otherwise unacceptable behavior may be reported by\nopening an issue or contacting one or more of the project maintainers.")]),e._v(" "),t("p",[e._v("This Code of Conduct is adapted from the "),t("a",{attrs:{href:"http://contributor-covenant.org",target:"_blank",rel:"noopener noreferrer"}},[e._v("Contributor Covenant"),t("OutboundLink")],1),e._v(", version 1.0.0, available at\n"),t("a",{attrs:{href:"http://contributor-covenant.org/version/1/0/0/",target:"_blank",rel:"noopener noreferrer"}},[e._v("http://contributor-covenant.org/version/1/0/0/"),t("OutboundLink")],1),e._v(".")])])}),[],!1,null,null,null);t.default=r.exports}}]); \ No newline at end of file diff --git a/assets/js/89.144159fa.js b/assets/js/89.eb69d8d4.js similarity index 99% rename from assets/js/89.144159fa.js rename to assets/js/89.eb69d8d4.js index 92627ba6a..840f8af7f 100644 --- a/assets/js/89.144159fa.js +++ b/assets/js/89.eb69d8d4.js @@ -1 +1 @@ -(window.webpackJsonp=window.webpackJsonp||[]).push([[89],{537:function(e,t,o){"use strict";o.r(t);var n=o(4),r=Object(n.a)({},(function(){var e=this,t=e._self._c;return t("ContentSlotsDistributor",{attrs:{"slot-key":e.$parent.slotKey}},[t("h1",{attrs:{id:"software-development-guidelines"}},[t("a",{staticClass:"header-anchor",attrs:{href:"#software-development-guidelines"}},[e._v("#")]),e._v(" Software Development Guidelines")]),e._v(" "),t("p",[e._v("This document describes guidelines for software developers, written for the "),t("a",{attrs:{href:"http://openeo.org",target:"_blank",rel:"noopener noreferrer"}},[e._v("openEO"),t("OutboundLink")],1),e._v(" project.\nSince the openEO infrastructure encompasses several programming languages and software environments, this document does not prescribe particular tools or platforms but rather focuses on general principles and methods behind them.")]),e._v(" "),t("ol",[t("li",[e._v("License: all software developed in the openEO project and published on the "),t("a",{attrs:{href:"http://github.com/open-eo/",target:"_blank",rel:"noopener noreferrer"}},[e._v("openEO GitHub"),t("OutboundLink")],1),e._v(" organisation shall be licensed under the "),t("a",{attrs:{href:"https://opensource.org/licenses/Apache-2.0",target:"_blank",rel:"noopener noreferrer"}},[e._v("Apache 2.0 license"),t("OutboundLink")],1),e._v(". If software repositories deviate from this, or contain code or other artifacts that deviates from this, this shall be described in the "),t("code",[e._v("README.md")]),e._v(" file.")]),e._v(" "),t("li",[e._v("Location: Official openEO software is developed under the "),t("a",{attrs:{href:"https://github.com/open-EO/",target:"_blank",rel:"noopener noreferrer"}},[e._v("openEO GitHub organisation"),t("OutboundLink")],1),e._v(".")]),e._v(" "),t("li",[e._v("Proof-of-concept versus sustainable: each repository shall indicate its status: either "),t("em",[e._v("proof-of-concept")]),e._v(", or "),t("em",[e._v("sustainable")]),e._v(". Proof-of-concept code is meant to work but comes without quality assurance. Software repositories with proof-of-concept developments shall clearly say so in the first paragraph of the "),t("code",[e._v("README.md")]),e._v(" file.")]),e._v(" "),t("li",[e._v("Sustainable code should undergo standard "),t("a",{attrs:{href:"#software-quality-guidelines"}},[e._v("quality checks")]),e._v(", and point out its "),t("a",{attrs:{href:"#software-documentation-guidelines"}},[e._v("documentation")]),e._v(".")]),e._v(" "),t("li",[e._v("Sustainable code shall undergo "),t("a",{attrs:{href:"#software-review"}},[e._v("code review")]),e._v("; no direct commits to master; any commit shall come in the form of a PR, commit after review.")]),e._v(" "),t("li",[e._v("Sustainable code shall be written in a "),t("a",{attrs:{href:"#test-driven-development"}},[e._v("Test-driven manner")]),e._v(", and repositories shall at the top of their "),t("code",[e._v("README.md")]),e._v(" give indication of the degree to which code is covered by tests.")]),e._v(" "),t("li",[t("a",{attrs:{href:"#continuous-integration"}},[e._v("Continuous integration")]),e._v(" shall be used to indicate code currently passes its test on CI platforms.")]),e._v(" "),t("li",[e._v("A "),t("RouterLink",{attrs:{to:"/documentation/code-of-conduct.html"}},[e._v("Code of conduct")]),e._v(" describes the rules and constraints to developers and contributors.")],1),e._v(" "),t("li",[e._v("Version numbers of sustainable software releases shall follow "),t("a",{attrs:{href:"http://semver.org",target:"_blank",rel:"noopener noreferrer"}},[e._v("Semantic Versioning 2.0.0"),t("OutboundLink")],1),e._v(".")])]),e._v(" "),t("h2",{attrs:{id:"software-quality-guidelines"}},[t("a",{staticClass:"header-anchor",attrs:{href:"#software-quality-guidelines"}},[e._v("#")]),e._v(" Software quality guidelines")]),e._v(" "),t("ul",[t("li",[e._v("software shall be written in such a way that another person can understand its intention")]),e._v(" "),t("li",[e._v("comment lines shall be used sparsely, but effectively")]),e._v(" "),t("li",[e._v("reuse of unstable or esoteric libraries shall be avoided")])]),e._v(" "),t("h2",{attrs:{id:"software-documentation-guidelines"}},[t("a",{staticClass:"header-anchor",attrs:{href:"#software-documentation-guidelines"}},[e._v("#")]),e._v(" Software documentation guidelines")]),e._v(" "),t("p",[e._v("Software documentation shall include:")]),e._v(" "),t("ul",[t("li",[e._v("installation instructions")]),e._v(" "),t("li",[e._v("usage instructions")]),e._v(" "),t("li",[e._v("explain in detail the intention of the software")]),e._v(" "),t("li",[e._v("pointers to reference documents explaining overarching concepts")])]),e._v(" "),t("p",[e._v("Each repository's "),t("code",[e._v("README.md")]),e._v(" shall point to the documentation.")]),e._v(" "),t("p",[e._v("Reference documentation shall be written using well-defined reference documentation language, such as "),t("a",{attrs:{href:"https://tools.ietf.org/html/rfc2119",target:"_blank",rel:"noopener noreferrer"}},[e._v("RFC2119"),t("OutboundLink")],1),e._v(" or "),t("a",{attrs:{href:"http://arc42.org",target:"_blank",rel:"noopener noreferrer"}},[e._v("arc42"),t("OutboundLink")],1),e._v(", and refer to the definitions used.")]),e._v(" "),t("h2",{attrs:{id:"software-review"}},[t("a",{staticClass:"header-anchor",attrs:{href:"#software-review"}},[e._v("#")]),e._v(" Software review")]),e._v(" "),t("ul",[t("li",[e._v("sustainable software development shall take place by always having two persons involved in a change to the master branch: individuals push to branches, pull request indicate readiness to be taken up in the master branch, a second developer reviews the pull request before merging it into the master branch.")]),e._v(" "),t("li",[e._v("software review discussions shall be intelligible for external developers, and serve as implicit documentation of development decisions taken")])]),e._v(" "),t("h2",{attrs:{id:"test-driven-development"}},[t("a",{staticClass:"header-anchor",attrs:{href:"#test-driven-development"}},[e._v("#")]),e._v(" Test-driven development")]),e._v(" "),t("p",[e._v("Software shall be developed in a test-driven fashion, meaning that while the code is written, tests are developed that verify, to a reasonable extent, the correctness of the code. Tools such as "),t("a",{attrs:{href:"https://codecov.io/",target:"_blank",rel:"noopener noreferrer"}},[e._v("codecov.io"),t("OutboundLink")],1),e._v(" to automatically indicate the amount of code covered by tests, and code that is not covered by tests shall be used in combination with a continuous integration framework.")]),e._v(" "),t("h2",{attrs:{id:"continuous-integration"}},[t("a",{staticClass:"header-anchor",attrs:{href:"#continuous-integration"}},[e._v("#")]),e._v(" Continuous integration")]),e._v(" "),t("p",[e._v("Repositories containing running software shall use an appropriate continuous integration platform, such as GitHub Actions or similar, to show whether the current build passes all checks. This helps understand contributors that the software passes tests on an independent platform, and may give insights in the way the software is compiled, deployed and tested.")]),e._v(" "),t("h2",{attrs:{id:"additional-guidelines"}},[t("a",{staticClass:"header-anchor",attrs:{href:"#additional-guidelines"}},[e._v("#")]),e._v(" Additional guidelines")]),e._v(" "),t("p",[e._v("There is specific guideline for "),t("a",{attrs:{href:e.$site.themeConfig.docPath+"developers/clients/library-guidelines.html"}},[e._v("client library development")]),e._v(".")])])}),[],!1,null,null,null);t.default=r.exports}}]); \ No newline at end of file +(window.webpackJsonp=window.webpackJsonp||[]).push([[89],{536:function(e,t,o){"use strict";o.r(t);var n=o(4),r=Object(n.a)({},(function(){var e=this,t=e._self._c;return t("ContentSlotsDistributor",{attrs:{"slot-key":e.$parent.slotKey}},[t("h1",{attrs:{id:"software-development-guidelines"}},[t("a",{staticClass:"header-anchor",attrs:{href:"#software-development-guidelines"}},[e._v("#")]),e._v(" Software Development Guidelines")]),e._v(" "),t("p",[e._v("This document describes guidelines for software developers, written for the "),t("a",{attrs:{href:"http://openeo.org",target:"_blank",rel:"noopener noreferrer"}},[e._v("openEO"),t("OutboundLink")],1),e._v(" project.\nSince the openEO infrastructure encompasses several programming languages and software environments, this document does not prescribe particular tools or platforms but rather focuses on general principles and methods behind them.")]),e._v(" "),t("ol",[t("li",[e._v("License: all software developed in the openEO project and published on the "),t("a",{attrs:{href:"http://github.com/open-eo/",target:"_blank",rel:"noopener noreferrer"}},[e._v("openEO GitHub"),t("OutboundLink")],1),e._v(" organisation shall be licensed under the "),t("a",{attrs:{href:"https://opensource.org/licenses/Apache-2.0",target:"_blank",rel:"noopener noreferrer"}},[e._v("Apache 2.0 license"),t("OutboundLink")],1),e._v(". If software repositories deviate from this, or contain code or other artifacts that deviates from this, this shall be described in the "),t("code",[e._v("README.md")]),e._v(" file.")]),e._v(" "),t("li",[e._v("Location: Official openEO software is developed under the "),t("a",{attrs:{href:"https://github.com/open-EO/",target:"_blank",rel:"noopener noreferrer"}},[e._v("openEO GitHub organisation"),t("OutboundLink")],1),e._v(".")]),e._v(" "),t("li",[e._v("Proof-of-concept versus sustainable: each repository shall indicate its status: either "),t("em",[e._v("proof-of-concept")]),e._v(", or "),t("em",[e._v("sustainable")]),e._v(". Proof-of-concept code is meant to work but comes without quality assurance. Software repositories with proof-of-concept developments shall clearly say so in the first paragraph of the "),t("code",[e._v("README.md")]),e._v(" file.")]),e._v(" "),t("li",[e._v("Sustainable code should undergo standard "),t("a",{attrs:{href:"#software-quality-guidelines"}},[e._v("quality checks")]),e._v(", and point out its "),t("a",{attrs:{href:"#software-documentation-guidelines"}},[e._v("documentation")]),e._v(".")]),e._v(" "),t("li",[e._v("Sustainable code shall undergo "),t("a",{attrs:{href:"#software-review"}},[e._v("code review")]),e._v("; no direct commits to master; any commit shall come in the form of a PR, commit after review.")]),e._v(" "),t("li",[e._v("Sustainable code shall be written in a "),t("a",{attrs:{href:"#test-driven-development"}},[e._v("Test-driven manner")]),e._v(", and repositories shall at the top of their "),t("code",[e._v("README.md")]),e._v(" give indication of the degree to which code is covered by tests.")]),e._v(" "),t("li",[t("a",{attrs:{href:"#continuous-integration"}},[e._v("Continuous integration")]),e._v(" shall be used to indicate code currently passes its test on CI platforms.")]),e._v(" "),t("li",[e._v("A "),t("RouterLink",{attrs:{to:"/documentation/code-of-conduct.html"}},[e._v("Code of conduct")]),e._v(" describes the rules and constraints to developers and contributors.")],1),e._v(" "),t("li",[e._v("Version numbers of sustainable software releases shall follow "),t("a",{attrs:{href:"http://semver.org",target:"_blank",rel:"noopener noreferrer"}},[e._v("Semantic Versioning 2.0.0"),t("OutboundLink")],1),e._v(".")])]),e._v(" "),t("h2",{attrs:{id:"software-quality-guidelines"}},[t("a",{staticClass:"header-anchor",attrs:{href:"#software-quality-guidelines"}},[e._v("#")]),e._v(" Software quality guidelines")]),e._v(" "),t("ul",[t("li",[e._v("software shall be written in such a way that another person can understand its intention")]),e._v(" "),t("li",[e._v("comment lines shall be used sparsely, but effectively")]),e._v(" "),t("li",[e._v("reuse of unstable or esoteric libraries shall be avoided")])]),e._v(" "),t("h2",{attrs:{id:"software-documentation-guidelines"}},[t("a",{staticClass:"header-anchor",attrs:{href:"#software-documentation-guidelines"}},[e._v("#")]),e._v(" Software documentation guidelines")]),e._v(" "),t("p",[e._v("Software documentation shall include:")]),e._v(" "),t("ul",[t("li",[e._v("installation instructions")]),e._v(" "),t("li",[e._v("usage instructions")]),e._v(" "),t("li",[e._v("explain in detail the intention of the software")]),e._v(" "),t("li",[e._v("pointers to reference documents explaining overarching concepts")])]),e._v(" "),t("p",[e._v("Each repository's "),t("code",[e._v("README.md")]),e._v(" shall point to the documentation.")]),e._v(" "),t("p",[e._v("Reference documentation shall be written using well-defined reference documentation language, such as "),t("a",{attrs:{href:"https://tools.ietf.org/html/rfc2119",target:"_blank",rel:"noopener noreferrer"}},[e._v("RFC2119"),t("OutboundLink")],1),e._v(" or "),t("a",{attrs:{href:"http://arc42.org",target:"_blank",rel:"noopener noreferrer"}},[e._v("arc42"),t("OutboundLink")],1),e._v(", and refer to the definitions used.")]),e._v(" "),t("h2",{attrs:{id:"software-review"}},[t("a",{staticClass:"header-anchor",attrs:{href:"#software-review"}},[e._v("#")]),e._v(" Software review")]),e._v(" "),t("ul",[t("li",[e._v("sustainable software development shall take place by always having two persons involved in a change to the master branch: individuals push to branches, pull request indicate readiness to be taken up in the master branch, a second developer reviews the pull request before merging it into the master branch.")]),e._v(" "),t("li",[e._v("software review discussions shall be intelligible for external developers, and serve as implicit documentation of development decisions taken")])]),e._v(" "),t("h2",{attrs:{id:"test-driven-development"}},[t("a",{staticClass:"header-anchor",attrs:{href:"#test-driven-development"}},[e._v("#")]),e._v(" Test-driven development")]),e._v(" "),t("p",[e._v("Software shall be developed in a test-driven fashion, meaning that while the code is written, tests are developed that verify, to a reasonable extent, the correctness of the code. Tools such as "),t("a",{attrs:{href:"https://codecov.io/",target:"_blank",rel:"noopener noreferrer"}},[e._v("codecov.io"),t("OutboundLink")],1),e._v(" to automatically indicate the amount of code covered by tests, and code that is not covered by tests shall be used in combination with a continuous integration framework.")]),e._v(" "),t("h2",{attrs:{id:"continuous-integration"}},[t("a",{staticClass:"header-anchor",attrs:{href:"#continuous-integration"}},[e._v("#")]),e._v(" Continuous integration")]),e._v(" "),t("p",[e._v("Repositories containing running software shall use an appropriate continuous integration platform, such as GitHub Actions or similar, to show whether the current build passes all checks. This helps understand contributors that the software passes tests on an independent platform, and may give insights in the way the software is compiled, deployed and tested.")]),e._v(" "),t("h2",{attrs:{id:"additional-guidelines"}},[t("a",{staticClass:"header-anchor",attrs:{href:"#additional-guidelines"}},[e._v("#")]),e._v(" Additional guidelines")]),e._v(" "),t("p",[e._v("There is specific guideline for "),t("a",{attrs:{href:e.$site.themeConfig.docPath+"developers/clients/library-guidelines.html"}},[e._v("client library development")]),e._v(".")])])}),[],!1,null,null,null);t.default=r.exports}}]); \ No newline at end of file diff --git a/assets/js/93.7e1b8d20.js b/assets/js/93.98abe5ea.js similarity index 99% rename from assets/js/93.7e1b8d20.js rename to assets/js/93.98abe5ea.js index 6bc30d82f..9bf7f357c 100644 --- a/assets/js/93.7e1b8d20.js +++ b/assets/js/93.98abe5ea.js @@ -1 +1 @@ -(window.webpackJsonp=window.webpackJsonp||[]).push([[93],{542:function(e,t,n){"use strict";n.r(t);var a=n(4),r=Object(a.a)({},(function(){var e=this,t=e._self._c;return t("ContentSlotsDistributor",{attrs:{"slot-key":e.$parent.slotKey}},[t("h2",{attrs:{id:"the-problem"}},[t("a",{staticClass:"header-anchor",attrs:{href:"#the-problem"}},[e._v("#")]),e._v(" The problem")]),e._v(" "),t("p",[e._v("Earth Observation data are becoming too large to be downloaded\nlocally for analysis. Also, the way they are organised (as tiles,\nor "),t("em",[e._v("granules")]),e._v(": files containing the imagery for a small part of\nthe Earth and a single observation date) makes it unnecessary\ncomplicated to analyse them. The solution to this is to store these\ndata in the cloud, on compute back-ends, process them there, and\nbrowse the results or download resulting figures or numbers. But\nhow do we do that?")]),e._v(" "),t("p",[e._v("The aim of openEO is to develop an open API to connect R, python\nand javascript clients to big Earth observation cloud back-ends in\na simple and unified way.")]),e._v(" "),t("p",[e._v("With such an API,")]),e._v(" "),t("ul",[t("li",[e._v("each client can work with every back-end, and")]),e._v(" "),t("li",[e._v("it becomes possible to compare back-ends in terms of capacity,\ncost, and results (validation, reproducibility)")])]),e._v(" "),t("h2",{attrs:{id:"why-an-api"}},[t("a",{staticClass:"header-anchor",attrs:{href:"#why-an-api"}},[e._v("#")]),e._v(" Why an API?")]),e._v(" "),t("p",[e._v("An API is an application programming interface. It "),t("em",[e._v("defines")]),e._v("\na "),t("em",[e._v("language")]),e._v(" that two computers (a client and a server) use to\ncommunicate.")]),e._v(" "),t("p",[e._v("The following figure shows how many interfaces are needed to be able\nto compare back-ends from different clients, without an openEO API:")]),e._v(" "),t("p",[t("img",{attrs:{src:"/images/api.png",alt:"Current situation, without openEO API"}})]),e._v(" "),t("p",[e._v("With an openEO API (dark blue), the situation becomes much easier:")]),e._v(" "),t("p",[t("img",{attrs:{src:"/images/api2.png",alt:"Situation in the future, with openEO API"}})]),e._v(" "),t("p",[e._v("However, existing back-ends need to be taught to work with the new\nAPI, and clients that interact with back-ends need to be developed.")]),e._v(" "),t("p",[e._v("The task of the openEO project is to design, develop, and evaluate\nan API for cloud-based Earth Observation data processing.")]),e._v(" "),t("h2",{attrs:{id:"first-results"}},[t("a",{staticClass:"header-anchor",attrs:{href:"#first-results"}},[e._v("#")]),e._v(" First results")]),e._v(" "),t("p",[e._v("The openEO project started in Oct 2017. Now, within 6 months, we\nfinished the first proof of concept, and demonstrate it. Three use\ncases were selected for this, three clients were developed pretty\nmuch from scratch (Python, R, and JavaScript), and\nseven back-ends were built or interfaced. Full information is available\nfrom the projects "),t("a",{attrs:{href:"https://github.com/Open-EO/",target:"_blank",rel:"noopener noreferrer"}},[e._v("github organisation"),t("OutboundLink")],1),e._v(",\nand we point here to the")]),e._v(" "),t("ul",[t("li",[e._v("swagger-2.0 complient "),t("a",{attrs:{href:"https://github.com/Open-EO/openeo-api",target:"_blank",rel:"noopener noreferrer"}},[e._v("API"),t("OutboundLink")],1),e._v(" and its "),t("a",{attrs:{href:"https://open-eo.github.io/openeo-api/",target:"_blank",rel:"noopener noreferrer"}},[e._v("documentation"),t("OutboundLink")],1)])]),e._v(" "),t("h2",{attrs:{id:"the-three-use-cases"}},[t("a",{staticClass:"header-anchor",attrs:{href:"#the-three-use-cases"}},[e._v("#")]),e._v(" The three use cases")]),e._v(" "),t("p",[e._v("The three use cases comprise")]),e._v(" "),t("ol",[t("li",[e._v("Derive minimum NDVI measurements over pixel time series of Sentinel 2 imagery")]),e._v(" "),t("li",[e._v("Create a monthly aggregated Sentinel 1 product from a custom Python script")]),e._v(" "),t("li",[e._v("Compute time series of zonal (regional) statistics of Sentinel 2 imagery over user-uploaded polygons")])]),e._v(" "),t("p",[e._v("The full description, including the consecutive interaction steps of the API, is found on the")]),e._v(" "),t("ul",[t("li",[e._v("proof-of-concept "),t("a",{attrs:{href:"https://open-eo.github.io/openeo-api/poc/index.html",target:"_blank",rel:"noopener noreferrer"}},[e._v("use cases"),t("OutboundLink")],1),e._v(" site")])]),e._v(" "),t("h2",{attrs:{id:"links-to-the-client-and-back-end-implementations"}},[t("a",{staticClass:"header-anchor",attrs:{href:"#links-to-the-client-and-back-end-implementations"}},[e._v("#")]),e._v(" Links to the client and back-end implementations")]),e._v(" "),t("p",[e._v("Clients:")]),e._v(" "),t("ul",[t("li",[t("a",{attrs:{href:"https://github.com/Open-EO/openeo-python-client",target:"_blank",rel:"noopener noreferrer"}},[e._v("Python client"),t("OutboundLink")],1),e._v("; "),t("a",{attrs:{href:"https://github.com/Open-EO/openeo-python-client/blob/master/examples/notebooks/Compositing.ipynb",target:"_blank",rel:"noopener noreferrer"}},[e._v("Example notebook"),t("OutboundLink")],1)]),e._v(" "),t("li",[t("a",{attrs:{href:"https://github.com/Open-EO/openeo-r-client",target:"_blank",rel:"noopener noreferrer"}},[e._v("R client"),t("OutboundLink")],1)]),e._v(" "),t("li",[t("a",{attrs:{href:"https://github.com/Open-EO/openeo-js-client",target:"_blank",rel:"noopener noreferrer"}},[e._v("Javascript client"),t("OutboundLink")],1),e._v(" and "),t("a",{attrs:{href:"https://github.com/Open-EO/openeo-web-editor",target:"_blank",rel:"noopener noreferrer"}},[e._v("JavaScript web editor"),t("OutboundLink")],1)])]),e._v(" "),t("p",[e._v("Back-ends")]),e._v(" "),t("ul",[t("li",[t("a",{attrs:{href:"https://open-eo.github.io/openeo-grassgis-driver/",target:"_blank",rel:"noopener noreferrer"}},[e._v("GRASS GIS driver"),t("OutboundLink")],1)]),e._v(" "),t("li",[t("a",{attrs:{href:"https://github.com/Open-EO/openeo-wcps-driver",target:"_blank",rel:"noopener noreferrer"}},[e._v("WCPS driver"),t("OutboundLink")],1)]),e._v(" "),t("li",[t("a",{attrs:{href:"https://github.com/Open-EO/openeo-openshift-driver",target:"_blank",rel:"noopener noreferrer"}},[e._v("OpenShift driver"),t("OutboundLink")],1)]),e._v(" "),t("li",[t("a",{attrs:{href:"https://github.com/Open-EO/openeo-geopyspark-driver",target:"_blank",rel:"noopener noreferrer"}},[e._v("Python GeoPySpark/GeoTrellis driver"),t("OutboundLink")],1)]),e._v(" "),t("li",[t("a",{attrs:{href:"https://github.com/Open-EO/openeo-sentinelhub-driver",target:"_blank",rel:"noopener noreferrer"}},[e._v("Sentinel Hub driver"),t("OutboundLink")],1)]),e._v(" "),t("li",[t("a",{attrs:{href:"https://github.com/Open-EO/openeo-earthengine-driver",target:"_blank",rel:"noopener noreferrer"}},[e._v("Google Earth Engine back-end"),t("OutboundLink")],1)]),e._v(" "),t("li",[t("a",{attrs:{href:"https://github.com/Open-EO/openeo-r-backend",target:"_blank",rel:"noopener noreferrer"}},[e._v("R back-end"),t("OutboundLink")],1),e._v(" (developed for testing purposes)")])]),e._v(" "),t("p",[e._v('With all this, you can install your own back-end of choice, install\na client, and start analysing the data! (but do read "Next steps",\nbelow). Alternatively, we show a couple of videos of screen casts\nmade while testing the various clients and back-ends.')]),e._v(" "),t("h2",{attrs:{id:"proof-of-concept-videos"}},[t("a",{staticClass:"header-anchor",attrs:{href:"#proof-of-concept-videos"}},[e._v("#")]),e._v(" Proof-of-concept videos")]),e._v(" "),t("h3",{attrs:{id:"r-client-and-wcps-back-end-use-case-1"}},[t("a",{staticClass:"header-anchor",attrs:{href:"#r-client-and-wcps-back-end-use-case-1"}},[e._v("#")]),e._v(" R client and WCPS back-end, use case 1")]),e._v(" "),t("iframe",{attrs:{width:"560",height:"315",src:"https://www.youtube.com/embed/NoD0nVGM3ww",frameborder:"0",allowfullscreen:""}}),e._v(" "),t("h3",{attrs:{id:"grass-gis-back-end-use-cases-1-2-and-3"}},[t("a",{staticClass:"header-anchor",attrs:{href:"#grass-gis-back-end-use-cases-1-2-and-3"}},[e._v("#")]),e._v(" Grass GIS back-end, use cases 1, 2 and 3")]),e._v(" "),t("iframe",{attrs:{width:"560",height:"315",src:"https://www.youtube.com/embed/NgF1WgCtSiM",frameborder:"0",allowfullscreen:""}}),e._v(" "),t("h3",{attrs:{id:"r-client-and-r-back-end-use-case-1"}},[t("a",{staticClass:"header-anchor",attrs:{href:"#r-client-and-r-back-end-use-case-1"}},[e._v("#")]),e._v(" R client and R back-end, use-case 1")]),e._v(" "),t("iframe",{attrs:{width:"560",height:"315",src:"https://www.youtube.com/embed/Yb_QflO-ulE",frameborder:"0",allowfullscreen:""}}),e._v(" "),t("h3",{attrs:{id:"r-client-and-r-back-end-use-case-3"}},[t("a",{staticClass:"header-anchor",attrs:{href:"#r-client-and-r-back-end-use-case-3"}},[e._v("#")]),e._v(" R client and R back-end, use case 3")]),e._v(" "),t("iframe",{attrs:{width:"560",height:"315",src:"https://www.youtube.com/embed/LYnad6KC_CU",frameborder:"0",allowfullscreen:""}}),e._v(" "),t("h3",{attrs:{id:"openeo-web-editor-js-client-with-three-back-ends-use-case-1"}},[t("a",{staticClass:"header-anchor",attrs:{href:"#openeo-web-editor-js-client-with-three-back-ends-use-case-1"}},[e._v("#")]),e._v(" openEO Web Editor (JS client) with three back-ends (use case 1)")]),e._v(" "),t("p",[e._v("Demonstrates use of back-ends Sentinel Hub, WCPS EURAC, and OpenShift EODC")]),e._v(" "),t("iframe",{attrs:{width:"560",height:"315",src:"https://www.youtube.com/embed/zDaQkw0NhpY",frameborder:"0",allowfullscreen:""}}),e._v(" "),t("h3",{attrs:{id:"openeo-web-editor-js-client-with-r-back-end-use-case-3"}},[t("a",{staticClass:"header-anchor",attrs:{href:"#openeo-web-editor-js-client-with-r-back-end-use-case-3"}},[e._v("#")]),e._v(" openEO Web Editor (JS client) with R back-end (use case 3)")]),e._v(" "),t("iframe",{attrs:{width:"560",height:"315",src:"https://www.youtube.com/embed/XsPbKypUuIE",frameborder:"0",allowfullscreen:""}}),e._v(" "),t("h3",{attrs:{id:"python-client-with-geopyspark-back-end-use-case-1"}},[t("a",{staticClass:"header-anchor",attrs:{href:"#python-client-with-geopyspark-back-end-use-case-1"}},[e._v("#")]),e._v(" Python client with GeoPySpark back-end (use case 1)")]),e._v(" "),t("iframe",{attrs:{width:"560",height:"315",src:"https://www.youtube.com/embed/qtIp9OC0qHY",frameborder:"0",allowfullscreen:""}}),e._v(" "),t("h3",{attrs:{id:"openeo-web-editor-js-client-with-google-earth-engine-back-end-use-case-1"}},[t("a",{staticClass:"header-anchor",attrs:{href:"#openeo-web-editor-js-client-with-google-earth-engine-back-end-use-case-1"}},[e._v("#")]),e._v(" openEO Web Editor (JS client) with Google Earth Engine back-end (use case 1)")]),e._v(" "),t("iframe",{attrs:{width:"560",height:"315",src:"https://www.youtube.com/embed/LmUlmsIGJrs",frameborder:"0",allowfullscreen:""}}),e._v(" "),t("h2",{attrs:{id:"links-to-documents"}},[t("a",{staticClass:"header-anchor",attrs:{href:"#links-to-documents"}},[e._v("#")]),e._v(" Links to documents")]),e._v(" "),t("p",[e._v("The following four documents (formal project deliverables) describe the proof-of-concept more extensively:")]),e._v(" "),t("ul",[t("li",[t("a",{attrs:{href:"http://pebesma.staff.ifgi.de/openeo_del/openEO_D04_CoreAPIPrototype_v1.0.pdf",target:"_blank",rel:"noopener noreferrer"}},[e._v("openEO core API prototype including Proof of Concept"),t("OutboundLink")],1)]),e._v(" "),t("li",[t("a",{attrs:{href:"http://pebesma.staff.ifgi.de/openeo_del/openEO_D06_PrototypeBackEnds_v1.0.pdf",target:"_blank",rel:"noopener noreferrer"}},[e._v("Two early prototype back-ends"),t("OutboundLink")],1)]),e._v(" "),t("li",[t("a",{attrs:{href:"http://pebesma.staff.ifgi.de/openeo_del/openEO_D07_ProofOfConcept_v1.0.pdf",target:"_blank",rel:"noopener noreferrer"}},[e._v("Proof of Concept (Python)"),t("OutboundLink")],1)])]),e._v(" "),t("p",[e._v("In addition, a document has been written that describes standards and interfaces used by the various back-ends, and the extent to which they are or will be useful for further developing the openEO API:")]),e._v(" "),t("ul",[t("li",[t("a",{attrs:{href:"http://pebesma.staff.ifgi.de/openeo_del/openEO_D05_BackOfficeStandards_v1.0.pdf",target:"_blank",rel:"noopener noreferrer"}},[e._v("Overview document about back offices metadata standards and interfaces"),t("OutboundLink")],1)])]),e._v(" "),t("p",[e._v("These deliverables have been submitted, but have not been approved,\nand hence may not be final.")]),e._v(" "),t("h2",{attrs:{id:"next-steps"}},[t("a",{staticClass:"header-anchor",attrs:{href:"#next-steps"}},[e._v("#")]),e._v(" Next steps")]),e._v(" "),t("p",[e._v("During the proof-of-concept, intentionally a number of difficult issues were not addressed, including")]),e._v(" "),t("ul",[t("li",[e._v("billing (costs) of processes and account management and")]),e._v(" "),t("li",[e._v("authentification\nwhile others were defined rather vaguely, including")]),e._v(" "),t("li",[e._v("the description of data (end point "),t("code",[e._v("/data")]),e._v(")")]),e._v(" "),t("li",[e._v("the description of processes (end point "),t("code",[e._v("/processes")]),e._v(").")])]),e._v(" "),t("p",[e._v("The next steps will include:")]),e._v(" "),t("ul",[t("li",[e._v("discussing of the use-cases in the proof-of-concept")]),e._v(" "),t("li",[e._v("deciding whether to adopt existing standards and interfaces, e.g. for data descriptions")]),e._v(" "),t("li",[e._v("getting users involved outside the openEO consortium to define further requirements and priorities")]),e._v(" "),t("li",[e._v("designing a new iteration of the openEO API.")])]),e._v(" "),t("h2",{attrs:{id:"getting-involved"}},[t("a",{staticClass:"header-anchor",attrs:{href:"#getting-involved"}},[e._v("#")]),e._v(" Getting involved")]),e._v(" "),t("p",[e._v("As any API, the openAPI will only become good and useful if it is being used, and it needs testing by a wide audience. We are now at the stage of designing it, but at the point where large chunks are useful already. If you want to contribute to any of this, please do not hesitate and contact us e.g. by")]),e._v(" "),t("ul",[t("li",[e._v("expressing interest")]),e._v(" "),t("li",[e._v("writing GitHub issues wherever you think it is appropriate")]),e._v(" "),t("li",[e._v("sending an "),t("a",{attrs:{href:"mailto:openeo.psc@uni-muenster.de"}},[e._v("email")])])])])}),[],!1,null,null,null);t.default=r.exports}}]); \ No newline at end of file +(window.webpackJsonp=window.webpackJsonp||[]).push([[93],{543:function(e,t,n){"use strict";n.r(t);var a=n(4),r=Object(a.a)({},(function(){var e=this,t=e._self._c;return t("ContentSlotsDistributor",{attrs:{"slot-key":e.$parent.slotKey}},[t("h2",{attrs:{id:"the-problem"}},[t("a",{staticClass:"header-anchor",attrs:{href:"#the-problem"}},[e._v("#")]),e._v(" The problem")]),e._v(" "),t("p",[e._v("Earth Observation data are becoming too large to be downloaded\nlocally for analysis. Also, the way they are organised (as tiles,\nor "),t("em",[e._v("granules")]),e._v(": files containing the imagery for a small part of\nthe Earth and a single observation date) makes it unnecessary\ncomplicated to analyse them. The solution to this is to store these\ndata in the cloud, on compute back-ends, process them there, and\nbrowse the results or download resulting figures or numbers. But\nhow do we do that?")]),e._v(" "),t("p",[e._v("The aim of openEO is to develop an open API to connect R, python\nand javascript clients to big Earth observation cloud back-ends in\na simple and unified way.")]),e._v(" "),t("p",[e._v("With such an API,")]),e._v(" "),t("ul",[t("li",[e._v("each client can work with every back-end, and")]),e._v(" "),t("li",[e._v("it becomes possible to compare back-ends in terms of capacity,\ncost, and results (validation, reproducibility)")])]),e._v(" "),t("h2",{attrs:{id:"why-an-api"}},[t("a",{staticClass:"header-anchor",attrs:{href:"#why-an-api"}},[e._v("#")]),e._v(" Why an API?")]),e._v(" "),t("p",[e._v("An API is an application programming interface. It "),t("em",[e._v("defines")]),e._v("\na "),t("em",[e._v("language")]),e._v(" that two computers (a client and a server) use to\ncommunicate.")]),e._v(" "),t("p",[e._v("The following figure shows how many interfaces are needed to be able\nto compare back-ends from different clients, without an openEO API:")]),e._v(" "),t("p",[t("img",{attrs:{src:"/images/api.png",alt:"Current situation, without openEO API"}})]),e._v(" "),t("p",[e._v("With an openEO API (dark blue), the situation becomes much easier:")]),e._v(" "),t("p",[t("img",{attrs:{src:"/images/api2.png",alt:"Situation in the future, with openEO API"}})]),e._v(" "),t("p",[e._v("However, existing back-ends need to be taught to work with the new\nAPI, and clients that interact with back-ends need to be developed.")]),e._v(" "),t("p",[e._v("The task of the openEO project is to design, develop, and evaluate\nan API for cloud-based Earth Observation data processing.")]),e._v(" "),t("h2",{attrs:{id:"first-results"}},[t("a",{staticClass:"header-anchor",attrs:{href:"#first-results"}},[e._v("#")]),e._v(" First results")]),e._v(" "),t("p",[e._v("The openEO project started in Oct 2017. Now, within 6 months, we\nfinished the first proof of concept, and demonstrate it. Three use\ncases were selected for this, three clients were developed pretty\nmuch from scratch (Python, R, and JavaScript), and\nseven back-ends were built or interfaced. Full information is available\nfrom the projects "),t("a",{attrs:{href:"https://github.com/Open-EO/",target:"_blank",rel:"noopener noreferrer"}},[e._v("github organisation"),t("OutboundLink")],1),e._v(",\nand we point here to the")]),e._v(" "),t("ul",[t("li",[e._v("swagger-2.0 complient "),t("a",{attrs:{href:"https://github.com/Open-EO/openeo-api",target:"_blank",rel:"noopener noreferrer"}},[e._v("API"),t("OutboundLink")],1),e._v(" and its "),t("a",{attrs:{href:"https://open-eo.github.io/openeo-api/",target:"_blank",rel:"noopener noreferrer"}},[e._v("documentation"),t("OutboundLink")],1)])]),e._v(" "),t("h2",{attrs:{id:"the-three-use-cases"}},[t("a",{staticClass:"header-anchor",attrs:{href:"#the-three-use-cases"}},[e._v("#")]),e._v(" The three use cases")]),e._v(" "),t("p",[e._v("The three use cases comprise")]),e._v(" "),t("ol",[t("li",[e._v("Derive minimum NDVI measurements over pixel time series of Sentinel 2 imagery")]),e._v(" "),t("li",[e._v("Create a monthly aggregated Sentinel 1 product from a custom Python script")]),e._v(" "),t("li",[e._v("Compute time series of zonal (regional) statistics of Sentinel 2 imagery over user-uploaded polygons")])]),e._v(" "),t("p",[e._v("The full description, including the consecutive interaction steps of the API, is found on the")]),e._v(" "),t("ul",[t("li",[e._v("proof-of-concept "),t("a",{attrs:{href:"https://open-eo.github.io/openeo-api/poc/index.html",target:"_blank",rel:"noopener noreferrer"}},[e._v("use cases"),t("OutboundLink")],1),e._v(" site")])]),e._v(" "),t("h2",{attrs:{id:"links-to-the-client-and-back-end-implementations"}},[t("a",{staticClass:"header-anchor",attrs:{href:"#links-to-the-client-and-back-end-implementations"}},[e._v("#")]),e._v(" Links to the client and back-end implementations")]),e._v(" "),t("p",[e._v("Clients:")]),e._v(" "),t("ul",[t("li",[t("a",{attrs:{href:"https://github.com/Open-EO/openeo-python-client",target:"_blank",rel:"noopener noreferrer"}},[e._v("Python client"),t("OutboundLink")],1),e._v("; "),t("a",{attrs:{href:"https://github.com/Open-EO/openeo-python-client/blob/master/examples/notebooks/Compositing.ipynb",target:"_blank",rel:"noopener noreferrer"}},[e._v("Example notebook"),t("OutboundLink")],1)]),e._v(" "),t("li",[t("a",{attrs:{href:"https://github.com/Open-EO/openeo-r-client",target:"_blank",rel:"noopener noreferrer"}},[e._v("R client"),t("OutboundLink")],1)]),e._v(" "),t("li",[t("a",{attrs:{href:"https://github.com/Open-EO/openeo-js-client",target:"_blank",rel:"noopener noreferrer"}},[e._v("Javascript client"),t("OutboundLink")],1),e._v(" and "),t("a",{attrs:{href:"https://github.com/Open-EO/openeo-web-editor",target:"_blank",rel:"noopener noreferrer"}},[e._v("JavaScript web editor"),t("OutboundLink")],1)])]),e._v(" "),t("p",[e._v("Back-ends")]),e._v(" "),t("ul",[t("li",[t("a",{attrs:{href:"https://open-eo.github.io/openeo-grassgis-driver/",target:"_blank",rel:"noopener noreferrer"}},[e._v("GRASS GIS driver"),t("OutboundLink")],1)]),e._v(" "),t("li",[t("a",{attrs:{href:"https://github.com/Open-EO/openeo-wcps-driver",target:"_blank",rel:"noopener noreferrer"}},[e._v("WCPS driver"),t("OutboundLink")],1)]),e._v(" "),t("li",[t("a",{attrs:{href:"https://github.com/Open-EO/openeo-openshift-driver",target:"_blank",rel:"noopener noreferrer"}},[e._v("OpenShift driver"),t("OutboundLink")],1)]),e._v(" "),t("li",[t("a",{attrs:{href:"https://github.com/Open-EO/openeo-geopyspark-driver",target:"_blank",rel:"noopener noreferrer"}},[e._v("Python GeoPySpark/GeoTrellis driver"),t("OutboundLink")],1)]),e._v(" "),t("li",[t("a",{attrs:{href:"https://github.com/Open-EO/openeo-sentinelhub-driver",target:"_blank",rel:"noopener noreferrer"}},[e._v("Sentinel Hub driver"),t("OutboundLink")],1)]),e._v(" "),t("li",[t("a",{attrs:{href:"https://github.com/Open-EO/openeo-earthengine-driver",target:"_blank",rel:"noopener noreferrer"}},[e._v("Google Earth Engine back-end"),t("OutboundLink")],1)]),e._v(" "),t("li",[t("a",{attrs:{href:"https://github.com/Open-EO/openeo-r-backend",target:"_blank",rel:"noopener noreferrer"}},[e._v("R back-end"),t("OutboundLink")],1),e._v(" (developed for testing purposes)")])]),e._v(" "),t("p",[e._v('With all this, you can install your own back-end of choice, install\na client, and start analysing the data! (but do read "Next steps",\nbelow). Alternatively, we show a couple of videos of screen casts\nmade while testing the various clients and back-ends.')]),e._v(" "),t("h2",{attrs:{id:"proof-of-concept-videos"}},[t("a",{staticClass:"header-anchor",attrs:{href:"#proof-of-concept-videos"}},[e._v("#")]),e._v(" Proof-of-concept videos")]),e._v(" "),t("h3",{attrs:{id:"r-client-and-wcps-back-end-use-case-1"}},[t("a",{staticClass:"header-anchor",attrs:{href:"#r-client-and-wcps-back-end-use-case-1"}},[e._v("#")]),e._v(" R client and WCPS back-end, use case 1")]),e._v(" "),t("iframe",{attrs:{width:"560",height:"315",src:"https://www.youtube.com/embed/NoD0nVGM3ww",frameborder:"0",allowfullscreen:""}}),e._v(" "),t("h3",{attrs:{id:"grass-gis-back-end-use-cases-1-2-and-3"}},[t("a",{staticClass:"header-anchor",attrs:{href:"#grass-gis-back-end-use-cases-1-2-and-3"}},[e._v("#")]),e._v(" Grass GIS back-end, use cases 1, 2 and 3")]),e._v(" "),t("iframe",{attrs:{width:"560",height:"315",src:"https://www.youtube.com/embed/NgF1WgCtSiM",frameborder:"0",allowfullscreen:""}}),e._v(" "),t("h3",{attrs:{id:"r-client-and-r-back-end-use-case-1"}},[t("a",{staticClass:"header-anchor",attrs:{href:"#r-client-and-r-back-end-use-case-1"}},[e._v("#")]),e._v(" R client and R back-end, use-case 1")]),e._v(" "),t("iframe",{attrs:{width:"560",height:"315",src:"https://www.youtube.com/embed/Yb_QflO-ulE",frameborder:"0",allowfullscreen:""}}),e._v(" "),t("h3",{attrs:{id:"r-client-and-r-back-end-use-case-3"}},[t("a",{staticClass:"header-anchor",attrs:{href:"#r-client-and-r-back-end-use-case-3"}},[e._v("#")]),e._v(" R client and R back-end, use case 3")]),e._v(" "),t("iframe",{attrs:{width:"560",height:"315",src:"https://www.youtube.com/embed/LYnad6KC_CU",frameborder:"0",allowfullscreen:""}}),e._v(" "),t("h3",{attrs:{id:"openeo-web-editor-js-client-with-three-back-ends-use-case-1"}},[t("a",{staticClass:"header-anchor",attrs:{href:"#openeo-web-editor-js-client-with-three-back-ends-use-case-1"}},[e._v("#")]),e._v(" openEO Web Editor (JS client) with three back-ends (use case 1)")]),e._v(" "),t("p",[e._v("Demonstrates use of back-ends Sentinel Hub, WCPS EURAC, and OpenShift EODC")]),e._v(" "),t("iframe",{attrs:{width:"560",height:"315",src:"https://www.youtube.com/embed/zDaQkw0NhpY",frameborder:"0",allowfullscreen:""}}),e._v(" "),t("h3",{attrs:{id:"openeo-web-editor-js-client-with-r-back-end-use-case-3"}},[t("a",{staticClass:"header-anchor",attrs:{href:"#openeo-web-editor-js-client-with-r-back-end-use-case-3"}},[e._v("#")]),e._v(" openEO Web Editor (JS client) with R back-end (use case 3)")]),e._v(" "),t("iframe",{attrs:{width:"560",height:"315",src:"https://www.youtube.com/embed/XsPbKypUuIE",frameborder:"0",allowfullscreen:""}}),e._v(" "),t("h3",{attrs:{id:"python-client-with-geopyspark-back-end-use-case-1"}},[t("a",{staticClass:"header-anchor",attrs:{href:"#python-client-with-geopyspark-back-end-use-case-1"}},[e._v("#")]),e._v(" Python client with GeoPySpark back-end (use case 1)")]),e._v(" "),t("iframe",{attrs:{width:"560",height:"315",src:"https://www.youtube.com/embed/qtIp9OC0qHY",frameborder:"0",allowfullscreen:""}}),e._v(" "),t("h3",{attrs:{id:"openeo-web-editor-js-client-with-google-earth-engine-back-end-use-case-1"}},[t("a",{staticClass:"header-anchor",attrs:{href:"#openeo-web-editor-js-client-with-google-earth-engine-back-end-use-case-1"}},[e._v("#")]),e._v(" openEO Web Editor (JS client) with Google Earth Engine back-end (use case 1)")]),e._v(" "),t("iframe",{attrs:{width:"560",height:"315",src:"https://www.youtube.com/embed/LmUlmsIGJrs",frameborder:"0",allowfullscreen:""}}),e._v(" "),t("h2",{attrs:{id:"links-to-documents"}},[t("a",{staticClass:"header-anchor",attrs:{href:"#links-to-documents"}},[e._v("#")]),e._v(" Links to documents")]),e._v(" "),t("p",[e._v("The following four documents (formal project deliverables) describe the proof-of-concept more extensively:")]),e._v(" "),t("ul",[t("li",[t("a",{attrs:{href:"http://pebesma.staff.ifgi.de/openeo_del/openEO_D04_CoreAPIPrototype_v1.0.pdf",target:"_blank",rel:"noopener noreferrer"}},[e._v("openEO core API prototype including Proof of Concept"),t("OutboundLink")],1)]),e._v(" "),t("li",[t("a",{attrs:{href:"http://pebesma.staff.ifgi.de/openeo_del/openEO_D06_PrototypeBackEnds_v1.0.pdf",target:"_blank",rel:"noopener noreferrer"}},[e._v("Two early prototype back-ends"),t("OutboundLink")],1)]),e._v(" "),t("li",[t("a",{attrs:{href:"http://pebesma.staff.ifgi.de/openeo_del/openEO_D07_ProofOfConcept_v1.0.pdf",target:"_blank",rel:"noopener noreferrer"}},[e._v("Proof of Concept (Python)"),t("OutboundLink")],1)])]),e._v(" "),t("p",[e._v("In addition, a document has been written that describes standards and interfaces used by the various back-ends, and the extent to which they are or will be useful for further developing the openEO API:")]),e._v(" "),t("ul",[t("li",[t("a",{attrs:{href:"http://pebesma.staff.ifgi.de/openeo_del/openEO_D05_BackOfficeStandards_v1.0.pdf",target:"_blank",rel:"noopener noreferrer"}},[e._v("Overview document about back offices metadata standards and interfaces"),t("OutboundLink")],1)])]),e._v(" "),t("p",[e._v("These deliverables have been submitted, but have not been approved,\nand hence may not be final.")]),e._v(" "),t("h2",{attrs:{id:"next-steps"}},[t("a",{staticClass:"header-anchor",attrs:{href:"#next-steps"}},[e._v("#")]),e._v(" Next steps")]),e._v(" "),t("p",[e._v("During the proof-of-concept, intentionally a number of difficult issues were not addressed, including")]),e._v(" "),t("ul",[t("li",[e._v("billing (costs) of processes and account management and")]),e._v(" "),t("li",[e._v("authentification\nwhile others were defined rather vaguely, including")]),e._v(" "),t("li",[e._v("the description of data (end point "),t("code",[e._v("/data")]),e._v(")")]),e._v(" "),t("li",[e._v("the description of processes (end point "),t("code",[e._v("/processes")]),e._v(").")])]),e._v(" "),t("p",[e._v("The next steps will include:")]),e._v(" "),t("ul",[t("li",[e._v("discussing of the use-cases in the proof-of-concept")]),e._v(" "),t("li",[e._v("deciding whether to adopt existing standards and interfaces, e.g. for data descriptions")]),e._v(" "),t("li",[e._v("getting users involved outside the openEO consortium to define further requirements and priorities")]),e._v(" "),t("li",[e._v("designing a new iteration of the openEO API.")])]),e._v(" "),t("h2",{attrs:{id:"getting-involved"}},[t("a",{staticClass:"header-anchor",attrs:{href:"#getting-involved"}},[e._v("#")]),e._v(" Getting involved")]),e._v(" "),t("p",[e._v("As any API, the openAPI will only become good and useful if it is being used, and it needs testing by a wide audience. We are now at the stage of designing it, but at the point where large chunks are useful already. If you want to contribute to any of this, please do not hesitate and contact us e.g. by")]),e._v(" "),t("ul",[t("li",[e._v("expressing interest")]),e._v(" "),t("li",[e._v("writing GitHub issues wherever you think it is appropriate")]),e._v(" "),t("li",[e._v("sending an "),t("a",{attrs:{href:"mailto:openeo.psc@uni-muenster.de"}},[e._v("email")])])])])}),[],!1,null,null,null);t.default=r.exports}}]); \ No newline at end of file diff --git a/assets/js/94.c0bfab8b.js b/assets/js/94.f5ad02c7.js similarity index 95% rename from assets/js/94.c0bfab8b.js rename to assets/js/94.f5ad02c7.js index 264b71cac..91f0f02e7 100644 --- a/assets/js/94.c0bfab8b.js +++ b/assets/js/94.f5ad02c7.js @@ -1 +1 @@ -(window.webpackJsonp=window.webpackJsonp||[]).push([[94],{544:function(e,t,r){"use strict";r.r(t);var n=r(4),s=Object(n.a)({},(function(){var e=this._self._c;return e("ContentSlotsDistributor",{attrs:{"slot-key":this.$parent.slotKey}},[e("p",[e("a",{attrs:{href:"https://ec.europa.eu/eusurvey/runner/openEO_UserSurvey",target:"_blank",rel:"noopener noreferrer"}},[this._v("This survey"),e("OutboundLink")],1),this._v(" aims to gather a detailed view of external user needs in relation EO data access and analysis. This will enable the openEO project team to better identify current needs of different users and the potential for openEO to be useful to them and to overcome any barriers they have in their work streams. Ultimately, this will steer the openEO API in a way which meets user needs including being compatible with additional EO service providers and their data infrastructures. Additional processes and use cases will also be added where necessary with the aim of benefiting more potential users.")]),this._v(" "),e("p",[this._v("The survey is open to all, so please fill it in by 18 June 2018, and share within your relevant networks. It should take no longer than 10 minutes to complete.")]),this._v(" "),e("p",[e("a",{attrs:{href:"https://ec.europa.eu/eusurvey/runner/openEO_UserSurvey",target:"_blank",rel:"noopener noreferrer"}},[this._v("https://ec.europa.eu/eusurvey/runner/openEO_UserSurvey"),e("OutboundLink")],1)])])}),[],!1,null,null,null);t.default=s.exports}}]); \ No newline at end of file +(window.webpackJsonp=window.webpackJsonp||[]).push([[94],{542:function(e,t,r){"use strict";r.r(t);var n=r(4),s=Object(n.a)({},(function(){var e=this._self._c;return e("ContentSlotsDistributor",{attrs:{"slot-key":this.$parent.slotKey}},[e("p",[e("a",{attrs:{href:"https://ec.europa.eu/eusurvey/runner/openEO_UserSurvey",target:"_blank",rel:"noopener noreferrer"}},[this._v("This survey"),e("OutboundLink")],1),this._v(" aims to gather a detailed view of external user needs in relation EO data access and analysis. This will enable the openEO project team to better identify current needs of different users and the potential for openEO to be useful to them and to overcome any barriers they have in their work streams. Ultimately, this will steer the openEO API in a way which meets user needs including being compatible with additional EO service providers and their data infrastructures. Additional processes and use cases will also be added where necessary with the aim of benefiting more potential users.")]),this._v(" "),e("p",[this._v("The survey is open to all, so please fill it in by 18 June 2018, and share within your relevant networks. It should take no longer than 10 minutes to complete.")]),this._v(" "),e("p",[e("a",{attrs:{href:"https://ec.europa.eu/eusurvey/runner/openEO_UserSurvey",target:"_blank",rel:"noopener noreferrer"}},[this._v("https://ec.europa.eu/eusurvey/runner/openEO_UserSurvey"),e("OutboundLink")],1)])])}),[],!1,null,null,null);t.default=s.exports}}]); \ No newline at end of file diff --git a/assets/js/95.e58c7ed0.js b/assets/js/95.c62b49fb.js similarity index 98% rename from assets/js/95.e58c7ed0.js rename to assets/js/95.c62b49fb.js index c35bc968e..44fe07ad1 100644 --- a/assets/js/95.e58c7ed0.js +++ b/assets/js/95.c62b49fb.js @@ -1 +1 @@ -(window.webpackJsonp=window.webpackJsonp||[]).push([[95],{543:function(e,t,n){"use strict";n.r(t);var s=n(4),r=Object(s.a)({},(function(){var e=this,t=e._self._c;return t("ContentSlotsDistributor",{attrs:{"slot-key":e.$parent.slotKey}},[t("p",[e._v("The openEO consortium is currently undergoing its first evaluation process by the European Commission. During the first year the partners exceeded the planned progress. During the starting phase the meaning of the different layers was clarified more precisely. openEO represents a set of contracts between two API layers.")]),e._v(" "),t("ol",[t("li",[e._v("Instances of the core API are implemented at back-end drivers within the respective EO service providers. By guaranteeing the same instances at the various back-ends, their interoperability can be guaranteed.")]),e._v(" "),t("li",[e._v("Client APIs – software libraries specific to given programming languages – are enabling users to interact with the back-end's drivers.\nThe communication between clients and service providers is realised via HTTP requests, which's complexity is not visible to the users, but is dealt with by openEO.")])]),e._v(" "),t("p",[e._v("Since the successful development of the Proof of Concept, client APIs are developed for "),t("a",{attrs:{href:"https://github.com/Open-EO/openeo-python-client",target:"_blank",rel:"noopener noreferrer"}},[e._v("Python"),t("OutboundLink")],1),e._v(", "),t("a",{attrs:{href:"https://github.com/Open-EO/openeo-r-client",target:"_blank",rel:"noopener noreferrer"}},[e._v("R"),t("OutboundLink")],1),e._v(", and "),t("a",{attrs:{href:"https://github.com/Open-EO/openeo-js-client",target:"_blank",rel:"noopener noreferrer"}},[e._v("JavaScript"),t("OutboundLink")],1),e._v(", enabling the execution of a growing set of functionalities. Being language neutral, new client APIs of e.g. additional programming languages, Quantum GIS interfaces, or GRASS GIS can be added easily. Currently, the core API is establishing access to entry points of "),t("RouterLink",{attrs:{to:"/software.md/#back-ends"}},[e._v("7 European EO service providers")]),e._v(", which are thus able to provide services to the user, reflecting examples from all stages of EO data processing.")],1),e._v(" "),t("p",[e._v("A process catalogue is under development, describing a set of functionalities to be implemented for openEO, their I/O data and their exact workflow. Interested users are encouraged to discuss with the consortium partners via the various provided channels to enable openEO forming widely accepted and used standards with a consistent syntax. The well-defined process catalogue shall also serve 3rd-party processing platforms with a template to become accessible to openEO. In the same manner, a client library development guideline is being prepared momentarily to ensure a standardised implementation of the client APIs.")]),e._v(" "),t("p",[e._v("For using arbitrary code to process EO data with the openEO API, first User-Defined Functions (UDF) are currently implemented and added to openEO-compatible workflows. The UDFs are running in specific dockers at the EO data service providers.")]),e._v(" "),t("p",[e._v("openEO is published in its version "),t("a",{attrs:{href:"https://api.openeo.org/v/0.3.0/",target:"_blank",rel:"noopener noreferrer"}},[e._v("0.3.0"),t("OutboundLink")],1),e._v(", providing a HTTP communication between the users and service providers specified by OpenAPI 3.0 JSON files. The JSON data entails process graphs, sent as a job to the back-ends, which can be executed in three different ways.")]),e._v(" "),t("ol",[t("li",[e._v("A batch job can be submitted, which stays inactive until processing is requested. It will run only once and stores its results after execution.")]),e._v(" "),t("li",[e._v("Secondary web services allow web-based access using different protocols such as OGC WMS, OGC WCS or XYZ tiles. The computation runs on demand to allow users to change e.g. the result's viewing extent or level of detail.")]),e._v(" "),t("li",[e._v("Lightweight process graphs (e.g. small previews) can be executed synchronously. More costly processes have to expect timeouts for long-polling HTTP requests.")])]),e._v(" "),t("p",[e._v("The next steps for the consortium will entail the realisation of the newest openEO version at all back-ends and a definition of the targeted level of UDFs (e.g. simple NDVI calculation vs. machine learning algorithms). The process catalogues will be widened up, entailing at least all needed processes to implement the project's use cases via openEO. As an interested user please contact us, if you have any suggestions.")]),e._v(" "),t("p",[e._v("Finally, we plan to submit our first preliminary stable openEO version in May 2019.")])])}),[],!1,null,null,null);t.default=r.exports}}]); \ No newline at end of file +(window.webpackJsonp=window.webpackJsonp||[]).push([[95],{545:function(e,t,n){"use strict";n.r(t);var s=n(4),r=Object(s.a)({},(function(){var e=this,t=e._self._c;return t("ContentSlotsDistributor",{attrs:{"slot-key":e.$parent.slotKey}},[t("p",[e._v("The openEO consortium is currently undergoing its first evaluation process by the European Commission. During the first year the partners exceeded the planned progress. During the starting phase the meaning of the different layers was clarified more precisely. openEO represents a set of contracts between two API layers.")]),e._v(" "),t("ol",[t("li",[e._v("Instances of the core API are implemented at back-end drivers within the respective EO service providers. By guaranteeing the same instances at the various back-ends, their interoperability can be guaranteed.")]),e._v(" "),t("li",[e._v("Client APIs – software libraries specific to given programming languages – are enabling users to interact with the back-end's drivers.\nThe communication between clients and service providers is realised via HTTP requests, which's complexity is not visible to the users, but is dealt with by openEO.")])]),e._v(" "),t("p",[e._v("Since the successful development of the Proof of Concept, client APIs are developed for "),t("a",{attrs:{href:"https://github.com/Open-EO/openeo-python-client",target:"_blank",rel:"noopener noreferrer"}},[e._v("Python"),t("OutboundLink")],1),e._v(", "),t("a",{attrs:{href:"https://github.com/Open-EO/openeo-r-client",target:"_blank",rel:"noopener noreferrer"}},[e._v("R"),t("OutboundLink")],1),e._v(", and "),t("a",{attrs:{href:"https://github.com/Open-EO/openeo-js-client",target:"_blank",rel:"noopener noreferrer"}},[e._v("JavaScript"),t("OutboundLink")],1),e._v(", enabling the execution of a growing set of functionalities. Being language neutral, new client APIs of e.g. additional programming languages, Quantum GIS interfaces, or GRASS GIS can be added easily. Currently, the core API is establishing access to entry points of "),t("RouterLink",{attrs:{to:"/software.md/#back-ends"}},[e._v("7 European EO service providers")]),e._v(", which are thus able to provide services to the user, reflecting examples from all stages of EO data processing.")],1),e._v(" "),t("p",[e._v("A process catalogue is under development, describing a set of functionalities to be implemented for openEO, their I/O data and their exact workflow. Interested users are encouraged to discuss with the consortium partners via the various provided channels to enable openEO forming widely accepted and used standards with a consistent syntax. The well-defined process catalogue shall also serve 3rd-party processing platforms with a template to become accessible to openEO. In the same manner, a client library development guideline is being prepared momentarily to ensure a standardised implementation of the client APIs.")]),e._v(" "),t("p",[e._v("For using arbitrary code to process EO data with the openEO API, first User-Defined Functions (UDF) are currently implemented and added to openEO-compatible workflows. The UDFs are running in specific dockers at the EO data service providers.")]),e._v(" "),t("p",[e._v("openEO is published in its version "),t("a",{attrs:{href:"https://api.openeo.org/v/0.3.0/",target:"_blank",rel:"noopener noreferrer"}},[e._v("0.3.0"),t("OutboundLink")],1),e._v(", providing a HTTP communication between the users and service providers specified by OpenAPI 3.0 JSON files. The JSON data entails process graphs, sent as a job to the back-ends, which can be executed in three different ways.")]),e._v(" "),t("ol",[t("li",[e._v("A batch job can be submitted, which stays inactive until processing is requested. It will run only once and stores its results after execution.")]),e._v(" "),t("li",[e._v("Secondary web services allow web-based access using different protocols such as OGC WMS, OGC WCS or XYZ tiles. The computation runs on demand to allow users to change e.g. the result's viewing extent or level of detail.")]),e._v(" "),t("li",[e._v("Lightweight process graphs (e.g. small previews) can be executed synchronously. More costly processes have to expect timeouts for long-polling HTTP requests.")])]),e._v(" "),t("p",[e._v("The next steps for the consortium will entail the realisation of the newest openEO version at all back-ends and a definition of the targeted level of UDFs (e.g. simple NDVI calculation vs. machine learning algorithms). The process catalogues will be widened up, entailing at least all needed processes to implement the project's use cases via openEO. As an interested user please contact us, if you have any suggestions.")]),e._v(" "),t("p",[e._v("Finally, we plan to submit our first preliminary stable openEO version in May 2019.")])])}),[],!1,null,null,null);t.default=r.exports}}]); \ No newline at end of file diff --git a/assets/js/96.fcae4780.js b/assets/js/96.bc6caa5f.js similarity index 91% rename from assets/js/96.fcae4780.js rename to assets/js/96.bc6caa5f.js index f793ba7a2..daa60e5b3 100644 --- a/assets/js/96.fcae4780.js +++ b/assets/js/96.bc6caa5f.js @@ -1 +1 @@ -(window.webpackJsonp=window.webpackJsonp||[]).push([[96],{545:function(t,e,n){"use strict";n.r(e);var a=n(4),o=Object(a.a)({},(function(){var t=this._self._c;return t("ContentSlotsDistributor",{attrs:{"slot-key":this.$parent.slotKey}},[t("p",[this._v("openEO will participate, along with the four other H2020 projects funded under the same call, in the "),t("a",{attrs:{href:"https://ec.europa.eu/info/events/h2020-eo-big-data-hackathon-2019-nov-07_en",target:"_blank",rel:"noopener noreferrer"}},[this._v("H2020 EO Big Data Hackathon"),t("OutboundLink")],1),this._v(", which is open for participation.")]),this._v(" "),t("p",[this._v("The hackaton will take place on Nov 7 and 8, 2019, in Frascati, Italy.")])])}),[],!1,null,null,null);e.default=o.exports}}]); \ No newline at end of file +(window.webpackJsonp=window.webpackJsonp||[]).push([[96],{546:function(t,e,n){"use strict";n.r(e);var a=n(4),o=Object(a.a)({},(function(){var t=this._self._c;return t("ContentSlotsDistributor",{attrs:{"slot-key":this.$parent.slotKey}},[t("p",[this._v("openEO will participate, along with the four other H2020 projects funded under the same call, in the "),t("a",{attrs:{href:"https://ec.europa.eu/info/events/h2020-eo-big-data-hackathon-2019-nov-07_en",target:"_blank",rel:"noopener noreferrer"}},[this._v("H2020 EO Big Data Hackathon"),t("OutboundLink")],1),this._v(", which is open for participation.")]),this._v(" "),t("p",[this._v("The hackaton will take place on Nov 7 and 8, 2019, in Frascati, Italy.")])])}),[],!1,null,null,null);e.default=o.exports}}]); \ No newline at end of file diff --git a/assets/js/99.9cd13a05.js b/assets/js/99.9dbfecc0.js similarity index 99% rename from assets/js/99.9cd13a05.js rename to assets/js/99.9dbfecc0.js index e3e3e9e84..80802bba0 100644 --- a/assets/js/99.9cd13a05.js +++ b/assets/js/99.9dbfecc0.js @@ -1 +1 @@ -(window.webpackJsonp=window.webpackJsonp||[]).push([[99],{550:function(t,e,r){"use strict";r.r(e);var s=r(4),a=Object(s.a)({},(function(){var t=this,e=t._self._c;return e("ContentSlotsDistributor",{attrs:{"slot-key":t.$parent.slotKey}},[e("h3",{attrs:{id:"update"}},[e("a",{staticClass:"header-anchor",attrs:{href:"#update"}},[t._v("#")]),t._v(" UPDATE:")]),t._v(" "),e("p",[e("strong",[t._v("Presentations")]),t._v(" and "),e("strong",[t._v("Notebooks")]),t._v(" of the user workshop can be downloaded "),e("a",{attrs:{href:"https://owncloud.tuwien.ac.at/index.php/s/c469i4hvgaR15Ip",target:"_blank",rel:"noopener noreferrer"}},[t._v("here"),e("OutboundLink")],1),t._v(".")]),t._v(" "),e("hr"),t._v(" "),e("p",[t._v("openEO hosts a (virtual) user workshop on "),e("strong",[t._v("19 October 2020")]),t._v(" (10:30 - 16:30 CEST in two parts) and encourages interested parties to register for this event at "),e("a",{attrs:{href:"https://ec.europa.eu/eusurvey/runner/openEOUserWorkshop",target:"_blank",rel:"noopener noreferrer"}},[t._v("https://ec.europa.eu/eusurvey/runner/openEOUserWorkshop"),e("OutboundLink")],1),t._v(".")]),t._v(" "),e("p",[e("strong",[t._v("Needed preparation:")]),t._v(" Manuals for installing the various client APIs, recommended for testing openEO in guided sessions, can be found in the "),e("em",[t._v("User Documentation")]),t._v(" under "),e("em",[e("RouterLink",{attrs:{to:"/documentation/1.0/"}},[t._v("Getting Started")])],1),t._v(".")]),t._v(" "),e("p",[e("strong",[t._v("User questionnaire:")]),t._v(" Please help us also by spending some minutes for this "),e("a",{attrs:{href:"https://ec.europa.eu/eusurvey/runner/OpenEOFinalUserWorkshop",target:"_blank",rel:"noopener noreferrer"}},[t._v("user questionnaire"),e("OutboundLink")],1),t._v(".")]),t._v(" "),e("p",[e("strong",[t._v("Access details")]),t._v(": Please click the session topics below to connect to the corresponding sessions in Microsoft Teams.")]),t._v(" "),e("p",[e("strong",[t._v("Agenda:")])]),t._v(" "),e("table",[e("thead",[e("tr",[e("th",{attrs:{colspan:"5"}},[t._v("Part 1")])]),t._v(" "),e("tr",[e("th",[t._v("No.")]),t._v(" "),e("th",[t._v("Start")]),t._v(" "),e("th",[t._v("Duration")]),t._v(" "),e("th",[t._v("Topic")]),t._v(" "),e("th",[t._v("Remark")])])]),t._v(" "),e("tbody",[e("tr",[e("td",[t._v("1.1")]),t._v(" "),e("td",[t._v("10:30h")]),t._v(" "),e("td",[t._v("30min")]),t._v(" "),e("td",[e("a",{attrs:{href:"https://bit.ly/3lLblSX",target:"_blank"}},[t._v("Introduction into openEO + technical overview")])]),t._v(" "),e("td")]),t._v(" "),e("tr",[e("td",[t._v("1.2")]),t._v(" "),e("td",[t._v("11:00h")]),t._v(" "),e("td",[t._v("20min")]),t._v(" "),e("td",[e("a",{attrs:{href:"https://bit.ly/3lLblSX",target:"_blank"}},[t._v("Overview backends")])]),t._v(" "),e("td")]),t._v(" "),e("tr",[e("td",[t._v("1.3")]),t._v(" "),e("td",[t._v("11:20h")]),t._v(" "),e("td",[t._v("20min")]),t._v(" "),e("td",[e("a",{attrs:{href:"https://bit.ly/3lLblSX",target:"_blank"}},[t._v("Overview processes + documentation")])]),t._v(" "),e("td")]),t._v(" "),e("tr",[e("td",[t._v("1.4")]),t._v(" "),e("td",[t._v("11:40h")]),t._v(" "),e("td",[t._v("5min")]),t._v(" "),e("td",[e("a",{attrs:{href:"https://bit.ly/3lLblSX",target:"_blank"}},[t._v("Installation of openEO")])]),t._v(" "),e("td")]),t._v(" "),e("tr",[e("td",[t._v("1.5")]),t._v(" "),e("td",[t._v("11:45h")]),t._v(" "),e("td",[t._v("15min")]),t._v(" "),e("td",[e("a",{attrs:{href:"https://bit.ly/3lLblSX",target:"_blank"}},[t._v("Q/A: Backends, Installation, Q/A Chat")])]),t._v(" "),e("td",[t._v("Questionaire")])]),t._v(" "),e("tr",[e("td",{attrs:{colspan:"5"}},[e("i",[t._v("Break for users to install openEO, partners stay available in chat for answering questions on that in bilateral talks")])])]),t._v(" "),e("tr",[e("td",{attrs:{colspan:"5"}})])]),t._v(" "),e("thead",[e("tr",[e("th",{attrs:{colspan:"5"}},[t._v("Part 2")])]),t._v(" "),e("tr",[e("th",[t._v("No.")]),t._v(" "),e("th",[t._v("Start")]),t._v(" "),e("th",[t._v("Duration")]),t._v(" "),e("th",[t._v("Topic")]),t._v(" "),e("th",[t._v("Remark")])])]),t._v(" "),e("tbody",[e("tr",[e("td",[t._v("2.1")]),t._v(" "),e("td",[t._v("14:00h")]),t._v(" "),e("td",[t._v("5min")]),t._v(" "),e("td",[e("a",{attrs:{href:"https://bit.ly/3lLblSX",target:"_blank"}},[t._v("Welcome back / Ways for users to approach to openEO")])]),t._v(" "),e("td")]),t._v(" "),e("tr",[e("th",{attrs:{colspan:"5"}},[t._v("Live Demontrations, Part 1")])]),t._v(" "),e("tr",[e("td",[t._v("2.2a")]),t._v(" "),e("td",[t._v("14:05h")]),t._v(" "),e("td",[t._v("20min")]),t._v(" "),e("td",[e("a",{attrs:{href:"https://bit.ly/3lLblSX",target:"_blank"}},[t._v("Python Client")])]),t._v(" "),e("td",{attrs:{rowspan:"2"}},[t._v("Parallel session")])]),t._v(" "),e("tr",[e("td",[t._v("2.2b")]),t._v(" "),e("td",[t._v("14:05h")]),t._v(" "),e("td",[t._v("20min")]),t._v(" "),e("td",[e("a",{attrs:{href:"https://bit.ly/3iWreUB",target:"_blank"}},[t._v("JavaScript Client + mobile application")])])]),t._v(" "),e("tr",[e("td"),t._v(" "),e("td",[e("i",[t._v("14:25h")])]),t._v(" "),e("td",[e("i",[t._v("5min")])]),t._v(" "),e("td",{attrs:{colspan:"2"}},[e("i",[t._v("Short break / Switching sessions")])])]),t._v(" "),e("tr",[e("th",{attrs:{colspan:"5"}},[t._v("Live Demontrations, Part 2")])]),t._v(" "),e("tr",[e("td",[t._v("2.3a")]),t._v(" "),e("td",[t._v("14:30h")]),t._v(" "),e("td",[t._v("20min")]),t._v(" "),e("td",[e("a",{attrs:{href:"https://bit.ly/3lLblSX",target:"_blank"}},[t._v("Web Editor + QGIS")])]),t._v(" "),e("td",{attrs:{rowspan:"2"}},[t._v("Parallel session")])]),t._v(" "),e("tr",[e("td",[t._v("2.3b")]),t._v(" "),e("td",[t._v("14:30h")]),t._v(" "),e("td",[t._v("20min")]),t._v(" "),e("td",[e("a",{attrs:{href:"https://bit.ly/3iWreUB",target:"_blank"}},[t._v("R Client")])])]),t._v(" "),e("tr",[e("td"),t._v(" "),e("td",[e("i",[t._v("14:50h")])]),t._v(" "),e("td",[e("i",[t._v("5min")])]),t._v(" "),e("td",{attrs:{colspan:"2"}},[e("i",[t._v("Short break / Switching sessions")])])]),t._v(" "),e("tr",[e("th",{attrs:{colspan:"5"}},[t._v("Guided Sessions and Q/A")])]),t._v(" "),e("tr",[e("td",[t._v("2.4a")]),t._v(" "),e("td",[t._v("14:55h")]),t._v(" "),e("td",[t._v("60min")]),t._v(" "),e("td",[e("a",{attrs:{href:"https://bit.ly/3lLblSX",target:"_blank"}},[t._v("Guided room for users to test the R Client")])]),t._v(" "),e("td",{attrs:{rowspan:"3"}},[t._v("Parallel session")])]),t._v(" "),e("tr",[e("td",[t._v("2.4b")]),t._v(" "),e("td",[t._v("14:55h")]),t._v(" "),e("td",[t._v("60min")]),t._v(" "),e("td",[e("a",{attrs:{href:"https://bit.ly/3iWreUB",target:"_blank"}},[t._v("Guided room for users to test the Python Client")])])]),t._v(" "),e("tr",[e("td",[t._v("2.4c")]),t._v(" "),e("td",[t._v("14:55h")]),t._v(" "),e("td",[t._v("60min")]),t._v(" "),e("td",[e("a",{attrs:{href:"https://bit.ly/31bt2mH",target:"_blank"}},[t._v("Guided room for users to test other clients")])])]),t._v(" "),e("tr",[e("td",[t._v("2.5a")]),t._v(" "),e("td",[t._v("15:55h")]),t._v(" "),e("td",[t._v("15min")]),t._v(" "),e("td",[e("a",{attrs:{href:"https://bit.ly/3lLblSX",target:"_blank"}},[t._v("Q/A and Discussions: R Client")])]),t._v(" "),e("td",{attrs:{rowspan:"3"}},[t._v("Parallel session")])]),t._v(" "),e("tr",[e("td",[t._v("2.5b")]),t._v(" "),e("td",[t._v("15:55h")]),t._v(" "),e("td",[t._v("15min")]),t._v(" "),e("td",[e("a",{attrs:{href:"https://bit.ly/3iWreUB",target:"_blank"}},[t._v("Q/A and Discussions: Python")])])]),t._v(" "),e("tr",[e("td",[t._v("2.5c")]),t._v(" "),e("td",[t._v("15:55h")]),t._v(" "),e("td",[t._v("15min")]),t._v(" "),e("td",[e("a",{attrs:{href:"https://bit.ly/31bt2mH",target:"_blank"}},[t._v("Q/A and Discussions: Other clients")])])]),t._v(" "),e("tr",[e("th",{attrs:{colspan:"5"}},[t._v("Wrap up")])]),t._v(" "),e("tr",[e("td",[t._v("2.6")]),t._v(" "),e("td",[t._v("16:10h")]),t._v(" "),e("td",[t._v("20min")]),t._v(" "),e("td",[e("a",{attrs:{href:"https://bit.ly/3lLblSX",target:"_blank"}},[t._v("Q/A; Discussion on user needs, future work")])]),t._v(" "),e("td")])])]),t._v(" "),e("p",[e("strong",[t._v("Background:")]),t._v(" openEO is a user-driven open source API, which grants a uniform communication between the Earth Observation (EO) data user community and diverse EO cloud service providers. Thus, it aims for a cross-platform interoperability to ease a comparison, the cooperation and the switch between them. The project consortium (H2020 Grant No 776242) released a stable version of the openEO API, covering standardised online processing of all aspects of an EO data life cycle on diverse cloud platforms.")]),t._v(" "),e("p",[t._v("In this User Workshop, the audience is provided with insight into the functionalities of the openEO API. In various live demonstration and training sessions, real demonstration cases will be explained from the user perspective. Possible applications of the openEO API will be presented for different access levels – from the use of programming languages to browser based model builders or mobile applications. Target audience for this event are programmers, decision makers, as well as third-party cloud EO service providers.")])])}),[],!1,null,null,null);e.default=a.exports}}]); \ No newline at end of file +(window.webpackJsonp=window.webpackJsonp||[]).push([[99],{549:function(t,e,r){"use strict";r.r(e);var s=r(4),a=Object(s.a)({},(function(){var t=this,e=t._self._c;return e("ContentSlotsDistributor",{attrs:{"slot-key":t.$parent.slotKey}},[e("h3",{attrs:{id:"update"}},[e("a",{staticClass:"header-anchor",attrs:{href:"#update"}},[t._v("#")]),t._v(" UPDATE:")]),t._v(" "),e("p",[e("strong",[t._v("Presentations")]),t._v(" and "),e("strong",[t._v("Notebooks")]),t._v(" of the user workshop can be downloaded "),e("a",{attrs:{href:"https://owncloud.tuwien.ac.at/index.php/s/c469i4hvgaR15Ip",target:"_blank",rel:"noopener noreferrer"}},[t._v("here"),e("OutboundLink")],1),t._v(".")]),t._v(" "),e("hr"),t._v(" "),e("p",[t._v("openEO hosts a (virtual) user workshop on "),e("strong",[t._v("19 October 2020")]),t._v(" (10:30 - 16:30 CEST in two parts) and encourages interested parties to register for this event at "),e("a",{attrs:{href:"https://ec.europa.eu/eusurvey/runner/openEOUserWorkshop",target:"_blank",rel:"noopener noreferrer"}},[t._v("https://ec.europa.eu/eusurvey/runner/openEOUserWorkshop"),e("OutboundLink")],1),t._v(".")]),t._v(" "),e("p",[e("strong",[t._v("Needed preparation:")]),t._v(" Manuals for installing the various client APIs, recommended for testing openEO in guided sessions, can be found in the "),e("em",[t._v("User Documentation")]),t._v(" under "),e("em",[e("RouterLink",{attrs:{to:"/documentation/1.0/"}},[t._v("Getting Started")])],1),t._v(".")]),t._v(" "),e("p",[e("strong",[t._v("User questionnaire:")]),t._v(" Please help us also by spending some minutes for this "),e("a",{attrs:{href:"https://ec.europa.eu/eusurvey/runner/OpenEOFinalUserWorkshop",target:"_blank",rel:"noopener noreferrer"}},[t._v("user questionnaire"),e("OutboundLink")],1),t._v(".")]),t._v(" "),e("p",[e("strong",[t._v("Access details")]),t._v(": Please click the session topics below to connect to the corresponding sessions in Microsoft Teams.")]),t._v(" "),e("p",[e("strong",[t._v("Agenda:")])]),t._v(" "),e("table",[e("thead",[e("tr",[e("th",{attrs:{colspan:"5"}},[t._v("Part 1")])]),t._v(" "),e("tr",[e("th",[t._v("No.")]),t._v(" "),e("th",[t._v("Start")]),t._v(" "),e("th",[t._v("Duration")]),t._v(" "),e("th",[t._v("Topic")]),t._v(" "),e("th",[t._v("Remark")])])]),t._v(" "),e("tbody",[e("tr",[e("td",[t._v("1.1")]),t._v(" "),e("td",[t._v("10:30h")]),t._v(" "),e("td",[t._v("30min")]),t._v(" "),e("td",[e("a",{attrs:{href:"https://bit.ly/3lLblSX",target:"_blank"}},[t._v("Introduction into openEO + technical overview")])]),t._v(" "),e("td")]),t._v(" "),e("tr",[e("td",[t._v("1.2")]),t._v(" "),e("td",[t._v("11:00h")]),t._v(" "),e("td",[t._v("20min")]),t._v(" "),e("td",[e("a",{attrs:{href:"https://bit.ly/3lLblSX",target:"_blank"}},[t._v("Overview backends")])]),t._v(" "),e("td")]),t._v(" "),e("tr",[e("td",[t._v("1.3")]),t._v(" "),e("td",[t._v("11:20h")]),t._v(" "),e("td",[t._v("20min")]),t._v(" "),e("td",[e("a",{attrs:{href:"https://bit.ly/3lLblSX",target:"_blank"}},[t._v("Overview processes + documentation")])]),t._v(" "),e("td")]),t._v(" "),e("tr",[e("td",[t._v("1.4")]),t._v(" "),e("td",[t._v("11:40h")]),t._v(" "),e("td",[t._v("5min")]),t._v(" "),e("td",[e("a",{attrs:{href:"https://bit.ly/3lLblSX",target:"_blank"}},[t._v("Installation of openEO")])]),t._v(" "),e("td")]),t._v(" "),e("tr",[e("td",[t._v("1.5")]),t._v(" "),e("td",[t._v("11:45h")]),t._v(" "),e("td",[t._v("15min")]),t._v(" "),e("td",[e("a",{attrs:{href:"https://bit.ly/3lLblSX",target:"_blank"}},[t._v("Q/A: Backends, Installation, Q/A Chat")])]),t._v(" "),e("td",[t._v("Questionaire")])]),t._v(" "),e("tr",[e("td",{attrs:{colspan:"5"}},[e("i",[t._v("Break for users to install openEO, partners stay available in chat for answering questions on that in bilateral talks")])])]),t._v(" "),e("tr",[e("td",{attrs:{colspan:"5"}})])]),t._v(" "),e("thead",[e("tr",[e("th",{attrs:{colspan:"5"}},[t._v("Part 2")])]),t._v(" "),e("tr",[e("th",[t._v("No.")]),t._v(" "),e("th",[t._v("Start")]),t._v(" "),e("th",[t._v("Duration")]),t._v(" "),e("th",[t._v("Topic")]),t._v(" "),e("th",[t._v("Remark")])])]),t._v(" "),e("tbody",[e("tr",[e("td",[t._v("2.1")]),t._v(" "),e("td",[t._v("14:00h")]),t._v(" "),e("td",[t._v("5min")]),t._v(" "),e("td",[e("a",{attrs:{href:"https://bit.ly/3lLblSX",target:"_blank"}},[t._v("Welcome back / Ways for users to approach to openEO")])]),t._v(" "),e("td")]),t._v(" "),e("tr",[e("th",{attrs:{colspan:"5"}},[t._v("Live Demontrations, Part 1")])]),t._v(" "),e("tr",[e("td",[t._v("2.2a")]),t._v(" "),e("td",[t._v("14:05h")]),t._v(" "),e("td",[t._v("20min")]),t._v(" "),e("td",[e("a",{attrs:{href:"https://bit.ly/3lLblSX",target:"_blank"}},[t._v("Python Client")])]),t._v(" "),e("td",{attrs:{rowspan:"2"}},[t._v("Parallel session")])]),t._v(" "),e("tr",[e("td",[t._v("2.2b")]),t._v(" "),e("td",[t._v("14:05h")]),t._v(" "),e("td",[t._v("20min")]),t._v(" "),e("td",[e("a",{attrs:{href:"https://bit.ly/3iWreUB",target:"_blank"}},[t._v("JavaScript Client + mobile application")])])]),t._v(" "),e("tr",[e("td"),t._v(" "),e("td",[e("i",[t._v("14:25h")])]),t._v(" "),e("td",[e("i",[t._v("5min")])]),t._v(" "),e("td",{attrs:{colspan:"2"}},[e("i",[t._v("Short break / Switching sessions")])])]),t._v(" "),e("tr",[e("th",{attrs:{colspan:"5"}},[t._v("Live Demontrations, Part 2")])]),t._v(" "),e("tr",[e("td",[t._v("2.3a")]),t._v(" "),e("td",[t._v("14:30h")]),t._v(" "),e("td",[t._v("20min")]),t._v(" "),e("td",[e("a",{attrs:{href:"https://bit.ly/3lLblSX",target:"_blank"}},[t._v("Web Editor + QGIS")])]),t._v(" "),e("td",{attrs:{rowspan:"2"}},[t._v("Parallel session")])]),t._v(" "),e("tr",[e("td",[t._v("2.3b")]),t._v(" "),e("td",[t._v("14:30h")]),t._v(" "),e("td",[t._v("20min")]),t._v(" "),e("td",[e("a",{attrs:{href:"https://bit.ly/3iWreUB",target:"_blank"}},[t._v("R Client")])])]),t._v(" "),e("tr",[e("td"),t._v(" "),e("td",[e("i",[t._v("14:50h")])]),t._v(" "),e("td",[e("i",[t._v("5min")])]),t._v(" "),e("td",{attrs:{colspan:"2"}},[e("i",[t._v("Short break / Switching sessions")])])]),t._v(" "),e("tr",[e("th",{attrs:{colspan:"5"}},[t._v("Guided Sessions and Q/A")])]),t._v(" "),e("tr",[e("td",[t._v("2.4a")]),t._v(" "),e("td",[t._v("14:55h")]),t._v(" "),e("td",[t._v("60min")]),t._v(" "),e("td",[e("a",{attrs:{href:"https://bit.ly/3lLblSX",target:"_blank"}},[t._v("Guided room for users to test the R Client")])]),t._v(" "),e("td",{attrs:{rowspan:"3"}},[t._v("Parallel session")])]),t._v(" "),e("tr",[e("td",[t._v("2.4b")]),t._v(" "),e("td",[t._v("14:55h")]),t._v(" "),e("td",[t._v("60min")]),t._v(" "),e("td",[e("a",{attrs:{href:"https://bit.ly/3iWreUB",target:"_blank"}},[t._v("Guided room for users to test the Python Client")])])]),t._v(" "),e("tr",[e("td",[t._v("2.4c")]),t._v(" "),e("td",[t._v("14:55h")]),t._v(" "),e("td",[t._v("60min")]),t._v(" "),e("td",[e("a",{attrs:{href:"https://bit.ly/31bt2mH",target:"_blank"}},[t._v("Guided room for users to test other clients")])])]),t._v(" "),e("tr",[e("td",[t._v("2.5a")]),t._v(" "),e("td",[t._v("15:55h")]),t._v(" "),e("td",[t._v("15min")]),t._v(" "),e("td",[e("a",{attrs:{href:"https://bit.ly/3lLblSX",target:"_blank"}},[t._v("Q/A and Discussions: R Client")])]),t._v(" "),e("td",{attrs:{rowspan:"3"}},[t._v("Parallel session")])]),t._v(" "),e("tr",[e("td",[t._v("2.5b")]),t._v(" "),e("td",[t._v("15:55h")]),t._v(" "),e("td",[t._v("15min")]),t._v(" "),e("td",[e("a",{attrs:{href:"https://bit.ly/3iWreUB",target:"_blank"}},[t._v("Q/A and Discussions: Python")])])]),t._v(" "),e("tr",[e("td",[t._v("2.5c")]),t._v(" "),e("td",[t._v("15:55h")]),t._v(" "),e("td",[t._v("15min")]),t._v(" "),e("td",[e("a",{attrs:{href:"https://bit.ly/31bt2mH",target:"_blank"}},[t._v("Q/A and Discussions: Other clients")])])]),t._v(" "),e("tr",[e("th",{attrs:{colspan:"5"}},[t._v("Wrap up")])]),t._v(" "),e("tr",[e("td",[t._v("2.6")]),t._v(" "),e("td",[t._v("16:10h")]),t._v(" "),e("td",[t._v("20min")]),t._v(" "),e("td",[e("a",{attrs:{href:"https://bit.ly/3lLblSX",target:"_blank"}},[t._v("Q/A; Discussion on user needs, future work")])]),t._v(" "),e("td")])])]),t._v(" "),e("p",[e("strong",[t._v("Background:")]),t._v(" openEO is a user-driven open source API, which grants a uniform communication between the Earth Observation (EO) data user community and diverse EO cloud service providers. Thus, it aims for a cross-platform interoperability to ease a comparison, the cooperation and the switch between them. The project consortium (H2020 Grant No 776242) released a stable version of the openEO API, covering standardised online processing of all aspects of an EO data life cycle on diverse cloud platforms.")]),t._v(" "),e("p",[t._v("In this User Workshop, the audience is provided with insight into the functionalities of the openEO API. In various live demonstration and training sessions, real demonstration cases will be explained from the user perspective. Possible applications of the openEO API will be presented for different access levels – from the use of programming languages to browser based model builders or mobile applications. Target audience for this event are programmers, decision makers, as well as third-party cloud EO service providers.")])])}),[],!1,null,null,null);e.default=a.exports}}]); \ No newline at end of file diff --git a/assets/js/app.3d9b00a6.js b/assets/js/app.23959bb1.js similarity index 81% rename from assets/js/app.3d9b00a6.js rename to assets/js/app.23959bb1.js index cfe4efe86..b1bfa6e28 100644 --- a/assets/js/app.3d9b00a6.js +++ b/assets/js/app.23959bb1.js @@ -1,4 +1,4 @@ -(window.webpackJsonp=window.webpackJsonp||[]).push([[0],[]]);!function(e){function t(t){for(var r,i,s=t[0],l=t[1],c=t[2],p=0,d=[];p=0&&(t=e.slice(r),e=e.slice(0,r));var o=e.indexOf("?");return o>=0&&(n=e.slice(o+1),e=e.slice(0,o)),{path:e,query:n,hash:t}}(a.path||""),d=t&&t.path||"/",f=c.path?k(c.path,d,n||a.append):d,h=function(e,t,n){void 0===t&&(t={});var r,o=n||p;try{r=o(e||"")}catch(e){r={}}for(var a in t){var i=t[a];r[a]=Array.isArray(i)?i.map(u):u(i)}return r}(c.query,a.query,r&&r.options.parseQuery),v=a.hash||c.hash;return v&&"#"!==v.charAt(0)&&(v="#"+v),{_normalized:!0,path:f,query:h,hash:v}}var q,G=function(){},W={name:"RouterLink",props:{to:{type:[String,Object],required:!0},tag:{type:String,default:"a"},custom:Boolean,exact:Boolean,exactPath:Boolean,append:Boolean,replace:Boolean,activeClass:String,exactActiveClass:String,ariaCurrentValue:{type:String,default:"page"},event:{type:[String,Array],default:"click"}},render:function(e){var t=this,n=this.$router,r=this.$route,a=n.resolve(this.to,r,this.append),i=a.location,s=a.route,l=a.href,c={},u=n.options.linkActiveClass,p=n.options.linkExactActiveClass,d=null==u?"router-link-active":u,v=null==p?"router-link-exact-active":p,m=null==this.activeClass?d:this.activeClass,g=null==this.exactActiveClass?v:this.exactActiveClass,y=s.redirectedFrom?h(null,z(s.redirectedFrom),null,n):s;c[g]=b(r,y,this.exactPath),c[m]=this.exact||this.exactPath?c[g]:function(e,t){return 0===e.path.replace(f,"/").indexOf(t.path.replace(f,"/"))&&(!t.hash||e.hash===t.hash)&&function(e,t){for(var n in t)if(!(n in e))return!1;return!0}(e.query,t.query)}(r,y);var w=c[g]?this.ariaCurrentValue:null,_=function(e){H(e)&&(t.replace?n.replace(i,G):n.push(i,G))},x={click:H};Array.isArray(this.event)?this.event.forEach((function(e){x[e]=_})):x[this.event]=_;var P={class:c},k=!this.$scopedSlots.$hasNormal&&this.$scopedSlots.default&&this.$scopedSlots.default({href:l,route:s,navigate:_,isActive:c[m],isExactActive:c[g]});if(k){if(1===k.length)return k[0];if(k.length>1||!k.length)return 0===k.length?e():e("span",{},k)}if("a"===this.tag)P.on=x,P.attrs={href:l,"aria-current":w};else{var S=function e(t){var n;if(t)for(var r=0;r-1&&(s.params[d]=n.params[d]);return s.path=V(u.path,s.params),l(u,s,i)}if(s.path){s.params={};for(var f=0;f-1}function Se(e,t){return ke(e)&&e._isRouter&&(null==t||e.type===t)}function Oe(e,t,n){var r=function(o){o>=e.length?n():e[o]?t(e[o],(function(){r(o+1)})):r(o+1)};r(0)}function Ce(e){return function(t,n,r){var o=!1,a=0,i=null;Ee(e,(function(e,t,n,s){if("function"==typeof e&&void 0===e.cid){o=!0,a++;var l,c=Te((function(t){var o;((o=t).__esModule||$e&&"Module"===o[Symbol.toStringTag])&&(t=t.default),e.resolved="function"==typeof t?t:q.extend(t),n.components[s]=t,--a<=0&&r()})),u=Te((function(e){var t="Failed to resolve async component "+s+": "+e;i||(i=ke(e)?e:new Error(t),r(i))}));try{l=e(c,u)}catch(e){u(e)}if(l)if("function"==typeof l.then)l.then(c,u);else{var p=l.component;p&&"function"==typeof p.then&&p.then(c,u)}}})),o||r()}}function Ee(e,t){return je(e.map((function(e){return Object.keys(e.components).map((function(n){return t(e.components[n],e.instances[n],e,n)}))})))}function je(e){return Array.prototype.concat.apply([],e)}var $e="function"==typeof Symbol&&"symbol"==typeof Symbol.toStringTag;function Te(e){var t=!1;return function(){for(var n=[],r=arguments.length;r--;)n[r]=arguments[r];if(!t)return t=!0,e.apply(this,n)}}var Ae=function(e,t){this.router=e,this.base=function(e){if(!e)if(Z){var t=document.querySelector("base");e=(e=t&&t.getAttribute("href")||"/").replace(/^https?:\/\/[^\/]+/,"")}else e="/";"/"!==e.charAt(0)&&(e="/"+e);return e.replace(/\/$/,"")}(t),this.current=m,this.pending=null,this.ready=!1,this.readyCbs=[],this.readyErrorCbs=[],this.errorCbs=[],this.listeners=[]};function Re(e,t,n,r){var o=Ee(e,(function(e,r,o,a){var i=function(e,t){"function"!=typeof e&&(e=q.extend(e));return e.options[t]}(e,t);if(i)return Array.isArray(i)?i.map((function(e){return n(e,r,o,a)})):n(i,r,o,a)}));return je(r?o.reverse():o)}function Ue(e,t){if(t)return function(){return e.apply(t,arguments)}}Ae.prototype.listen=function(e){this.cb=e},Ae.prototype.onReady=function(e,t){this.ready?e():(this.readyCbs.push(e),t&&this.readyErrorCbs.push(t))},Ae.prototype.onError=function(e){this.errorCbs.push(e)},Ae.prototype.transitionTo=function(e,t,n){var r,o=this;try{r=this.router.match(e,this.current)}catch(e){throw this.errorCbs.forEach((function(t){t(e)})),e}var a=this.current;this.confirmTransition(r,(function(){o.updateRoute(r),t&&t(r),o.ensureURL(),o.router.afterHooks.forEach((function(e){e&&e(r,a)})),o.ready||(o.ready=!0,o.readyCbs.forEach((function(e){e(r)})))}),(function(e){n&&n(e),e&&!o.ready&&(Se(e,be.redirected)&&a===m||(o.ready=!0,o.readyErrorCbs.forEach((function(t){t(e)}))))}))},Ae.prototype.confirmTransition=function(e,t,n){var r=this,o=this.current;this.pending=e;var a,i,s=function(e){!Se(e)&&ke(e)&&(r.errorCbs.length?r.errorCbs.forEach((function(t){t(e)})):console.error(e)),n&&n(e)},l=e.matched.length-1,c=o.matched.length-1;if(b(e,o)&&l===c&&e.matched[l]===o.matched[c])return this.ensureURL(),e.hash&&se(this.router,o,e,!1),s(((i=xe(a=o,e,be.duplicated,'Avoided redundant navigation to current location: "'+a.fullPath+'".')).name="NavigationDuplicated",i));var u=function(e,t){var n,r=Math.max(e.length,t.length);for(n=0;n0)){var t=this.router,n=t.options.scrollBehavior,r=me&&n;r&&this.listeners.push(ie());var o=function(){var n=e.current,o=Le(e.base);e.current===m&&o===e._startLocation||e.transitionTo(o,(function(e){r&&se(t,e,n,!0)}))};window.addEventListener("popstate",o),this.listeners.push((function(){window.removeEventListener("popstate",o)}))}},t.prototype.go=function(e){window.history.go(e)},t.prototype.push=function(e,t,n){var r=this,o=this.current;this.transitionTo(e,(function(e){ge(S(r.base+e.fullPath)),se(r.router,e,o,!1),t&&t(e)}),n)},t.prototype.replace=function(e,t,n){var r=this,o=this.current;this.transitionTo(e,(function(e){ye(S(r.base+e.fullPath)),se(r.router,e,o,!1),t&&t(e)}),n)},t.prototype.ensureURL=function(e){if(Le(this.base)!==this.current.fullPath){var t=S(this.base+this.current.fullPath);e?ge(t):ye(t)}},t.prototype.getCurrentLocation=function(){return Le(this.base)},t}(Ae);function Le(e){var t=window.location.pathname,n=t.toLowerCase(),r=e.toLowerCase();return!e||n!==r&&0!==n.indexOf(S(r+"/"))||(t=t.slice(e.length)),(t||"/")+window.location.search+window.location.hash}var Ie=function(e){function t(t,n,r){e.call(this,t,n),r&&function(e){var t=Le(e);if(!/^\/#/.test(t))return window.location.replace(S(e+"/#"+t)),!0}(this.base)||De()}return e&&(t.__proto__=e),t.prototype=Object.create(e&&e.prototype),t.prototype.constructor=t,t.prototype.setupListeners=function(){var e=this;if(!(this.listeners.length>0)){var t=this.router.options.scrollBehavior,n=me&&t;n&&this.listeners.push(ie());var r=function(){var t=e.current;De()&&e.transitionTo(Ne(),(function(r){n&&se(e.router,r,t,!0),me||Be(r.fullPath)}))},o=me?"popstate":"hashchange";window.addEventListener(o,r),this.listeners.push((function(){window.removeEventListener(o,r)}))}},t.prototype.push=function(e,t,n){var r=this,o=this.current;this.transitionTo(e,(function(e){Je(e.fullPath),se(r.router,e,o,!1),t&&t(e)}),n)},t.prototype.replace=function(e,t,n){var r=this,o=this.current;this.transitionTo(e,(function(e){Be(e.fullPath),se(r.router,e,o,!1),t&&t(e)}),n)},t.prototype.go=function(e){window.history.go(e)},t.prototype.ensureURL=function(e){var t=this.current.fullPath;Ne()!==t&&(e?Je(t):Be(t))},t.prototype.getCurrentLocation=function(){return Ne()},t}(Ae);function De(){var e=Ne();return"/"===e.charAt(0)||(Be("/"+e),!1)}function Ne(){var e=window.location.href,t=e.indexOf("#");return t<0?"":e=e.slice(t+1)}function Fe(e){var t=window.location.href,n=t.indexOf("#");return(n>=0?t.slice(0,n):t)+"#"+e}function Je(e){me?ge(Fe(e)):window.location.hash=e}function Be(e){me?ye(Fe(e)):window.location.replace(Fe(e))}var Ve=function(e){function t(t,n){e.call(this,t,n),this.stack=[],this.index=-1}return e&&(t.__proto__=e),t.prototype=Object.create(e&&e.prototype),t.prototype.constructor=t,t.prototype.push=function(e,t,n){var r=this;this.transitionTo(e,(function(e){r.stack=r.stack.slice(0,r.index+1).concat(e),r.index++,t&&t(e)}),n)},t.prototype.replace=function(e,t,n){var r=this;this.transitionTo(e,(function(e){r.stack=r.stack.slice(0,r.index).concat(e),t&&t(e)}),n)},t.prototype.go=function(e){var t=this,n=this.index+e;if(!(n<0||n>=this.stack.length)){var r=this.stack[n];this.confirmTransition(r,(function(){var e=t.current;t.index=n,t.updateRoute(r),t.router.afterHooks.forEach((function(t){t&&t(r,e)}))}),(function(e){Se(e,be.duplicated)&&(t.index=n)}))}},t.prototype.getCurrentLocation=function(){var e=this.stack[this.stack.length-1];return e?e.fullPath:"/"},t.prototype.ensureURL=function(){},t}(Ae),ze=function(e){void 0===e&&(e={}),this.app=null,this.apps=[],this.options=e,this.beforeHooks=[],this.resolveHooks=[],this.afterHooks=[],this.matcher=Q(e.routes||[],this);var t=e.mode||"hash";switch(this.fallback="history"===t&&!me&&!1!==e.fallback,this.fallback&&(t="hash"),Z||(t="abstract"),this.mode=t,t){case"history":this.history=new Me(this,e.base);break;case"hash":this.history=new Ie(this,e.base,this.fallback);break;case"abstract":this.history=new Ve(this,e.base);break;default:0}},qe={currentRoute:{configurable:!0}};ze.prototype.match=function(e,t,n){return this.matcher.match(e,t,n)},qe.currentRoute.get=function(){return this.history&&this.history.current},ze.prototype.init=function(e){var t=this;if(this.apps.push(e),e.$once("hook:destroyed",(function(){var n=t.apps.indexOf(e);n>-1&&t.apps.splice(n,1),t.app===e&&(t.app=t.apps[0]||null),t.app||t.history.teardown()})),!this.app){this.app=e;var n=this.history;if(n instanceof Me||n instanceof Ie){var r=function(e){n.setupListeners(),function(e){var r=n.current,o=t.options.scrollBehavior;me&&o&&"fullPath"in e&&se(t,e,r,!1)}(e)};n.transitionTo(n.getCurrentLocation(),r,r)}n.listen((function(e){t.apps.forEach((function(t){t._route=e}))}))}},ze.prototype.beforeEach=function(e){return We(this.beforeHooks,e)},ze.prototype.beforeResolve=function(e){return We(this.resolveHooks,e)},ze.prototype.afterEach=function(e){return We(this.afterHooks,e)},ze.prototype.onReady=function(e,t){this.history.onReady(e,t)},ze.prototype.onError=function(e){this.history.onError(e)},ze.prototype.push=function(e,t,n){var r=this;if(!t&&!n&&"undefined"!=typeof Promise)return new Promise((function(t,n){r.history.push(e,t,n)}));this.history.push(e,t,n)},ze.prototype.replace=function(e,t,n){var r=this;if(!t&&!n&&"undefined"!=typeof Promise)return new Promise((function(t,n){r.history.replace(e,t,n)}));this.history.replace(e,t,n)},ze.prototype.go=function(e){this.history.go(e)},ze.prototype.back=function(){this.go(-1)},ze.prototype.forward=function(){this.go(1)},ze.prototype.getMatchedComponents=function(e){var t=e?e.matched?e:this.resolve(e).route:this.currentRoute;return t?[].concat.apply([],t.matched.map((function(e){return Object.keys(e.components).map((function(t){return e.components[t]}))}))):[]},ze.prototype.resolve=function(e,t,n){var r=z(e,t=t||this.history.current,n,this),o=this.match(r,t),a=o.redirectedFrom||o.fullPath;return{location:r,route:o,href:function(e,t,n){var r="hash"===n?"#"+t:t;return e?S(e+"/"+r):r}(this.history.base,a,this.mode),normalizedTo:r,resolved:o}},ze.prototype.getRoutes=function(){return this.matcher.getRoutes()},ze.prototype.addRoute=function(e,t){this.matcher.addRoute(e,t),this.history.current!==m&&this.history.transitionTo(this.history.getCurrentLocation())},ze.prototype.addRoutes=function(e){this.matcher.addRoutes(e),this.history.current!==m&&this.history.transitionTo(this.history.getCurrentLocation())},Object.defineProperties(ze.prototype,qe);var Ge=ze;function We(e,t){return e.push(t),function(){var n=e.indexOf(t);n>-1&&e.splice(n,1)}}ze.install=function e(t){if(!e.installed||q!==t){e.installed=!0,q=t;var n=function(e){return void 0!==e},r=function(e,t){var r=e.$options._parentVnode;n(r)&&n(r=r.data)&&n(r=r.registerRouteInstance)&&r(e,t)};t.mixin({beforeCreate:function(){n(this.$options.router)?(this._routerRoot=this,this._router=this.$options.router,this._router.init(this),t.util.defineReactive(this,"_route",this._router.history.current)):this._routerRoot=this.$parent&&this.$parent._routerRoot||this,r(this,this)},destroyed:function(){r(this)}}),Object.defineProperty(t.prototype,"$router",{get:function(){return this._routerRoot._router}}),Object.defineProperty(t.prototype,"$route",{get:function(){return this._routerRoot._route}}),t.component("RouterView",x),t.component("RouterLink",W);var o=t.config.optionMergeStrategies;o.beforeRouteEnter=o.beforeRouteLeave=o.beforeRouteUpdate=o.created}},ze.version="3.6.5",ze.isNavigationFailure=Se,ze.NavigationFailureType=be,ze.START_LOCATION=m,Z&&window.Vue&&window.Vue.use(ze);var He={"components/AlgoliaSearchBox":()=>Promise.all([n.e(0),n.e(29)]).then(n.bind(null,290)),"components/DropdownLink":()=>Promise.all([n.e(0),n.e(17)]).then(n.bind(null,180)),"components/DropdownTransition":()=>Promise.all([n.e(0),n.e(30)]).then(n.bind(null,160)),"components/Home":()=>Promise.all([n.e(0),n.e(23)]).then(n.bind(null,291)),"components/NavLink":()=>n.e(38).then(n.bind(null,159)),"components/NavLinks":()=>Promise.all([n.e(0),n.e(16)]).then(n.bind(null,200)),"components/Navbar":()=>Promise.all([n.e(0),n.e(1)]).then(n.bind(null,465)),"components/Page":()=>Promise.all([n.e(0),n.e(14)]).then(n.bind(null,292)),"components/PageEdit":()=>Promise.all([n.e(0),n.e(24)]).then(n.bind(null,205)),"components/PageNav":()=>Promise.all([n.e(0),n.e(21)]).then(n.bind(null,206)),"components/Sidebar":()=>Promise.all([n.e(0),n.e(12)]).then(n.bind(null,293)),"components/SidebarButton":()=>Promise.all([n.e(0),n.e(31)]).then(n.bind(null,296)),"components/SidebarGroup":()=>Promise.all([n.e(0),n.e(3)]).then(n.bind(null,201)),"components/SidebarLink":()=>Promise.all([n.e(0),n.e(25)]).then(n.bind(null,181)),"components/SidebarLinks":()=>Promise.all([n.e(0),n.e(3)]).then(n.bind(null,176)),"components/VersionChooser":()=>Promise.all([n.e(0),n.e(20)]).then(n.bind(null,294)),"components/VersioningMixin":()=>n.e(52).then(n.bind(null,164)),"global-components/Badge":()=>Promise.all([n.e(0),n.e(4)]).then(n.bind(null,490)),"layouts/404":()=>n.e(7).then(n.bind(null,477)),"layouts/Layout":()=>Promise.all([n.e(0),n.e(1),n.e(2)]).then(n.bind(null,478)),NotFound:()=>n.e(7).then(n.bind(null,477)),Layout:()=>Promise.all([n.e(0),n.e(1),n.e(2)]).then(n.bind(null,478))},Ze={"v-3ec20de4":()=>n.e(54).then(n.bind(null,491)),"v-31596d2d":()=>n.e(55).then(n.bind(null,492)),"v-5e94256a":()=>n.e(57).then(n.bind(null,493)),"v-4155eb1e":()=>n.e(58).then(n.bind(null,494)),"v-26232766":()=>n.e(56).then(n.bind(null,495)),"v-5e0de9fe":()=>n.e(59).then(n.bind(null,496)),"v-418e1b4d":()=>n.e(60).then(n.bind(null,497)),"v-63a2d53d":()=>n.e(61).then(n.bind(null,498)),"v-6bf62e0d":()=>n.e(41).then(n.bind(null,499)),"v-d80ea866":()=>n.e(62).then(n.bind(null,500)),"v-4081eb72":()=>n.e(64).then(n.bind(null,501)),"v-4899abd1":()=>n.e(63).then(n.bind(null,502)),"v-0059cb2a":()=>n.e(66).then(n.bind(null,503)),"v-5e5c94cd":()=>n.e(65).then(n.bind(null,504)),"v-25dd3de6":()=>n.e(67).then(n.bind(null,505)),"v-6993aee6":()=>n.e(68).then(n.bind(null,506)),"v-3359623e":()=>n.e(42).then(n.bind(null,507)),"v-37dbaaa0":()=>n.e(71).then(n.bind(null,508)),"v-6aca4be5":()=>n.e(70).then(n.bind(null,509)),"v-cfac61a6":()=>n.e(69).then(n.bind(null,510)),"v-7758ae27":()=>n.e(72).then(n.bind(null,511)),"v-5fd8f1ad":()=>n.e(13).then(n.bind(null,512)),"v-f5de2fb4":()=>n.e(73).then(n.bind(null,513)),"v-654015de":()=>n.e(75).then(n.bind(null,514)),"v-9f635184":()=>n.e(18).then(n.bind(null,515)),"v-8d587926":()=>n.e(76).then(n.bind(null,516)),"v-dc734f12":()=>n.e(77).then(n.bind(null,517)),"v-75018026":()=>n.e(43).then(n.bind(null,518)),"v-43de507e":()=>n.e(74).then(n.bind(null,519)),"v-253cefad":()=>n.e(79).then(n.bind(null,520)),"v-1772ad2d":()=>n.e(78).then(n.bind(null,521)),"v-2840d4fe":()=>n.e(80).then(n.bind(null,522)),"v-1b45967e":()=>n.e(81).then(n.bind(null,523)),"v-021062ed":()=>n.e(82).then(n.bind(null,524)),"v-97aa86e6":()=>n.e(44).then(n.bind(null,525)),"v-e35c5e24":()=>n.e(83).then(n.bind(null,526)),"v-4af2bfca":()=>n.e(84).then(n.bind(null,527)),"v-1a823cb0":()=>n.e(46).then(n.bind(null,528)),"v-04d2236d":()=>n.e(45).then(n.bind(null,529)),"v-00153acd":()=>n.e(85).then(n.bind(null,530)),"v-9a2a2626":()=>n.e(86).then(n.bind(null,531)),"v-560d08d2":()=>n.e(47).then(n.bind(null,532)),"v-ef2073ec":()=>n.e(15).then(n.bind(null,533)),"v-592eaa86":()=>n.e(48).then(n.bind(null,534)),"v-ffc79ec2":()=>n.e(87).then(n.bind(null,535)),"v-c71b5aa6":()=>n.e(88).then(n.bind(null,536)),"v-1005bb66":()=>n.e(89).then(n.bind(null,537)),"v-186cd6ed":()=>n.e(90).then(n.bind(null,538)),"v-0ee3f026":()=>n.e(91).then(n.bind(null,539)),"v-2997b752":()=>n.e(92).then(n.bind(null,540)),"v-24966ce6":()=>n.e(49).then(n.bind(null,541)),"v-4fe4e126":()=>n.e(93).then(n.bind(null,542)),"v-d2a018a6":()=>n.e(95).then(n.bind(null,543)),"v-f9778ae6":()=>n.e(94).then(n.bind(null,544)),"v-9ddae032":()=>n.e(96).then(n.bind(null,545)),"v-45d803ab":()=>n.e(50).then(n.bind(null,546)),"v-2fcee9ad":()=>n.e(98).then(n.bind(null,547)),"v-3f85032d":()=>n.e(97).then(n.bind(null,548)),"v-0e5e57cd":()=>n.e(100).then(n.bind(null,549)),"v-525dec3e":()=>n.e(99).then(n.bind(null,550)),"v-06e0a8ca":()=>n.e(102).then(n.bind(null,551)),"v-6e6b7e2d":()=>n.e(101).then(n.bind(null,552)),"v-1227575e":()=>n.e(103).then(n.bind(null,553)),"v-59d340ad":()=>n.e(51).then(n.bind(null,554)),"v-00d62ee6":()=>n.e(104).then(n.bind(null,555)),"v-221bfb8d":()=>n.e(105).then(n.bind(null,556)),"v-3eeef04a":()=>n.e(106).then(n.bind(null,557)),"v-d5007282":()=>n.e(109).then(n.bind(null,558)),"v-857a96a6":()=>n.e(107).then(n.bind(null,559)),"v-10d9ffb7":()=>n.e(108).then(n.bind(null,560)),"v-8850e2c4":()=>n.e(110).then(n.bind(null,561)),"v-64c18f4d":()=>n.e(111).then(n.bind(null,562)),"v-9adb302a":()=>n.e(112).then(n.bind(null,563))};function Ke(e){const t=Object.create(null);return function(n){return t[n]||(t[n]=e(n))}}const Xe=/-(\w)/g,Qe=Ke(e=>e.replace(Xe,(e,t)=>t?t.toUpperCase():"")),Ye=/\B([A-Z])/g,et=Ke(e=>e.replace(Ye,"-$1").toLowerCase()),tt=Ke(e=>e.charAt(0).toUpperCase()+e.slice(1));function nt(e,t){if(!t)return;if(e(t))return e(t);return t.includes("-")?e(tt(Qe(t))):e(tt(t))||e(et(t))}const rt=Object.assign({},He,Ze),ot=e=>rt[e],at=e=>Ze[e],it=e=>He[e],st=e=>r.a.component(e);function lt(e){return nt(at,e)}function ct(e){return nt(it,e)}function ut(e){return nt(ot,e)}function pt(e){return nt(st,e)}function dt(...e){return Promise.all(e.filter(e=>e).map(async e=>{if(!pt(e)&&ut(e)){const t=await ut(e)();r.a.component(e,t.default)}}))}function ft(e,t){"undefined"!=typeof window&&window.__VUEPRESS__&&(window.__VUEPRESS__[e]=t)}var ht=n(47),vt=n.n(ht),mt=n(48),gt=n.n(mt),yt={created(){if(this.siteMeta=this.$site.headTags.filter(([e])=>"meta"===e).map(([e,t])=>t),this.$ssrContext){const t=this.getMergedMetaTags();this.$ssrContext.title=this.$title,this.$ssrContext.lang=this.$lang,this.$ssrContext.pageMeta=(e=t)?e.map(e=>{let t="{t+=` ${n}="${gt()(e[n])}"`}),t+">"}).join("\n "):"",this.$ssrContext.canonicalLink=wt(this.$canonicalUrl)}var e},mounted(){this.currentMetaTags=[...document.querySelectorAll("meta")],this.updateMeta(),this.updateCanonicalLink()},methods:{updateMeta(){document.title=this.$title,document.documentElement.lang=this.$lang;const e=this.getMergedMetaTags();this.currentMetaTags=_t(e,this.currentMetaTags)},getMergedMetaTags(){const e=this.$page.frontmatter.meta||[];return vt()([{name:"description",content:this.$description}],e,this.siteMeta,xt)},updateCanonicalLink(){bt(),this.$canonicalUrl&&document.head.insertAdjacentHTML("beforeend",wt(this.$canonicalUrl))}},watch:{$page(){this.updateMeta(),this.updateCanonicalLink()}},beforeDestroy(){_t(null,this.currentMetaTags),bt()}};function bt(){const e=document.querySelector("link[rel='canonical']");e&&e.remove()}function wt(e=""){return e?``:""}function _t(e,t){if(t&&[...t].filter(e=>e.parentNode===document.head).forEach(e=>document.head.removeChild(e)),e)return e.map(e=>{const t=document.createElement("meta");return Object.keys(e).forEach(n=>{t.setAttribute(n,e[n])}),document.head.appendChild(t),t})}function xt(e){for(const t of["name","property","itemprop"])if(e.hasOwnProperty(t))return e[t]+t;return JSON.stringify(e)}var Pt=n(13),kt=n.n(Pt),St={mounted(){kt.a.configure({showSpinner:!1}),this.$router.beforeEach((e,t,n)=>{e.path===t.path||r.a.component(e.name)||kt.a.start(),n()}),this.$router.afterEach(()=>{kt.a.done(),this.isSidebarOpen=!1})}},Ot=n(49),Ct={mounted(){window.addEventListener("scroll",this.onScroll)},methods:{onScroll:n.n(Ot)()((function(){this.setActiveHash()}),300),setActiveHash(){const e=[].slice.call(document.querySelectorAll(".sidebar-link")),t=[].slice.call(document.querySelectorAll(".header-anchor")).filter(t=>e.some(e=>e.hash===t.hash)),n=Math.max(window.pageYOffset,document.documentElement.scrollTop,document.body.scrollTop),r=Math.max(document.documentElement.scrollHeight,document.body.scrollHeight),o=window.innerHeight+n;for(let e=0;e=a.parentElement.offsetTop+10&&(!i||n{this.$nextTick(()=>{this.$vuepress.$set("disableScrollBehavior",!1)})})}}}},beforeDestroy(){window.removeEventListener("scroll",this.onScroll)}},Et={props:{parent:Object,code:String,options:{align:String,color:String,backgroundTransition:Boolean,backgroundColor:String,successText:String,staticIcon:Boolean}},data:()=>({success:!1,originalBackground:null,originalTransition:null}),computed:{alignStyle(){let e={};return e[this.options.align]="7.5px",e},iconClass(){return this.options.staticIcon?"":"hover"}},mounted(){this.originalTransition=this.parent.style.transition,this.originalBackground=this.parent.style.background},beforeDestroy(){this.parent.style.transition=this.originalTransition,this.parent.style.background=this.originalBackground},methods:{hexToRgb(e){let t=/^#?([a-f\d]{2})([a-f\d]{2})([a-f\d]{2})$/i.exec(e);return t?{r:parseInt(t[1],16),g:parseInt(t[2],16),b:parseInt(t[3],16)}:null},copyToClipboard(e){if(navigator.clipboard)navigator.clipboard.writeText(this.code).then(()=>{this.setSuccessTransitions()},()=>{});else{let e=document.createElement("textarea");document.body.appendChild(e),e.value=this.code,e.select(),document.execCommand("Copy"),e.remove(),this.setSuccessTransitions()}},setSuccessTransitions(){if(clearTimeout(this.successTimeout),this.options.backgroundTransition){this.parent.style.transition="background 350ms";let e=this.hexToRgb(this.options.backgroundColor);this.parent.style.background=`rgba(${e.r}, ${e.g}, ${e.b}, 0.1)`}this.success=!0,this.successTimeout=setTimeout(()=>{this.options.backgroundTransition&&(this.parent.style.background=this.originalBackground,this.parent.style.transition=this.originalTransition),this.success=!1},500)}}},jt=(n(146),n(4)),$t=Object(jt.a)(Et,(function(){var e=this,t=e._self._c;return t("div",{staticClass:"code-copy"},[t("svg",{class:e.iconClass,style:e.alignStyle,attrs:{xmlns:"http://www.w3.org/2000/svg",width:"24",height:"24",viewBox:"0 0 24 24"},on:{click:e.copyToClipboard}},[t("path",{attrs:{fill:"none",d:"M0 0h24v24H0z"}}),e._v(" "),t("path",{attrs:{fill:e.options.color,d:"M16 1H4c-1.1 0-2 .9-2 2v14h2V3h12V1zm-1 4l6 6v10c0 1.1-.9 2-2 2H7.99C6.89 23 6 22.1 6 21l.01-14c0-1.1.89-2 1.99-2h7zm-1 7h5.5L14 6.5V12z"}})]),e._v(" "),t("span",{class:e.success?"success":"",style:e.alignStyle},[e._v("\n "+e._s(e.options.successText)+"\n ")])])}),[],!1,null,"49140617",null).exports,Tt=(n(147),[yt,St,Ct,{updated(){this.update()},methods:{update(){setTimeout(()=>{document.querySelectorAll('div[class*="language-"] pre').forEach(e=>{if(e.classList.contains("code-copy-added"))return;let t=new(r.a.extend($t));t.options={align:"bottom",color:"#27b1ff",backgroundTransition:!0,backgroundColor:"#0075b8",successText:"Copied!",staticIcon:!1},t.code=e.innerText,t.parent=e,t.$mount(),e.classList.add("code-copy-added"),e.appendChild(t.$el)})},100)}}}]),At={name:"GlobalLayout",computed:{layout(){const e=this.getLayout();return ft("layout",e),r.a.component(e)}},methods:{getLayout(){if(this.$page.path){const e=this.$page.frontmatter.layout;return e&&(this.$vuepress.getLayoutAsyncComponent(e)||this.$vuepress.getVueComponent(e))?e:"Layout"}return"NotFound"}}},Rt=Object(jt.a)(At,(function(){return(0,this._self._c)(this.layout,{tag:"component"})}),[],!1,null,null,null).exports;!function(e,t,n){switch(t){case"components":e[t]||(e[t]={}),Object.assign(e[t],n);break;case"mixins":e[t]||(e[t]=[]),e[t].push(...n);break;default:throw new Error("Unknown option name.")}}(Rt,"mixins",Tt);const Ut=[{name:"v-3ec20de4",path:"/",component:Rt,beforeEnter:(e,t,n)=>{dt("Layout","v-3ec20de4").then(n)}},{path:"/index.html",redirect:"/"},{name:"v-31596d2d",path:"/about.html",component:Rt,beforeEnter:(e,t,n)=>{dt("Layout","v-31596d2d").then(n)}},{name:"v-5e94256a",path:"/documentation/0.4/",component:Rt,beforeEnter:(e,t,n)=>{dt("Layout","v-5e94256a").then(n)}},{path:"/documentation/0.4/index.html",redirect:"/documentation/0.4/"},{name:"v-4155eb1e",path:"/documentation/0.4/developers/",component:Rt,beforeEnter:(e,t,n)=>{dt("Layout","v-4155eb1e").then(n)}},{path:"/documentation/0.4/developers/index.html",redirect:"/documentation/0.4/developers/"},{name:"v-26232766",path:"/contact.html",component:Rt,beforeEnter:(e,t,n)=>{dt("Layout","v-26232766").then(n)}},{name:"v-5e0de9fe",path:"/documentation/0.4/developers/api/",component:Rt,beforeEnter:(e,t,n)=>{dt("Layout","v-5e0de9fe").then(n)}},{path:"/documentation/0.4/developers/api/index.html",redirect:"/documentation/0.4/developers/api/"},{name:"v-418e1b4d",path:"/documentation/0.4/developers/api/errors.html",component:Rt,beforeEnter:(e,t,n)=>{dt("Layout","v-418e1b4d").then(n)}},{name:"v-63a2d53d",path:"/documentation/0.4/developers/api/reference.html",component:Rt,beforeEnter:(e,t,n)=>{dt("Layout","v-63a2d53d").then(n)}},{name:"v-6bf62e0d",path:"/documentation/0.4/developers/arch.html",component:Rt,beforeEnter:(e,t,n)=>{dt("Layout","v-6bf62e0d").then(n)}},{name:"v-d80ea866",path:"/documentation/0.4/developers/backends/getting-started.html",component:Rt,beforeEnter:(e,t,n)=>{dt("Layout","v-d80ea866").then(n)}},{name:"v-4081eb72",path:"/documentation/0.4/developers/clients/getting-started.html",component:Rt,beforeEnter:(e,t,n)=>{dt("Layout","v-4081eb72").then(n)}},{name:"v-4899abd1",path:"/documentation/0.4/developers/backends/udfs.html",component:Rt,beforeEnter:(e,t,n)=>{dt("Layout","v-4899abd1").then(n)}},{name:"v-0059cb2a",path:"/documentation/0.4/developers/examples/",component:Rt,beforeEnter:(e,t,n)=>{dt("Layout","v-0059cb2a").then(n)}},{path:"/documentation/0.4/developers/examples/index.html",redirect:"/documentation/0.4/developers/examples/"},{name:"v-5e5c94cd",path:"/documentation/0.4/developers/clients/library-guidelines.html",component:Rt,beforeEnter:(e,t,n)=>{dt("Layout","v-5e5c94cd").then(n)}},{name:"v-25dd3de6",path:"/documentation/0.4/developers/examples/poc.html",component:Rt,beforeEnter:(e,t,n)=>{dt("Layout","v-25dd3de6").then(n)}},{name:"v-6993aee6",path:"/documentation/0.4/getting-started.html",component:Rt,beforeEnter:(e,t,n)=>{dt("Layout","v-6993aee6").then(n)}},{name:"v-3359623e",path:"/documentation/0.4/glossary.html",component:Rt,beforeEnter:(e,t,n)=>{dt("Layout","v-3359623e").then(n)}},{name:"v-37dbaaa0",path:"/documentation/1.0/",component:Rt,beforeEnter:(e,t,n)=>{dt("Layout","v-37dbaaa0").then(n)}},{path:"/documentation/1.0/index.html",redirect:"/documentation/1.0/"},{name:"v-6aca4be5",path:"/documentation/0.4/udfs.html",component:Rt,beforeEnter:(e,t,n)=>{dt("Layout","v-6aca4be5").then(n)}},{name:"v-cfac61a6",path:"/documentation/0.4/processes.html",component:Rt,beforeEnter:(e,t,n)=>{dt("Layout","v-cfac61a6").then(n)}},{name:"v-7758ae27",path:"/documentation/1.0/authentication.html",component:Rt,beforeEnter:(e,t,n)=>{dt("Layout","v-7758ae27").then(n)}},{name:"v-5fd8f1ad",path:"/documentation/1.0/datacubes.html",component:Rt,beforeEnter:(e,t,n)=>{dt("Layout","v-5fd8f1ad").then(n)}},{name:"v-f5de2fb4",path:"/documentation/1.0/datacubes/",component:Rt,beforeEnter:(e,t,n)=>{dt("Layout","v-f5de2fb4").then(n)}},{path:"/documentation/1.0/datacubes/index.html",redirect:"/documentation/1.0/datacubes/"},{name:"v-654015de",path:"/documentation/1.0/developers/api/",component:Rt,beforeEnter:(e,t,n)=>{dt("Layout","v-654015de").then(n)}},{path:"/documentation/1.0/developers/api/index.html",redirect:"/documentation/1.0/developers/api/"},{name:"v-9f635184",path:"/documentation/1.0/cookbook/",component:Rt,beforeEnter:(e,t,n)=>{dt("Layout","v-9f635184").then(n)}},{path:"/documentation/1.0/cookbook/index.html",redirect:"/documentation/1.0/cookbook/"},{name:"v-8d587926",path:"/documentation/1.0/developers/api/errors.html",component:Rt,beforeEnter:(e,t,n)=>{dt("Layout","v-8d587926").then(n)}},{name:"v-dc734f12",path:"/documentation/1.0/developers/api/reference.html",component:Rt,beforeEnter:(e,t,n)=>{dt("Layout","v-dc734f12").then(n)}},{name:"v-75018026",path:"/documentation/1.0/developers/arch.html",component:Rt,beforeEnter:(e,t,n)=>{dt("Layout","v-75018026").then(n)}},{name:"v-43de507e",path:"/documentation/1.0/developers/",component:Rt,beforeEnter:(e,t,n)=>{dt("Layout","v-43de507e").then(n)}},{path:"/documentation/1.0/developers/index.html",redirect:"/documentation/1.0/developers/"},{name:"v-253cefad",path:"/documentation/1.0/developers/backends/performance.html",component:Rt,beforeEnter:(e,t,n)=>{dt("Layout","v-253cefad").then(n)}},{name:"v-1772ad2d",path:"/documentation/1.0/developers/backends/getting-started.html",component:Rt,beforeEnter:(e,t,n)=>{dt("Layout","v-1772ad2d").then(n)}},{name:"v-2840d4fe",path:"/documentation/1.0/developers/backends/xarray.html",component:Rt,beforeEnter:(e,t,n)=>{dt("Layout","v-2840d4fe").then(n)}},{name:"v-1b45967e",path:"/documentation/1.0/developers/clients/getting-started.html",component:Rt,beforeEnter:(e,t,n)=>{dt("Layout","v-1b45967e").then(n)}},{name:"v-021062ed",path:"/documentation/1.0/developers/clients/library-guidelines.html",component:Rt,beforeEnter:(e,t,n)=>{dt("Layout","v-021062ed").then(n)}},{name:"v-97aa86e6",path:"/documentation/1.0/developers/profiles/api.html",component:Rt,beforeEnter:(e,t,n)=>{dt("Layout","v-97aa86e6").then(n)}},{name:"v-e35c5e24",path:"/documentation/1.0/developers/profiles/",component:Rt,beforeEnter:(e,t,n)=>{dt("Layout","v-e35c5e24").then(n)}},{path:"/documentation/1.0/developers/profiles/index.html",redirect:"/documentation/1.0/developers/profiles/"},{name:"v-4af2bfca",path:"/documentation/1.0/glossary.html",component:Rt,beforeEnter:(e,t,n)=>{dt("Layout","v-4af2bfca").then(n)}},{name:"v-1a823cb0",path:"/documentation/1.0/javascript/",component:Rt,beforeEnter:(e,t,n)=>{dt("Layout","v-1a823cb0").then(n)}},{path:"/documentation/1.0/javascript/index.html",redirect:"/documentation/1.0/javascript/"},{name:"v-04d2236d",path:"/documentation/1.0/developers/profiles/processes.html",component:Rt,beforeEnter:(e,t,n)=>{dt("Layout","v-04d2236d").then(n)}},{name:"v-00153acd",path:"/documentation/1.0/processes.html",component:Rt,beforeEnter:(e,t,n)=>{dt("Layout","v-00153acd").then(n)}},{name:"v-9a2a2626",path:"/documentation/1.0/python/client-side-processing.html",component:Rt,beforeEnter:(e,t,n)=>{dt("Layout","v-9a2a2626").then(n)}},{name:"v-560d08d2",path:"/documentation/1.0/python/",component:Rt,beforeEnter:(e,t,n)=>{dt("Layout","v-560d08d2").then(n)}},{path:"/documentation/1.0/python/index.html",redirect:"/documentation/1.0/python/"},{name:"v-ef2073ec",path:"/documentation/1.0/qgis/",component:Rt,beforeEnter:(e,t,n)=>{dt("Layout","v-ef2073ec").then(n)}},{path:"/documentation/1.0/qgis/index.html",redirect:"/documentation/1.0/qgis/"},{name:"v-592eaa86",path:"/documentation/1.0/r/",component:Rt,beforeEnter:(e,t,n)=>{dt("Layout","v-592eaa86").then(n)}},{path:"/documentation/1.0/r/index.html",redirect:"/documentation/1.0/r/"},{name:"v-ffc79ec2",path:"/documentation/1.0/udfs.html",component:Rt,beforeEnter:(e,t,n)=>{dt("Layout","v-ffc79ec2").then(n)}},{name:"v-c71b5aa6",path:"/documentation/code-of-conduct.html",component:Rt,beforeEnter:(e,t,n)=>{dt("Layout","v-c71b5aa6").then(n)}},{name:"v-1005bb66",path:"/documentation/software-guidelines.html",component:Rt,beforeEnter:(e,t,n)=>{dt("Layout","v-1005bb66").then(n)}},{name:"v-186cd6ed",path:"/events/igarrs2021.html",component:Rt,beforeEnter:(e,t,n)=>{dt("Layout","v-186cd6ed").then(n)}},{name:"v-0ee3f026",path:"/news/2017-12-05-welcome.html",component:Rt,beforeEnter:(e,t,n)=>{dt("Layout","v-0ee3f026").then(n)}},{name:"v-2997b752",path:"/news/2017-12-18-VITO_meeting.html",component:Rt,beforeEnter:(e,t,n)=>{dt("Layout","v-2997b752").then(n)}},{name:"v-24966ce6",path:"/news/2018-01-31-WWU_meeting.html",component:Rt,beforeEnter:(e,t,n)=>{dt("Layout","v-24966ce6").then(n)}},{name:"v-4fe4e126",path:"/news/2018-03-15-poc.html",component:Rt,beforeEnter:(e,t,n)=>{dt("Layout","v-4fe4e126").then(n)}},{name:"v-d2a018a6",path:"/news/2018-10-30-year-one-review-meeting.html",component:Rt,beforeEnter:(e,t,n)=>{dt("Layout","v-d2a018a6").then(n)}},{name:"v-f9778ae6",path:"/news/2018-05-23-user-requirements-survey-launched.html",component:Rt,beforeEnter:(e,t,n)=>{dt("Layout","v-f9778ae6").then(n)}},{name:"v-9ddae032",path:"/news/2019-10-07-EO-big-data-hackaton.html",component:Rt,beforeEnter:(e,t,n)=>{dt("Layout","v-9ddae032").then(n)}},{name:"v-45d803ab",path:"/news/2019-03-07-openeo-api-040.html",component:Rt,beforeEnter:(e,t,n)=>{dt("Layout","v-45d803ab").then(n)}},{name:"v-2fcee9ad",path:"/news/2020-07-31-openeo-api-released.html",component:Rt,beforeEnter:(e,t,n)=>{dt("Layout","v-2fcee9ad").then(n)}},{name:"v-3f85032d",path:"/news/2020-07-31-lessons-learned.html",component:Rt,beforeEnter:(e,t,n)=>{dt("Layout","v-3f85032d").then(n)}},{name:"v-0e5e57cd",path:"/news/2020-11-30-openeo-api-101-released.html",component:Rt,beforeEnter:(e,t,n)=>{dt("Layout","v-0e5e57cd").then(n)}},{name:"v-525dec3e",path:"/news/2020-09-02-openeo-user-workshop.html",component:Rt,beforeEnter:(e,t,n)=>{dt("Layout","v-525dec3e").then(n)}},{name:"v-06e0a8ca",path:"/news/2021-11-08-r-client-on-cran.html",component:Rt,beforeEnter:(e,t,n)=>{dt("Layout","v-06e0a8ca").then(n)}},{name:"v-6e6b7e2d",path:"/news/2021-05-17-openeo-api-110-released.html",component:Rt,beforeEnter:(e,t,n)=>{dt("Layout","v-6e6b7e2d").then(n)}},{name:"v-1227575e",path:"/news/2022-04-08-psc-meetings.html",component:Rt,beforeEnter:(e,t,n)=>{dt("Layout","v-1227575e").then(n)}},{name:"v-59d340ad",path:"/news/2022-05-12-r-client-v120.html",component:Rt,beforeEnter:(e,t,n)=>{dt("Layout","v-59d340ad").then(n)}},{name:"v-00d62ee6",path:"/news/2022-07-07-monthly-dev-calls.html",component:Rt,beforeEnter:(e,t,n)=>{dt("Layout","v-00d62ee6").then(n)}},{name:"v-221bfb8d",path:"/news/2022-11-17-r-client-v130.html",component:Rt,beforeEnter:(e,t,n)=>{dt("Layout","v-221bfb8d").then(n)}},{name:"v-3eeef04a",path:"/news/2023-05-25-new-openeo-versions-120-200rc1%20copy.html",component:Rt,beforeEnter:(e,t,n)=>{dt("Layout","v-3eeef04a").then(n)}},{path:"/news/2023-05-25-new-openeo-versions-120-200rc1 copy.html",redirect:"/news/2023-05-25-new-openeo-versions-120-200rc1%20copy.html"},{path:"/news/2023-05-25-new-openeo-versions-120-200rc1 copy.html",redirect:"/news/2023-05-25-new-openeo-versions-120-200rc1%20copy.html"},{name:"v-d5007282",path:"/news/2024-03-22_mooc_cubeandclouds.html",component:Rt,beforeEnter:(e,t,n)=>{dt("Layout","v-d5007282").then(n)}},{name:"v-857a96a6",path:"/news/2023-12-06-openeo-submitted-to-ogc.html",component:Rt,beforeEnter:(e,t,n)=>{dt("Layout","v-857a96a6").then(n)}},{name:"v-10d9ffb7",path:"/news/2024-02-06-openeo-ogc-rfc.html",component:Rt,beforeEnter:(e,t,n)=>{dt("Layout","v-10d9ffb7").then(n)}},{name:"v-8850e2c4",path:"/news/",component:Rt,beforeEnter:(e,t,n)=>{dt("Layout","v-8850e2c4").then(n)}},{path:"/news/index.html",redirect:"/news/"},{name:"v-64c18f4d",path:"/psc.html",component:Rt,beforeEnter:(e,t,n)=>{dt("Layout","v-64c18f4d").then(n)}},{name:"v-9adb302a",path:"/software.html",component:Rt,beforeEnter:(e,t,n)=>{dt("Layout","v-9adb302a").then(n)}},{path:"*",component:Rt}],Mt={title:"openEO",description:"openEO develops an open API to connect various clients to big EO cloud back-ends in a simple and unified way.",base:"/",headTags:[],pages:[{title:"Home",frontmatter:{home:!0},regularPath:"/",relativePath:"README.md",key:"v-3ec20de4",path:"/",lastUpdated:"7/26/2024, 6:48:28 PM",lastUpdatedTimestamp:1722019708e3,codeSwitcherOptions:{groups:{default:{py:"Python",r:"R",js:"JavaScript"}}}},{title:"About",frontmatter:{},regularPath:"/about.html",relativePath:"about.md",key:"v-31596d2d",path:"/about.html",headers:[{level:2,title:"openEO?",slug:"openeo"},{level:2,title:"Why an API?",slug:"why-an-api"},{level:2,title:"More information",slug:"more-information"}],lastUpdated:"7/26/2024, 6:48:28 PM",lastUpdatedTimestamp:1722019708e3,codeSwitcherOptions:{groups:{default:{py:"Python",r:"R",js:"JavaScript"}}}},{title:"openEO Documentation",frontmatter:{},regularPath:"/documentation/0.4/",relativePath:"documentation/0.4/README.md",key:"v-5e94256a",path:"/documentation/0.4/",lastUpdated:"7/26/2024, 6:48:28 PM",lastUpdatedTimestamp:1722019708e3,codeSwitcherOptions:{groups:{default:{py:"Python",r:"R",js:"JavaScript"}}}},{title:"Introduction",frontmatter:{},regularPath:"/documentation/0.4/developers/",relativePath:"documentation/0.4/developers/README.md",key:"v-4155eb1e",path:"/documentation/0.4/developers/",headers:[{level:2,title:"Additional information",slug:"additional-information"}],lastUpdated:"7/26/2024, 6:48:28 PM",lastUpdatedTimestamp:1722019708e3,codeSwitcherOptions:{groups:{default:{py:"Python",r:"R",js:"JavaScript"}}}},{title:"Contact",frontmatter:{sidebar:!1},regularPath:"/contact.html",relativePath:"contact.md",key:"v-26232766",path:"/contact.html",lastUpdated:"7/26/2024, 6:48:28 PM",lastUpdatedTimestamp:1722019708e3,codeSwitcherOptions:{groups:{default:{py:"Python",r:"R",js:"JavaScript"}}}},{frontmatter:{iframe:"https://api.openeo.org/v/0.4.2/"},regularPath:"/documentation/0.4/developers/api/",relativePath:"documentation/0.4/developers/api/README.md",key:"v-5e0de9fe",path:"/documentation/0.4/developers/api/",lastUpdated:"7/26/2024, 6:48:28 PM",lastUpdatedTimestamp:1722019708e3,codeSwitcherOptions:{groups:{default:{py:"Python",r:"R",js:"JavaScript"}}}},{title:"Status and error handling",frontmatter:{},regularPath:"/documentation/0.4/developers/api/errors.html",relativePath:"documentation/0.4/developers/api/errors.md",key:"v-418e1b4d",path:"/documentation/0.4/developers/api/errors.html",headers:[{level:2,title:"JSON error object",slug:"json-error-object"},{level:2,title:"Standardized status codes",slug:"standardized-status-codes"},{level:2,title:"openEO error codes",slug:"openeo-error-codes"}],lastUpdated:"7/26/2024, 6:48:28 PM",lastUpdatedTimestamp:1722019708e3,codeSwitcherOptions:{groups:{default:{py:"Python",r:"R",js:"JavaScript"}}}},{frontmatter:{fullpage:!0,stripCSS:!0},regularPath:"/documentation/0.4/developers/api/reference.html",relativePath:"documentation/0.4/developers/api/reference.md",key:"v-63a2d53d",path:"/documentation/0.4/developers/api/reference.html",lastUpdated:"7/26/2024, 6:48:28 PM",lastUpdatedTimestamp:1722019708e3,codeSwitcherOptions:{groups:{default:{py:"Python",r:"R",js:"JavaScript"}}}},{title:"Architecture",frontmatter:{},regularPath:"/documentation/0.4/developers/arch.html",relativePath:"documentation/0.4/developers/arch.md",key:"v-6bf62e0d",path:"/documentation/0.4/developers/arch.html",lastUpdated:"7/26/2024, 6:48:28 PM",lastUpdatedTimestamp:1722019708e3,codeSwitcherOptions:{groups:{default:{py:"Python",r:"R",js:"JavaScript"}}}},{title:"Getting started for back-end providers",frontmatter:{},regularPath:"/documentation/0.4/developers/backends/getting-started.html",relativePath:"documentation/0.4/developers/backends/getting-started.md",key:"v-d80ea866",path:"/documentation/0.4/developers/backends/getting-started.html",lastUpdated:"7/26/2024, 6:48:28 PM",lastUpdatedTimestamp:1722019708e3,codeSwitcherOptions:{groups:{default:{py:"Python",r:"R",js:"JavaScript"}}}},{title:"Getting started for client developers",frontmatter:{},regularPath:"/documentation/0.4/developers/clients/getting-started.html",relativePath:"documentation/0.4/developers/clients/getting-started.md",key:"v-4081eb72",path:"/documentation/0.4/developers/clients/getting-started.html",headers:[{level:2,title:"Client library developers",slug:"client-library-developers"},{level:2,title:"Applications and Software plugins",slug:"applications-and-software-plugins"}],lastUpdated:"7/26/2024, 6:48:28 PM",lastUpdatedTimestamp:1722019708e3,codeSwitcherOptions:{groups:{default:{py:"Python",r:"R",js:"JavaScript"}}}},{title:"User-defined functions",frontmatter:{},regularPath:"/documentation/0.4/developers/backends/udfs.html",relativePath:"documentation/0.4/developers/backends/udfs.md",key:"v-4899abd1",path:"/documentation/0.4/developers/backends/udfs.html",lastUpdated:"7/26/2024, 6:48:28 PM",lastUpdatedTimestamp:1722019708e3,codeSwitcherOptions:{groups:{default:{py:"Python",r:"R",js:"JavaScript"}}}},{title:"Examples",frontmatter:{},regularPath:"/documentation/0.4/developers/examples/",relativePath:"documentation/0.4/developers/examples/README.md",key:"v-0059cb2a",path:"/documentation/0.4/developers/examples/",lastUpdated:"7/26/2024, 6:48:28 PM",lastUpdatedTimestamp:1722019708e3,codeSwitcherOptions:{groups:{default:{py:"Python",r:"R",js:"JavaScript"}}}},{title:"Client library development guidelines",frontmatter:{},regularPath:"/documentation/0.4/developers/clients/library-guidelines.html",relativePath:"documentation/0.4/developers/clients/library-guidelines.md",key:"v-5e5c94cd",path:"/documentation/0.4/developers/clients/library-guidelines.html",headers:[{level:2,title:"Conventions",slug:"conventions"},{level:3,title:"Casing",slug:"casing"},{level:3,title:"Scopes",slug:"scopes"},{level:3,title:"Scope categories",slug:"scope-categories"},{level:3,title:"Parameters",slug:"parameters"},{level:2,title:"Method mappings",slug:"method-mappings"},{level:3,title:"Scope: openEO (root category)",slug:"scope-openeo-root-category"},{level:4,title:"Parameters",slug:"parameters-2"},{level:3,title:"Scope: Connection (API category)",slug:"scope-connection-api-category"},{level:4,title:"Parameters",slug:"parameters-3"},{level:3,title:"Scope Capabilities (Content category)",slug:"scope-capabilities-content-category"},{level:4,title:"Parameters",slug:"parameters-4"},{level:3,title:"Scope: File (API category)",slug:"scope-file-api-category"},{level:4,title:"Parameters",slug:"parameters-5"},{level:3,title:"Scope: Job (API category)",slug:"scope-job-api-category"},{level:4,title:"Parameters",slug:"parameters-6"},{level:3,title:"Scope: ProcessGraph (API category)",slug:"scope-processgraph-api-category"},{level:3,title:"Scope: Service (API category)",slug:"scope-service-api-category"},{level:2,title:"Processes",slug:"processes"},{level:2,title:"Workflow example",slug:"workflow-example"},{level:3,title:"R (functional style)",slug:"r-functional-style"},{level:3,title:"Python (mixed style)",slug:"python-mixed-style"},{level:3,title:"Java (object oriented style)",slug:"java-object-oriented-style"},{level:3,title:"PHP (procedural style)",slug:"php-procedural-style"}],lastUpdated:"7/26/2024, 6:48:28 PM",lastUpdatedTimestamp:1722019708e3,codeSwitcherOptions:{groups:{default:{py:"Python",r:"R",js:"JavaScript"}}}},{title:"Examples (proof of concept)",frontmatter:{},regularPath:"/documentation/0.4/developers/examples/poc.html",relativePath:"documentation/0.4/developers/examples/poc.md",key:"v-25dd3de6",path:"/documentation/0.4/developers/examples/poc.html",headers:[{level:2,title:"Use Case 1",slug:"use-case-1"},{level:2,title:"Use Case 2",slug:"use-case-2"},{level:2,title:"Use Case 3",slug:"use-case-3"}],lastUpdated:"7/26/2024, 6:48:28 PM",lastUpdatedTimestamp:1722019708e3,codeSwitcherOptions:{groups:{default:{py:"Python",r:"R",js:"JavaScript"}}}},{title:"Getting started for users",frontmatter:{},regularPath:"/documentation/0.4/getting-started.html",relativePath:"documentation/0.4/getting-started.md",key:"v-6993aee6",path:"/documentation/0.4/getting-started.html",headers:[{level:2,title:"Contribute",slug:"contribute"}],lastUpdated:"7/26/2024, 6:48:28 PM",lastUpdatedTimestamp:1722019708e3,codeSwitcherOptions:{groups:{default:{py:"Python",r:"R",js:"JavaScript"}}}},{title:"Glossary",frontmatter:{},regularPath:"/documentation/0.4/glossary.html",relativePath:"documentation/0.4/glossary.md",key:"v-3359623e",path:"/documentation/0.4/glossary.html",headers:[{level:2,title:"General terms",slug:"general-terms"},{level:2,title:"Processes and process graphs",slug:"processes-and-process-graphs"},{level:2,title:"EO data (Collections)",slug:"eo-data-collections"},{level:2,title:"Spatial data cubes",slug:"spatial-data-cubes"},{level:3,title:"apply: processes that do not change dimensions",slug:"apply-processes-that-do-not-change-dimensions"},{level:3,title:"filter: subsetting dimensions by dimension value selection",slug:"filter-subsetting-dimensions-by-dimension-value-selection"},{level:3,title:"reduce: removing dimensions entirely by computation",slug:"reduce-removing-dimensions-entirely-by-computation"},{level:3,title:"aggregate: reducing resolution",slug:"aggregate-reducing-resolution"},{level:3,title:"resample: changing data cube geometry",slug:"resample-changing-data-cube-geometry"},{level:2,title:"User-defined function (UDF)",slug:"user-defined-function-udf"},{level:2,title:"Data Processing modes",slug:"data-processing-modes"}],lastUpdated:"7/26/2024, 6:48:28 PM",lastUpdatedTimestamp:1722019708e3,codeSwitcherOptions:{groups:{default:{py:"Python",r:"R",js:"JavaScript"}}}},{title:"Introduction",frontmatter:{},regularPath:"/documentation/1.0/",relativePath:"documentation/1.0/README.md",key:"v-37dbaaa0",path:"/documentation/1.0/",headers:[{level:2,title:"Contribute",slug:"contribute"}],lastUpdated:"7/26/2024, 6:48:28 PM",lastUpdatedTimestamp:1722019708e3,codeSwitcherOptions:{groups:{default:{py:"Python",r:"R",js:"JavaScript"}}}},{title:"User-defined functions",frontmatter:{},regularPath:"/documentation/0.4/udfs.html",relativePath:"documentation/0.4/udfs.md",key:"v-6aca4be5",path:"/documentation/0.4/udfs.html",lastUpdated:"7/26/2024, 6:48:28 PM",lastUpdatedTimestamp:1722019708e3,codeSwitcherOptions:{groups:{default:{py:"Python",r:"R",js:"JavaScript"}}}},{frontmatter:{fullpage:!0,stripCSS:!0},regularPath:"/documentation/0.4/processes.html",relativePath:"documentation/0.4/processes.md",key:"v-cfac61a6",path:"/documentation/0.4/processes.html",lastUpdated:"7/26/2024, 6:48:28 PM",lastUpdatedTimestamp:1722019708e3,codeSwitcherOptions:{groups:{default:{py:"Python",r:"R",js:"JavaScript"}}}},{title:"Authentication",frontmatter:{},regularPath:"/documentation/1.0/authentication.html",relativePath:"documentation/1.0/authentication.md",key:"v-7758ae27",path:"/documentation/1.0/authentication.html",headers:[{level:2,title:"HTTP Basic",slug:"http-basic"},{level:2,title:"OpenID Connect",slug:"openid-connect"},{level:3,title:"Authorization Code Flow",slug:"authorization-code-flow"},{level:3,title:"Device Flow",slug:"device-flow"},{level:3,title:"Client Credentials Flow",slug:"client-credentials-flow"},{level:3,title:"Resource Owner Password flow",slug:"resource-owner-password-flow"},{level:3,title:"Refresh Token Flow",slug:"refresh-token-flow"}],lastUpdated:"7/26/2024, 6:48:28 PM",lastUpdatedTimestamp:1722019708e3,codeSwitcherOptions:{groups:{default:{py:"Python",r:"R",js:"JavaScript"}}}},{title:"Datacubes",frontmatter:{},regularPath:"/documentation/1.0/datacubes.html",relativePath:"documentation/1.0/datacubes.md",key:"v-5fd8f1ad",path:"/documentation/1.0/datacubes.html",headers:[{level:2,title:"What are Datacubes?",slug:"what-are-datacubes"},{level:2,title:"Dimensions",slug:"dimensions"},{level:3,title:"Applying Processes on Dimensions",slug:"applying-processes-on-dimensions"},{level:3,title:"Resolution",slug:"resolution"},{level:3,title:"Coordinate Reference System as a Dimension",slug:"coordinate-reference-system-as-a-dimension"},{level:2,title:"Values in a datacube",slug:"values-in-a-datacube"},{level:2,title:"Processes on Datacubes",slug:"processes-on-datacubes"},{level:3,title:"Filter",slug:"filter"},{level:3,title:"Apply",slug:"apply"},{level:3,title:"Resample",slug:"resample"},{level:3,title:"Reduce",slug:"reduce"},{level:3,title:"Aggregate",slug:"aggregate"}],lastUpdated:"7/26/2024, 6:48:28 PM",lastUpdatedTimestamp:1722019708e3,codeSwitcherOptions:{groups:{default:{py:"Python",r:"R",js:"JavaScript"}}}},{title:"Datacube Documentation",frontmatter:{},regularPath:"/documentation/1.0/datacubes/",relativePath:"documentation/1.0/datacubes/README.md",key:"v-f5de2fb4",path:"/documentation/1.0/datacubes/",lastUpdated:"7/26/2024, 6:48:28 PM",lastUpdatedTimestamp:1722019708e3,codeSwitcherOptions:{groups:{default:{py:"Python",r:"R",js:"JavaScript"}}}},{frontmatter:{},regularPath:"/documentation/1.0/developers/api/",relativePath:"documentation/1.0/developers/api/README.md",key:"v-654015de",path:"/documentation/1.0/developers/api/",lastUpdated:"7/26/2024, 6:48:28 PM",lastUpdatedTimestamp:1722019708e3,codeSwitcherOptions:{groups:{default:{py:"Python",r:"R",js:"JavaScript"}}}},{title:"openEO Cookbook",frontmatter:{sidebarDepth:3},regularPath:"/documentation/1.0/cookbook/",relativePath:"documentation/1.0/cookbook/README.md",key:"v-9f635184",path:"/documentation/1.0/cookbook/",headers:[{level:2,title:"Chapter 1",slug:"chapter-1"},{level:3,title:"Connecting to a back-end",slug:"connecting-to-a-back-end"},{level:3,title:"Input: load_collection",slug:"input-load-collection"},{level:3,title:"Filter Bands: filter_bands",slug:"filter-bands-filter-bands"},{level:3,title:"Temporal Mean: reduce_dimension",slug:"temporal-mean-reduce-dimension"},{level:3,title:"Scale All Pixels Linearly: apply, linear_scale_range",slug:"scale-all-pixels-linearly-apply-linear-scale-range"},{level:3,title:"Spatial Aggregation: aggregate_spatial",slug:"spatial-aggregation-aggregate-spatial"},{level:3,title:"Output: save_result",slug:"output-save-result"},{level:4,title:"Raster Formats: GTiff, NetCDF",slug:"raster-formats-gtiff-netcdf"},{level:4,title:"Raster Formats: PNG",slug:"raster-formats-png"},{level:4,title:"Text Formats: JSON, CSV",slug:"text-formats-json-csv"},{level:3,title:"Output: Process as JSON",slug:"output-process-as-json"},{level:2,title:"Chapter 2",slug:"chapter-2"},{level:3,title:"Bandmath",slug:"bandmath"},{level:4,title:"Example 1: NDVI",slug:"example-1-ndvi"},{level:4,title:"Example 2: EVI",slug:"example-2-evi"},{level:3,title:"Masks: mask",slug:"masks-mask"},{level:4,title:"Mask Out Specific Values",slug:"mask-out-specific-values"},{level:4,title:"Thresholds",slug:"thresholds"},{level:3,title:"Pixel Operations: apply",slug:"pixel-operations-apply"},{level:3,title:"Image Kernels: apply_kernel",slug:"image-kernels-apply-kernel"},{level:2,title:"Endnote",slug:"endnote"}],lastUpdated:"7/26/2024, 6:48:28 PM",lastUpdatedTimestamp:1722019708e3,codeSwitcherOptions:{groups:{default:{py:"Python",r:"R",js:"JavaScript"}}}},{title:"openEO error codes",frontmatter:{},regularPath:"/documentation/1.0/developers/api/errors.html",relativePath:"documentation/1.0/developers/api/errors.md",key:"v-8d587926",path:"/documentation/1.0/developers/api/errors.html",lastUpdated:"7/26/2024, 6:48:28 PM",lastUpdatedTimestamp:1722019708e3,codeSwitcherOptions:{groups:{default:{py:"Python",r:"R",js:"JavaScript"}}}},{frontmatter:{fullpage:!0,stripCSS:!0},regularPath:"/documentation/1.0/developers/api/reference.html",relativePath:"documentation/1.0/developers/api/reference.md",key:"v-dc734f12",path:"/documentation/1.0/developers/api/reference.html",lastUpdated:"7/26/2024, 6:48:28 PM",lastUpdatedTimestamp:1722019708e3,codeSwitcherOptions:{groups:{default:{py:"Python",r:"R",js:"JavaScript"}}}},{title:"Architecture",frontmatter:{},regularPath:"/documentation/1.0/developers/arch.html",relativePath:"documentation/1.0/developers/arch.md",key:"v-75018026",path:"/documentation/1.0/developers/arch.html",lastUpdated:"7/26/2024, 6:48:28 PM",lastUpdatedTimestamp:1722019708e3,codeSwitcherOptions:{groups:{default:{py:"Python",r:"R",js:"JavaScript"}}}},{title:"Introduction",frontmatter:{},regularPath:"/documentation/1.0/developers/",relativePath:"documentation/1.0/developers/README.md",key:"v-43de507e",path:"/documentation/1.0/developers/",headers:[{level:2,title:"Additional information",slug:"additional-information"}],lastUpdated:"7/26/2024, 6:48:28 PM",lastUpdatedTimestamp:1722019708e3,codeSwitcherOptions:{groups:{default:{py:"Python",r:"R",js:"JavaScript"}}}},{title:"Performance guide for openEO backends",frontmatter:{},regularPath:"/documentation/1.0/developers/backends/performance.html",relativePath:"documentation/1.0/developers/backends/performance.md",key:"v-253cefad",path:"/documentation/1.0/developers/backends/performance.html",headers:[{level:2,title:"openEO API vision on performance & scalability",slug:"openeo-api-vision-on-performance-scalability"},{level:3,title:"Bringing the processing to the data",slug:"bringing-the-processing-to-the-data"},{level:3,title:"Datacube processing",slug:"datacube-processing"},{level:2,title:"Process graph execution",slug:"process-graph-execution"},{level:2,title:"Performance FAQ",slug:"performance-faq"},{level:3,title:"I have a highly optimized workflow, can openEO expose it?",slug:"i-have-a-highly-optimized-workflow-can-openeo-expose-it"},{level:3,title:"Can openEO be as fast as a hand-written workflow?",slug:"can-openeo-be-as-fast-as-a-hand-written-workflow"}],lastUpdated:"7/26/2024, 6:48:28 PM",lastUpdatedTimestamp:1722019708e3,codeSwitcherOptions:{groups:{default:{py:"Python",r:"R",js:"JavaScript"}}}},{title:"Getting started for service (back-end) providers",frontmatter:{},regularPath:"/documentation/1.0/developers/backends/getting-started.html",relativePath:"documentation/1.0/developers/backends/getting-started.md",key:"v-1772ad2d",path:"/documentation/1.0/developers/backends/getting-started.html",lastUpdated:"7/26/2024, 6:48:28 PM",lastUpdatedTimestamp:1722019708e3,codeSwitcherOptions:{groups:{default:{py:"Python",r:"R",js:"JavaScript"}}}},{title:"Getting started with openEO and Xarray and Dask",frontmatter:{},regularPath:"/documentation/1.0/developers/backends/xarray.html",relativePath:"documentation/1.0/developers/backends/xarray.md",key:"v-2840d4fe",path:"/documentation/1.0/developers/backends/xarray.html",headers:[{level:2,title:"Process Graph Parser for Python",slug:"process-graph-parser-for-python"},{level:2,title:"Python Processes for openEO",slug:"python-processes-for-openeo"},{level:2,title:"The loadcollection and saveresult process",slug:"the-load-collection-and-save-result-process"},{level:3,title:"Connection to ODC and STAC",slug:"connection-to-odc-and-stac"},{level:2,title:"openEO Client Side Processing",slug:"openeo-client-side-processing"},{level:2,title:"Adding a new process",slug:"adding-a-new-process"},{level:3,title:"Add the process spec",slug:"add-the-process-spec"},{level:3,title:"Add the process implementation",slug:"add-the-process-implementation"},{level:2,title:"HTTP REST Interface",slug:"http-rest-interface"}],lastUpdated:"7/26/2024, 6:48:28 PM",lastUpdatedTimestamp:1722019708e3,codeSwitcherOptions:{groups:{default:{py:"Python",r:"R",js:"JavaScript"}}}},{title:"Getting started for client developers",frontmatter:{},regularPath:"/documentation/1.0/developers/clients/getting-started.html",relativePath:"documentation/1.0/developers/clients/getting-started.md",key:"v-1b45967e",path:"/documentation/1.0/developers/clients/getting-started.html",headers:[{level:2,title:"Client library developers",slug:"client-library-developers"},{level:2,title:"Applications and Software plugins",slug:"applications-and-software-plugins"}],lastUpdated:"7/26/2024, 6:48:28 PM",lastUpdatedTimestamp:1722019708e3,codeSwitcherOptions:{groups:{default:{py:"Python",r:"R",js:"JavaScript"}}}},{title:"Client library development guidelines",frontmatter:{},regularPath:"/documentation/1.0/developers/clients/library-guidelines.html",relativePath:"documentation/1.0/developers/clients/library-guidelines.md",key:"v-021062ed",path:"/documentation/1.0/developers/clients/library-guidelines.html",headers:[{level:2,title:"Conventions",slug:"conventions"},{level:3,title:"Casing",slug:"casing"},{level:3,title:"Scopes",slug:"scopes"},{level:3,title:"Scope categories",slug:"scope-categories"},{level:3,title:"Parameters",slug:"parameters"},{level:2,title:"Method mappings",slug:"method-mappings"},{level:3,title:"Scope: openEO (root category)",slug:"scope-openeo-root-category"},{level:4,title:"Parameters",slug:"parameters-2"},{level:3,title:"Scope: Connection (API category)",slug:"scope-connection-api-category"},{level:4,title:"Parameters",slug:"parameters-3"},{level:3,title:"Scope Capabilities (Content category)",slug:"scope-capabilities-content-category"},{level:4,title:"Parameters",slug:"parameters-4"},{level:3,title:"Scope: File (API category)",slug:"scope-file-api-category"},{level:4,title:"Parameters",slug:"parameters-5"},{level:3,title:"Scope: Job (API category)",slug:"scope-job-api-category"},{level:4,title:"Parameters",slug:"parameters-6"},{level:3,title:"Scope: UserProcess (API category)",slug:"scope-userprocess-api-category"},{level:3,title:"Scope: Service (API category)",slug:"scope-service-api-category"},{level:2,title:"Processes",slug:"processes"},{level:2,title:"Workflow example",slug:"workflow-example"},{level:3,title:"R (functional style)",slug:"r-functional-style"},{level:3,title:"Python (mixed style)",slug:"python-mixed-style"},{level:3,title:"Java (object oriented style)",slug:"java-object-oriented-style"},{level:3,title:"PHP (procedural style)",slug:"php-procedural-style"}],lastUpdated:"7/26/2024, 6:48:28 PM",lastUpdatedTimestamp:1722019708e3,codeSwitcherOptions:{groups:{default:{py:"Python",r:"R",js:"JavaScript"}}}},{title:"API Profiles",frontmatter:{},regularPath:"/documentation/1.0/developers/profiles/api.html",relativePath:"documentation/1.0/developers/profiles/api.md",key:"v-97aa86e6",path:"/documentation/1.0/developers/profiles/api.html",headers:[{level:2,title:"Requirements per Profile",slug:"requirements-per-profile"},{level:3,title:"L1: Minimal",slug:"l1-minimal"},{level:4,title:"API fundamentals",slug:"api-fundamentals"},{level:4,title:"Well-known Discovery",slug:"well-known-discovery"},{level:4,title:"Capabilities",slug:"capabilities"},{level:4,title:"File Formats",slug:"file-formats"},{level:4,title:"Authentication",slug:"authentication"},{level:4,title:"Pre-defined Processes",slug:"pre-defined-processes"},{level:4,title:"Collections",slug:"collections"},{level:4,title:"Data Processing",slug:"data-processing"},{level:3,title:"L1A: Minimal - Synchronous Processing",slug:"l1a-minimal-synchronous-processing"},{level:4,title:"Synchronous Processing",slug:"synchronous-processing"},{level:3,title:"L1B: Minimal - Batch Jobs",slug:"l1b-minimal-batch-jobs"},{level:4,title:"Batch Jobs",slug:"batch-jobs"},{level:4,title:"Batch Jobs > Results",slug:"batch-jobs-results"},{level:3,title:"L1C: Minimal - Secondary Web Services",slug:"l1c-minimal-secondary-web-services"},{level:4,title:"Secondary Web Service Discovery",slug:"secondary-web-service-discovery"},{level:4,title:"Secondary Web Services",slug:"secondary-web-services"},{level:3,title:"L2: Recommended",slug:"l2-recommended"},{level:4,title:"API fundamentals",slug:"api-fundamentals-2"},{level:4,title:"Well-known Discovery",slug:"well-known-discovery-2"},{level:4,title:"Capabilities",slug:"capabilities-2"},{level:4,title:"File Formats",slug:"file-formats-2"},{level:4,title:"Authentication",slug:"authentication-2"},{level:4,title:"User Account",slug:"user-account"},{level:4,title:"Pre-defined Processes",slug:"pre-defined-processes-2"},{level:4,title:"Collections",slug:"collections-2"},{level:4,title:"User-defined processes",slug:"user-defined-processes"},{level:4,title:"Data Processing",slug:"data-processing-2"},{level:4,title:"Batch Jobs",slug:"batch-jobs-2"},{level:4,title:"Batch Jobs > Logs",slug:"batch-jobs-logs"},{level:4,title:"Batch Jobs > Results",slug:"batch-jobs-results-2"},{level:4,title:"Synchronous Processing",slug:"synchronous-processing-2"},{level:3,title:"L3: Advanced",slug:"l3-advanced"},{level:4,title:"API fundamentals",slug:"api-fundamentals-3"},{level:4,title:"Well-known Discovery",slug:"well-known-discovery-3"},{level:4,title:"Conformance Classes",slug:"conformance-classes"},{level:4,title:"Authentication",slug:"authentication-3"},{level:4,title:"Pre-defined Processes",slug:"pre-defined-processes-3"},{level:4,title:"Collections",slug:"collections-3"},{level:4,title:"User-defined processes",slug:"user-defined-processes-2"},{level:4,title:"Validation",slug:"validation"},{level:4,title:"Batch Jobs",slug:"batch-jobs-3"},{level:4,title:"Batch Jobs > Logs",slug:"batch-jobs-logs-2"},{level:4,title:"Batch Jobs > Estimates",slug:"batch-jobs-estimates"},{level:4,title:"Batch Jobs > Results",slug:"batch-jobs-results-3"},{level:4,title:"Synchronous Processing",slug:"synchronous-processing-3"},{level:3,title:"L3-UDF: UDF",slug:"l3-udf-udf"},{level:4,title:"UDF Runtimes",slug:"udf-runtimes"},{level:3,title:"L3-FS: File Storage",slug:"l3-fs-file-storage"},{level:4,title:"File Storage",slug:"file-storage"},{level:3,title:"L3-SWS: Secondary Web Services",slug:"l3-sws-secondary-web-services"},{level:4,title:"Secondary Web Service Discovery",slug:"secondary-web-service-discovery-2"},{level:4,title:"Secondary Web Services",slug:"secondary-web-services-2"},{level:3,title:"L4: Above and Beyond",slug:"l4-above-and-beyond"},{level:4,title:"Secondary Web Services",slug:"secondary-web-services-3"},{level:4,title:"Secondary Web Services > Logs",slug:"secondary-web-services-logs"},{level:4,title:"Batch Jobs",slug:"batch-jobs-4"},{level:4,title:"Batch Jobs > Estimates",slug:"batch-jobs-estimates-2"},{level:4,title:"Batch Jobs > Results",slug:"batch-jobs-results-4"}],lastUpdated:"7/26/2024, 6:48:28 PM",lastUpdatedTimestamp:1722019708e3,codeSwitcherOptions:{groups:{default:{py:"Python",r:"R",js:"JavaScript"}}}},{title:"openEO Profiles",frontmatter:{},regularPath:"/documentation/1.0/developers/profiles/",relativePath:"documentation/1.0/developers/profiles/README.md",key:"v-e35c5e24",path:"/documentation/1.0/developers/profiles/",lastUpdated:"7/26/2024, 6:48:28 PM",lastUpdatedTimestamp:1722019708e3,codeSwitcherOptions:{groups:{default:{py:"Python",r:"R",js:"JavaScript"}}}},{title:"Glossary",frontmatter:{},regularPath:"/documentation/1.0/glossary.html",relativePath:"documentation/1.0/glossary.md",key:"v-4af2bfca",path:"/documentation/1.0/glossary.html",headers:[{level:2,title:"General terms",slug:"general-terms"},{level:2,title:"Processes",slug:"processes"},{level:2,title:"EO data (Collections)",slug:"eo-data-collections"},{level:2,title:"Spatial datacubes",slug:"spatial-datacubes"},{level:2,title:"Vector data",slug:"vector-data"},{level:2,title:"User-defined function (UDF)",slug:"user-defined-function-udf"},{level:2,title:"Data Processing modes",slug:"data-processing-modes"}],lastUpdated:"7/26/2024, 6:48:28 PM",lastUpdatedTimestamp:1722019708e3,codeSwitcherOptions:{groups:{default:{py:"Python",r:"R",js:"JavaScript"}}}},{title:"JavaScript Client",frontmatter:{},regularPath:"/documentation/1.0/javascript/",relativePath:"documentation/1.0/javascript/index.md",key:"v-1a823cb0",path:"/documentation/1.0/javascript/",headers:[{level:2,title:"Installation",slug:"installation"},{level:2,title:"Exploring a back-end",slug:"exploring-a-back-end"},{level:3,title:"Collections",slug:"collections"},{level:3,title:"Processes",slug:"processes"},{level:2,title:"Authentication",slug:"authentication"},{level:3,title:"Basic Authentication",slug:"basic-authentication"},{level:3,title:"OpenID Connect Authentication",slug:"openid-connect-authentication"},{level:2,title:"Creating a (user-defined) process",slug:"creating-a-user-defined-process"},{level:2,title:"Batch Job Management",slug:"batch-job-management"},{level:2,title:"Full Example",slug:"full-example"},{level:2,title:"User Defined Functions",slug:"user-defined-functions"},{level:2,title:"Additional Information",slug:"additional-information"}],lastUpdated:"7/26/2024, 6:48:28 PM",lastUpdatedTimestamp:1722019708e3,codeSwitcherOptions:{groups:{default:{py:"Python",r:"R",js:"JavaScript"}}}},{title:"Process Profiles",frontmatter:{},regularPath:"/documentation/1.0/developers/profiles/processes.html",relativePath:"documentation/1.0/developers/profiles/processes.md",key:"v-04d2236d",path:"/documentation/1.0/developers/profiles/processes.html",headers:[{level:2,title:"Requirements per Profile",slug:"requirements-per-profile"},{level:3,title:"L1: Minimal",slug:"l1-minimal"},{level:3,title:"L2: Recommended",slug:"l2-recommended"},{level:3,title:"L2A: Recommended Raster",slug:"l2a-recommended-raster"},{level:3,title:"L2B: Recommended Vector",slug:"l2b-recommended-vector"},{level:3,title:"L2-Date: Date & Time manipulation",slug:"l2-date-date-time-manipulation"},{level:3,title:"L2-Text: Text manipulation",slug:"l2-text-text-manipulation"},{level:3,title:"L3: Advanced",slug:"l3-advanced"},{level:3,title:"L3-ML: Machine Learning",slug:"l3-ml-machine-learning"},{level:3,title:"L3-UDF: User-Defined Functions",slug:"l3-udf-user-defined-functions"},{level:3,title:"L3-Clim: Cimatology",slug:"l3-clim-cimatology"},{level:3,title:"L3-ARD: Analysis-Ready Data",slug:"l3-ard-analysis-ready-data"},{level:3,title:"L4: Above and Beyond",slug:"l4-above-and-beyond"}],lastUpdated:"7/26/2024, 6:48:28 PM",lastUpdatedTimestamp:1722019708e3,codeSwitcherOptions:{groups:{default:{py:"Python",r:"R",js:"JavaScript"}}}},{frontmatter:{fullpage:!0,stripCSS:!0},regularPath:"/documentation/1.0/processes.html",relativePath:"documentation/1.0/processes.md",key:"v-00153acd",path:"/documentation/1.0/processes.html",lastUpdated:"7/26/2024, 6:48:28 PM",lastUpdatedTimestamp:1722019708e3,codeSwitcherOptions:{groups:{default:{py:"Python",r:"R",js:"JavaScript"}}}},{title:"Get started with the openEO Python Client Client Side Processing",frontmatter:{},regularPath:"/documentation/1.0/python/client-side-processing.html",relativePath:"documentation/1.0/python/client-side-processing.md",key:"v-9a2a2626",path:"/documentation/1.0/python/client-side-processing.html",headers:[{level:2,title:"Background",slug:"background"},{level:2,title:"Installation",slug:"installation"},{level:2,title:"Usage",slug:"usage"},{level:3,title:"STAC Collections and Items",slug:"stac-collections-and-items"},{level:3,title:"Local Collections",slug:"local-collections"},{level:3,title:"Local Processing",slug:"local-processing"},{level:2,title:"Client-Side Processing Example Notebooks",slug:"client-side-processing-example-notebooks"},{level:2,title:"Additional Information",slug:"additional-information"}],lastUpdated:"7/26/2024, 6:48:28 PM",lastUpdatedTimestamp:1722019708e3,codeSwitcherOptions:{groups:{default:{py:"Python",r:"R",js:"JavaScript"}}}},{title:"Python Client",frontmatter:{},regularPath:"/documentation/1.0/python/",relativePath:"documentation/1.0/python/index.md",key:"v-560d08d2",path:"/documentation/1.0/python/",headers:[{level:2,title:"Installation",slug:"installation"},{level:2,title:"Exploring a back-end",slug:"exploring-a-back-end"},{level:3,title:"Collections",slug:"collections"},{level:3,title:"Processes",slug:"processes"},{level:2,title:"Authentication",slug:"authentication"},{level:3,title:"Basic Authentication",slug:"basic-authentication"},{level:3,title:"OpenID Connect Authentication",slug:"openid-connect-authentication"},{level:2,title:"Working with Datacube",slug:"working-with-datacube"},{level:3,title:"Creating a Datacube",slug:"creating-a-datacube"},{level:3,title:"Applying processes",slug:"applying-processes"},{level:3,title:"Defining output format",slug:"defining-output-format"},{level:2,title:"Execution",slug:"execution"},{level:3,title:"Batch job execution",slug:"batch-job-execution"},{level:2,title:"Full Example",slug:"full-example"},{level:2,title:"User Defined Functions",slug:"user-defined-functions"},{level:2,title:"Additional Information",slug:"additional-information"}],lastUpdated:"7/26/2024, 6:48:28 PM",lastUpdatedTimestamp:1722019708e3,codeSwitcherOptions:{groups:{default:{py:"Python",r:"R",js:"JavaScript"}}}},{title:"QGIS Plugin",frontmatter:{},regularPath:"/documentation/1.0/qgis/",relativePath:"documentation/1.0/qgis/index.md",key:"v-ef2073ec",path:"/documentation/1.0/qgis/",headers:[{level:2,title:"Installation",slug:"installation"},{level:2,title:"Connecting",slug:"connecting"},{level:2,title:"Exploring a backend",slug:"exploring-a-backend"},{level:2,title:"Job Management",slug:"job-management"},{level:3,title:"Creating new Jobs",slug:"creating-new-jobs"},{level:3,title:"Adapting existing Jobs",slug:"adapting-existing-jobs"},{level:4,title:"Process Argument Helper",slug:"process-argument-helper"},{level:2,title:"Service Management",slug:"service-management"},{level:2,title:"Additional Information",slug:"additional-information"}],lastUpdated:"7/26/2024, 6:48:28 PM",lastUpdatedTimestamp:1722019708e3,codeSwitcherOptions:{groups:{default:{py:"Python",r:"R",js:"JavaScript"}}}},{title:"R Client",frontmatter:{},regularPath:"/documentation/1.0/r/",relativePath:"documentation/1.0/r/index.md",key:"v-592eaa86",path:"/documentation/1.0/r/",headers:[{level:2,title:"Useful links",slug:"useful-links"},{level:2,title:"Installation",slug:"installation"},{level:2,title:"Exploring a back-end",slug:"exploring-a-back-end"},{level:3,title:"Collections",slug:"collections"},{level:3,title:"Processes",slug:"processes"},{level:2,title:"Authentication",slug:"authentication"},{level:3,title:"Basic Authentication",slug:"basic-authentication"},{level:3,title:"OpenID Connect Authentication",slug:"openid-connect-authentication"},{level:2,title:"Creating a (user-defined) process",slug:"creating-a-user-defined-process"},{level:2,title:"Batch Job Management",slug:"batch-job-management"},{level:2,title:"Full Example",slug:"full-example"},{level:2,title:"User Defined Functions",slug:"user-defined-functions"}],lastUpdated:"7/26/2024, 6:48:28 PM",lastUpdatedTimestamp:1722019708e3,codeSwitcherOptions:{groups:{default:{py:"Python",r:"R",js:"JavaScript"}}}},{title:"User-defined functions",frontmatter:{},regularPath:"/documentation/1.0/udfs.html",relativePath:"documentation/1.0/udfs.md",key:"v-ffc79ec2",path:"/documentation/1.0/udfs.html",headers:[{level:2,title:"Users",slug:"users"},{level:3,title:"JavaScript",slug:"javascript"},{level:3,title:"Python",slug:"python"},{level:3,title:"QGIS",slug:"qgis"},{level:3,title:"R",slug:"r"},{level:3,title:"Web Editor",slug:"web-editor"},{level:2,title:"Back-ends",slug:"back-ends"}],lastUpdated:"7/26/2024, 6:48:28 PM",lastUpdatedTimestamp:1722019708e3,codeSwitcherOptions:{groups:{default:{py:"Python",r:"R",js:"JavaScript"}}}},{title:"Contributor Code of Conduct",frontmatter:{},regularPath:"/documentation/code-of-conduct.html",relativePath:"documentation/code-of-conduct.md",key:"v-c71b5aa6",path:"/documentation/code-of-conduct.html",lastUpdated:"7/26/2024, 6:48:28 PM",lastUpdatedTimestamp:1722019708e3,codeSwitcherOptions:{groups:{default:{py:"Python",r:"R",js:"JavaScript"}}}},{title:"Software Development Guidelines",frontmatter:{},regularPath:"/documentation/software-guidelines.html",relativePath:"documentation/software-guidelines.md",key:"v-1005bb66",path:"/documentation/software-guidelines.html",headers:[{level:2,title:"Software quality guidelines",slug:"software-quality-guidelines"},{level:2,title:"Software documentation guidelines",slug:"software-documentation-guidelines"},{level:2,title:"Software review",slug:"software-review"},{level:2,title:"Test-driven development",slug:"test-driven-development"},{level:2,title:"Continuous integration",slug:"continuous-integration"},{level:2,title:"Additional guidelines",slug:"additional-guidelines"}],lastUpdated:"7/26/2024, 6:48:28 PM",lastUpdatedTimestamp:1722019708e3,codeSwitcherOptions:{groups:{default:{py:"Python",r:"R",js:"JavaScript"}}}},{title:"IEEE IGARRS 2021 HD-3: Hands-on openEO: access cloud platforms using your preferred programming language",frontmatter:{},regularPath:"/events/igarrs2021.html",relativePath:"events/igarrs2021.md",key:"v-186cd6ed",path:"/events/igarrs2021.html",headers:[{level:2,title:"Agenda",slug:"agenda"},{level:2,title:"Python client",slug:"python-client"},{level:3,title:"Logging in",slug:"logging-in"},{level:3,title:"openEO in Python intro",slug:"openeo-in-python-intro"},{level:2,title:"R client",slug:"r-client"},{level:2,title:"openEO user interfaces",slug:"openeo-user-interfaces"},{level:2,title:"Use cases",slug:"use-cases"}],lastUpdated:"7/26/2024, 6:48:28 PM",lastUpdatedTimestamp:1722019708e3,codeSwitcherOptions:{groups:{default:{py:"Python",r:"R",js:"JavaScript"}}}},{title:"Welcome to openEO!",frontmatter:{news:!0,title:"Welcome to openEO!",date:"2017-12-05T00:00:00.000Z",author:"Edzer Pebesma"},regularPath:"/news/2017-12-05-welcome.html",relativePath:"news/2017-12-05-welcome.md",key:"v-0ee3f026",path:"/news/2017-12-05-welcome.html",lastUpdated:"7/26/2024, 6:48:28 PM",lastUpdatedTimestamp:1722019708e3,codeSwitcherOptions:{groups:{default:{py:"Python",r:"R",js:"JavaScript"}}}},{title:"First week of intensive collaboration: Dec 4-6, 2017",frontmatter:{news:!0,title:"First week of intensive collaboration: Dec 4-6, 2017",date:"2017-12-18T00:00:00.000Z",author:"Edzer Pebesma"},regularPath:"/news/2017-12-18-VITO_meeting.html",relativePath:"news/2017-12-18-VITO_meeting.md",key:"v-2997b752",path:"/news/2017-12-18-VITO_meeting.html",lastUpdated:"7/26/2024, 6:48:28 PM",lastUpdatedTimestamp:1722019708e3,codeSwitcherOptions:{groups:{default:{py:"Python",r:"R",js:"JavaScript"}}}},{title:"Second week of intensive collaboration: Jan 22-24, 2018",frontmatter:{news:!0,title:"Second week of intensive collaboration: Jan 22-24, 2018",date:"2018-01-31T00:00:00.000Z",author:"Marius Appel"},regularPath:"/news/2018-01-31-WWU_meeting.html",relativePath:"news/2018-01-31-WWU_meeting.md",key:"v-24966ce6",path:"/news/2018-01-31-WWU_meeting.html",lastUpdated:"7/26/2024, 6:48:28 PM",lastUpdatedTimestamp:1722019708e3,codeSwitcherOptions:{groups:{default:{py:"Python",r:"R",js:"JavaScript"}}}},{title:"openEO proves its concept",frontmatter:{news:!0,title:"openEO proves its concept",date:"2018-03-17T00:00:00.000Z",author:"Edzer Pebesma, the openEO consortium"},regularPath:"/news/2018-03-15-poc.html",relativePath:"news/2018-03-15-poc.md",key:"v-4fe4e126",path:"/news/2018-03-15-poc.html",headers:[{level:2,title:"The problem",slug:"the-problem"},{level:2,title:"Why an API?",slug:"why-an-api"},{level:2,title:"First results",slug:"first-results"},{level:2,title:"The three use cases",slug:"the-three-use-cases"},{level:2,title:"Links to the client and back-end implementations",slug:"links-to-the-client-and-back-end-implementations"},{level:2,title:"Proof-of-concept videos",slug:"proof-of-concept-videos"},{level:3,title:"R client and WCPS back-end, use case 1",slug:"r-client-and-wcps-back-end-use-case-1"},{level:3,title:"Grass GIS back-end, use cases 1, 2 and 3",slug:"grass-gis-back-end-use-cases-1-2-and-3"},{level:3,title:"R client and R back-end, use-case 1",slug:"r-client-and-r-back-end-use-case-1"},{level:3,title:"R client and R back-end, use case 3",slug:"r-client-and-r-back-end-use-case-3"},{level:3,title:"openEO Web Editor (JS client) with three back-ends (use case 1)",slug:"openeo-web-editor-js-client-with-three-back-ends-use-case-1"},{level:3,title:"openEO Web Editor (JS client) with R back-end (use case 3)",slug:"openeo-web-editor-js-client-with-r-back-end-use-case-3"},{level:3,title:"Python client with GeoPySpark back-end (use case 1)",slug:"python-client-with-geopyspark-back-end-use-case-1"},{level:3,title:"openEO Web Editor (JS client) with Google Earth Engine back-end (use case 1)",slug:"openeo-web-editor-js-client-with-google-earth-engine-back-end-use-case-1"},{level:2,title:"Links to documents",slug:"links-to-documents"},{level:2,title:"Next steps",slug:"next-steps"},{level:2,title:"Getting involved",slug:"getting-involved"}],lastUpdated:"7/26/2024, 6:48:28 PM",lastUpdatedTimestamp:1722019708e3,codeSwitcherOptions:{groups:{default:{py:"Python",r:"R",js:"JavaScript"}}}},{title:"openEO year one review meeting",frontmatter:{news:!0,title:"openEO year one review meeting",date:"2018-10-30T00:00:00.000Z",author:"Matthias Schramm"},regularPath:"/news/2018-10-30-year-one-review-meeting.html",relativePath:"news/2018-10-30-year-one-review-meeting.md",key:"v-d2a018a6",path:"/news/2018-10-30-year-one-review-meeting.html",lastUpdated:"7/26/2024, 6:48:28 PM",lastUpdatedTimestamp:1722019708e3,codeSwitcherOptions:{groups:{default:{py:"Python",r:"R",js:"JavaScript"}}}},{title:"User Requirements Survey for openEO launched",frontmatter:{news:!0,title:"User Requirements Survey for openEO launched",date:"2018-05-23T00:00:00.000Z",author:"Sarah Carter"},regularPath:"/news/2018-05-23-user-requirements-survey-launched.html",relativePath:"news/2018-05-23-user-requirements-survey-launched.md",key:"v-f9778ae6",path:"/news/2018-05-23-user-requirements-survey-launched.html",lastUpdated:"7/26/2024, 6:48:28 PM",lastUpdatedTimestamp:1722019708e3,codeSwitcherOptions:{groups:{default:{py:"Python",r:"R",js:"JavaScript"}}}},{title:"H2020 EO Big Data Hackathon Nov 7-8",frontmatter:{news:!0,title:"H2020 EO Big Data Hackathon Nov 7-8",date:"2019-10-07T00:00:00.000Z",author:"Edzer Pebesma"},regularPath:"/news/2019-10-07-EO-big-data-hackaton.html",relativePath:"news/2019-10-07-EO-big-data-hackaton.md",key:"v-9ddae032",path:"/news/2019-10-07-EO-big-data-hackaton.html",lastUpdated:"7/26/2024, 6:48:28 PM",lastUpdatedTimestamp:1722019708e3,codeSwitcherOptions:{groups:{default:{py:"Python",r:"R",js:"JavaScript"}}}},{title:"openEO API v0.4.0 released",frontmatter:{news:!0,title:"openEO API v0.4.0 released",date:"2019-03-07T00:00:00.000Z",author:"Matthias Mohr"},regularPath:"/news/2019-03-07-openeo-api-040.html",relativePath:"news/2019-03-07-openeo-api-040.md",key:"v-45d803ab",path:"/news/2019-03-07-openeo-api-040.html",headers:[{level:2,title:"New process catalogue and process graph changes",slug:"new-process-catalogue-and-process-graph-changes"},{level:2,title:"Other improvements",slug:"other-improvements"},{level:2,title:"Next steps",slug:"next-steps"}],lastUpdated:"7/26/2024, 6:48:28 PM",lastUpdatedTimestamp:1722019708e3,codeSwitcherOptions:{groups:{default:{py:"Python",r:"R",js:"JavaScript"}}}},{title:"Stable release of the openEO API and Processes (v1.0.0)",frontmatter:{news:!0,title:"Stable release of the openEO API and Processes (v1.0.0)",date:"2020-07-31T00:00:00.000Z",author:"Matthias Mohr"},regularPath:"/news/2020-07-31-openeo-api-released.html",relativePath:"news/2020-07-31-openeo-api-released.md",key:"v-2fcee9ad",path:"/news/2020-07-31-openeo-api-released.html",headers:[{level:2,title:"Processes",slug:"processes"},{level:2,title:"STAC and OGC APIs",slug:"stac-and-ogc-apis"},{level:2,title:"User-defined Functions (UDFs)",slug:"user-defined-functions-udfs"},{level:2,title:"Other improvements",slug:"other-improvements"},{level:2,title:"Limitations",slug:"limitations"},{level:2,title:"Next steps",slug:"next-steps"}],lastUpdated:"7/26/2024, 6:48:28 PM",lastUpdatedTimestamp:1722019708e3,codeSwitcherOptions:{groups:{default:{py:"Python",r:"R",js:"JavaScript"}}}},{title:"Lessons learned while developing the openEO API",frontmatter:{news:!0,title:"Lessons learned while developing the openEO API",date:"2020-07-31T00:00:00.000Z",author:"Matthias Mohr"},regularPath:"/news/2020-07-31-lessons-learned.html",relativePath:"news/2020-07-31-lessons-learned.md",key:"v-3f85032d",path:"/news/2020-07-31-lessons-learned.html",headers:[{level:2,title:"1. Collection Names",slug:"_1-collection-names"},{level:2,title:"2. Other Names",slug:"_2-other-names"},{level:2,title:"3. Chunked Collections",slug:"_3-chunked-collections"},{level:2,title:"4. What to specify?",slug:"_4-what-to-specify"},{level:3,title:"File Formats",slug:"file-formats"},{level:2,title:"5. Authentication",slug:"_5-authentication"},{level:2,title:"6. Debugging Experience",slug:"_6-debugging-experience"},{level:2,title:"7. Defining interoperable Processes",slug:"_7-defining-interoperable-processes"},{level:2,title:"Conclusion",slug:"conclusion"}],lastUpdated:"7/26/2024, 6:48:28 PM",lastUpdatedTimestamp:1722019708e3,codeSwitcherOptions:{groups:{default:{py:"Python",r:"R",js:"JavaScript"}}}},{title:"openEO API v1.0.1 released",frontmatter:{news:!0,title:"openEO API v1.0.1 released",date:"2020-11-30T00:00:00.000Z",author:"Matthias Mohr"},regularPath:"/news/2020-11-30-openeo-api-101-released.html",relativePath:"news/2020-11-30-openeo-api-101-released.md",key:"v-0e5e57cd",path:"/news/2020-11-30-openeo-api-101-released.html",lastUpdated:"7/26/2024, 6:48:28 PM",lastUpdatedTimestamp:1722019708e3,codeSwitcherOptions:{groups:{default:{py:"Python",r:"R",js:"JavaScript"}}}},{title:"openEO Virtual User Workshop",frontmatter:{news:!0,title:"openEO Virtual User Workshop",date:"2020-09-02T00:00:00.000Z",author:"Matthias Schramm"},regularPath:"/news/2020-09-02-openeo-user-workshop.html",relativePath:"news/2020-09-02-openeo-user-workshop.md",key:"v-525dec3e",path:"/news/2020-09-02-openeo-user-workshop.html",headers:[{level:3,title:"UPDATE:",slug:"update"}],lastUpdated:"7/26/2024, 6:48:28 PM",lastUpdatedTimestamp:1722019708e3,codeSwitcherOptions:{groups:{default:{py:"Python",r:"R",js:"JavaScript"}}}},{title:"R Client on CRAN",frontmatter:{news:!0,title:"R Client on CRAN",date:"2021-11-08T00:00:00.000Z",author:"Matthias Mohr"},regularPath:"/news/2021-11-08-r-client-on-cran.html",relativePath:"news/2021-11-08-r-client-on-cran.md",key:"v-06e0a8ca",path:"/news/2021-11-08-r-client-on-cran.html",lastUpdated:"7/26/2024, 6:48:28 PM",lastUpdatedTimestamp:1722019708e3,codeSwitcherOptions:{groups:{default:{py:"Python",r:"R",js:"JavaScript"}}}},{title:"openEO API v1.1.0 released",frontmatter:{news:!0,title:"openEO API v1.1.0 released",date:"2021-05-17T00:00:00.000Z",author:"Matthias Mohr"},regularPath:"/news/2021-05-17-openeo-api-110-released.html",relativePath:"news/2021-05-17-openeo-api-110-released.md",key:"v-6e6b7e2d",path:"/news/2021-05-17-openeo-api-110-released.html",lastUpdated:"7/26/2024, 6:48:28 PM",lastUpdatedTimestamp:1722019708e3,codeSwitcherOptions:{groups:{default:{py:"Python",r:"R",js:"JavaScript"}}}},{title:"openEO PSC meetings",frontmatter:{news:!0,title:"openEO PSC meetings",date:"2022-04-08T00:00:00.000Z",author:"Matthias Mohr"},regularPath:"/news/2022-04-08-psc-meetings.html",relativePath:"news/2022-04-08-psc-meetings.md",key:"v-1227575e",path:"/news/2022-04-08-psc-meetings.html",lastUpdated:"7/26/2024, 6:48:28 PM",lastUpdatedTimestamp:1722019708e3,codeSwitcherOptions:{groups:{default:{py:"Python",r:"R",js:"JavaScript"}}}},{title:"R Client v1.2.0 has been released",frontmatter:{news:!0,title:"R Client v1.2.0 has been released",date:"2022-05-12T00:00:00.000Z",author:"Matthias Mohr, Florian Lahn"},regularPath:"/news/2022-05-12-r-client-v120.html",relativePath:"news/2022-05-12-r-client-v120.md",key:"v-59d340ad",path:"/news/2022-05-12-r-client-v120.html",lastUpdated:"7/26/2024, 6:48:28 PM",lastUpdatedTimestamp:1722019708e3,codeSwitcherOptions:{groups:{default:{py:"Python",r:"R",js:"JavaScript"}}}},{title:"Monthly openEO community meeting",frontmatter:{news:!0,title:"Monthly openEO community meeting",date:"2022-07-07T00:00:00.000Z",author:"Matthias Mohr"},regularPath:"/news/2022-07-07-monthly-dev-calls.html",relativePath:"news/2022-07-07-monthly-dev-calls.md",key:"v-00d62ee6",path:"/news/2022-07-07-monthly-dev-calls.html",lastUpdated:"7/26/2024, 6:48:28 PM",lastUpdatedTimestamp:1722019708e3,codeSwitcherOptions:{groups:{default:{py:"Python",r:"R",js:"JavaScript"}}}},{title:"R Client v1.3.0 has been released",frontmatter:{news:!0,title:"R Client v1.3.0 has been released",date:"2022-11-17T00:00:00.000Z",author:"Matthias Mohr, Peter J. Zellner, Florian Lahn"},regularPath:"/news/2022-11-17-r-client-v130.html",relativePath:"news/2022-11-17-r-client-v130.md",key:"v-221bfb8d",path:"/news/2022-11-17-r-client-v130.html",headers:[{level:2,title:"Better support for sf",slug:"better-support-for-sf"},{level:2,title:"New Vignettes",slug:"new-vignettes"}],lastUpdated:"7/26/2024, 6:48:28 PM",lastUpdatedTimestamp:1722019708e3,codeSwitcherOptions:{groups:{default:{py:"Python",r:"R",js:"JavaScript"}}}},{title:"New releases for openEO API and openEO Processes, focus on vector data",frontmatter:{news:!0,title:"New releases for openEO API and openEO Processes, focus on vector data",date:"2023-05-25T00:00:00.000Z",author:"Matthias Mohr"},regularPath:"/news/2023-05-25-new-openeo-versions-120-200rc1%20copy.html",relativePath:"news/2023-05-25-new-openeo-versions-120-200rc1 copy.md",key:"v-3eeef04a",path:"/news/2023-05-25-new-openeo-versions-120-200rc1%20copy.html",headers:[{level:2,title:"openEO API v1.2.0",slug:"openeo-api-v1-2-0"},{level:2,title:"openEO Processes v2.0.0-rc.1",slug:"openeo-processes-v2-0-0-rc-1"}],lastUpdated:"7/26/2024, 6:48:28 PM",lastUpdatedTimestamp:1722019708e3,codeSwitcherOptions:{groups:{default:{py:"Python",r:"R",js:"JavaScript"}}}},{title:"MOOC Cubes and Clouds - open for registration",frontmatter:{news:!0,title:"MOOC Cubes and Clouds - open for registration",date:"2024-03-22T00:00:00.000Z",author:"Peter Zellner"},regularPath:"/news/2024-03-22_mooc_cubeandclouds.html",relativePath:"news/2024-03-22_mooc_cubeandclouds.md",key:"v-d5007282",path:"/news/2024-03-22_mooc_cubeandclouds.html",lastUpdated:"7/26/2024, 6:48:28 PM",lastUpdatedTimestamp:1722019708e3,codeSwitcherOptions:{groups:{default:{py:"Python",r:"R",js:"JavaScript"}}}},{title:"openEO submitted to OGC for consideration as an OGC community standard",frontmatter:{news:!0,title:"openEO submitted to OGC for consideration as an OGC community standard",date:"2023-12-06T00:00:00.000Z",author:"Matthias Mohr"},regularPath:"/news/2023-12-06-openeo-submitted-to-ogc.html",relativePath:"news/2023-12-06-openeo-submitted-to-ogc.md",key:"v-857a96a6",path:"/news/2023-12-06-openeo-submitted-to-ogc.html",lastUpdated:"7/26/2024, 6:48:28 PM",lastUpdatedTimestamp:1722019708e3,codeSwitcherOptions:{groups:{default:{py:"Python",r:"R",js:"JavaScript"}}}},{title:"OGC seeks public comment on the adoption of openEO as a Community Standard",frontmatter:{news:!0,title:"OGC seeks public comment on the adoption of openEO as a Community Standard",date:"2024-02-06T00:00:00.000Z",author:"Matthias Mohr"},regularPath:"/news/2024-02-06-openeo-ogc-rfc.html",relativePath:"news/2024-02-06-openeo-ogc-rfc.md",key:"v-10d9ffb7",path:"/news/2024-02-06-openeo-ogc-rfc.html",lastUpdated:"7/26/2024, 6:48:28 PM",lastUpdatedTimestamp:1722019708e3,codeSwitcherOptions:{groups:{default:{py:"Python",r:"R",js:"JavaScript"}}}},{title:"News",frontmatter:{sidebar:!1},regularPath:"/news/",relativePath:"news/README.md",key:"v-8850e2c4",path:"/news/",lastUpdated:"7/26/2024, 6:48:28 PM",lastUpdatedTimestamp:1722019708e3,codeSwitcherOptions:{groups:{default:{py:"Python",r:"R",js:"JavaScript"}}}},{title:"openEO Project Steering Committee",frontmatter:{},regularPath:"/psc.html",relativePath:"psc.md",key:"v-64c18f4d",path:"/psc.html",headers:[{level:2,title:"Members",slug:"members"},{level:2,title:"Detailed Process",slug:"detailed-process"},{level:3,title:"When is Vote Required?",slug:"when-is-vote-required"},{level:3,title:"Final remarks",slug:"final-remarks"},{level:2,title:"Committee Membership",slug:"committee-membership"},{level:3,title:"Adding Members",slug:"adding-members"},{level:3,title:"Stepping Down",slug:"stepping-down"},{level:2,title:"History",slug:"history"}],codeSwitcherOptions:{groups:{default:{py:"Python",r:"R",js:"JavaScript"}}}},{title:"Software",frontmatter:{},regularPath:"/software.html",relativePath:"software.md",key:"v-9adb302a",path:"/software.html",headers:[{level:2,title:"Clients",slug:"clients"},{level:2,title:"Back-ends",slug:"back-ends"},{level:2,title:"Specification",slug:"specification"},{level:2,title:"Ecosystem",slug:"ecosystem"}],lastUpdated:"7/26/2024, 6:48:28 PM",lastUpdatedTimestamp:1722019708e3,codeSwitcherOptions:{groups:{default:{py:"Python",r:"R",js:"JavaScript"}}}}],themeConfig:{apiVersion:"1.2.0",versions:[{folder:"1.0",path:"/documentation/1.0/",title:"1.x",apiTag:"1.2.0",processesTag:"2.0.0-rc.1",apiVersions:["1.0.0","1.0.1","1.1.0","1.2.0"],userNav:[{text:"Introduction",link:"index.html"},{text:"Glossary",link:"glossary.html"},{text:"Datacubes",link:"datacubes.html"},{text:"Getting Started",items:[{text:"JavaScript",link:"javascript/index.html"},{text:"Python",link:"python/index.html"},{text:"QGIS",link:"qgis/index.html"},{text:"R",link:"r/index.html"},{text:"Client-Side Processing (Python)",link:"python/client-side-processing.html"}]},{text:"Processes",link:"processes.html"},{text:"Cookbook",link:"cookbook/index.html"},{text:"Authentication",link:"authentication.html"},{text:"UDFs",link:"udfs.html"}],devNav:[{text:"Introduction",link:"developers/index.html"},{text:"Glossary",link:"glossary.html"},{text:"Architecture",link:"developers/arch.html"},{text:"Service Providers",items:[{text:"Getting Started",link:"developers/backends/getting-started.html"},{text:"Performance Guide",link:"developers/backends/performance.html"},{text:"Xarray / Dask Guide",link:"developers/backends/xarray.html"},{text:"Profiles",link:"developers/profiles/index.html"}]},{text:"Client Developers",items:[{text:"Getting Started",link:"developers/clients/getting-started.html"},{text:"Library Guidelines",link:"developers/clients/library-guidelines.html"}]},{text:"API",items:[{text:"Reference",link:"developers/api/reference.html"},{text:"Profiles",link:"developers/profiles/api.html"}]},{text:"Processes",items:[{text:"Reference",link:"processes.html"},{text:"Profiles",link:"developers/profiles/processes.html"}]},{text:"Error Codes",link:"developers/api/errors.html"},{text:"Authentication",link:"authentication.html"},{text:"UDFs",link:"udfs.html"}]},{folder:"0.4",path:"/documentation/0.4/",title:"0.4",apiTag:"0.4.2",apiFormat:"json",processesTag:"0.4.2",apiVersions:["0.4.0","0.4.1","0.4.2"],userNav:[{text:"Getting Started",link:"getting-started.html"},{text:"Glossary",link:"glossary.html"},{text:"Processes",link:"processes.html"},{text:"UDFs",link:"udfs.html"}],devNav:[{text:"Introduction",link:"developers/index.html"},{text:"Glossary",link:"glossary.html"},{text:"Architecture",link:"developers/arch.html"},{text:"Service Providers",items:[{text:"Getting Started",link:"developers/backends/getting-started.html"},{text:"UDFs",link:"developers/backends/udfs.html"}]},{text:"Client Developers",items:[{text:"Getting Started",link:"developers/clients/getting-started.html"},{text:"Library Guidelines",link:"developers/clients/library-guidelines.html"}]},{text:"API",items:[{text:"Specification",link:"developers/api/reference.html"},{text:"Further documentation",link:"developers/api/index.html"}]},{text:"Processes",link:"processes.html"},{text:"Error Codes",link:"developers/api/errors.html"},{text:"Examples",link:"developers/examples/"}]}],defaultVersion:0,docPath:"/documentation/1.0/",logo:"/images/openeo_navbar_logo.png",editLinks:!0,docsRepo:"Open-EO/openeo.org",algolia:{appId:"3J2STFK847",apiKey:"b12d6cb143c2ddadfa8989c962d1a049",indexName:"openeo"},nav:[{text:"Home",link:"/"},{text:"About",link:"/about.html"},{text:"News",link:"/news/"},{text:"Software",link:"/software.html"},{text:"Services / Hub",link:"https://hub.openeo.org"},{text:"User Documentation",userNav:!0,items:[]},{text:"Developers",devNav:!0,items:[]},{text:"PSC",link:"/psc.html"},{text:"Contact",link:"/contact.html"}],sidebar:"auto"}},Lt=n(148),It=Lt.themeConfig.versions[Lt.themeConfig.defaultVersion];"undefined"!=typeof window&&(window.global=window);n(149);r.a.component("ApiSpec",()=>n.e(39).then(n.bind(null,479))),r.a.component("ErrorCodes",()=>n.e(19).then(n.bind(null,480))),r.a.component("Channels",()=>Promise.all([n.e(0),n.e(27)]).then(n.bind(null,481))),r.a.component("InlineFrame",()=>Promise.all([n.e(0),n.e(28)]).then(n.bind(null,482))),r.a.component("News",()=>n.e(40).then(n.bind(null,483))),r.a.component("ProcessesSpec",()=>Promise.all([n.e(0),n.e(26)]).then(n.bind(null,484))),r.a.component("Badge",()=>Promise.all([n.e(0),n.e(4)]).then(n.bind(null,490)));n(150),n(151);r.a.component("CodeSwitcher",()=>n.e(53).then(n.bind(null,485)));var Dt=[({router:e,Vue:t})=>{t.config.ignoredElements=["redoc"],e.addRoutes([{path:"/documentation",redirect:It.path},{path:"/about",redirect:"about.html"},{path:"/software",redirect:"software.html"},{path:"/contact",redirect:"contact.html"},{path:"/glossary",redirect:It.path+"glossary.html"},{path:"/documentation/1.0/developers/backends/opendatacube.html",redirect:"/documentation/1.0/developers/backends/xarray.html"}])},{},({Vue:e})=>{e.mixin({computed:{$dataBlock(){return this.$options.__data__block__}}})},{},{},{},{},{},({Vue:e})=>{e.component("CodeCopy",$t)}],Nt=[];class Ft extends class{constructor(){this.store=new r.a({data:{state:{}}})}$get(e){return this.store.state[e]}$set(e,t){r.a.set(this.store.state,e,t)}$emit(...e){this.store.$emit(...e)}$on(...e){this.store.$on(...e)}}{}Object.assign(Ft.prototype,{getPageAsyncComponent:lt,getLayoutAsyncComponent:ct,getAsyncComponent:ut,getVueComponent:pt});var Jt={install(e){const t=new Ft;e.$vuepress=t,e.prototype.$vuepress=t}};function Bt(e,t){const n=t.toLowerCase();return e.options.routes.some(e=>e.path.toLowerCase()===n)}var Vt={props:{pageKey:String,slotKey:{type:String,default:"default"}},render(e){const t=this.pageKey||this.$parent.$page.key;return ft("pageKey",t),r.a.component(t)||r.a.component(t,lt(t)),r.a.component(t)?e(t):e("")}},zt={functional:!0,props:{slotKey:String,required:!0},render:(e,{props:t,slots:n})=>e("div",{class:["content__"+t.slotKey]},n()[t.slotKey])},qt={computed:{openInNewWindowTitle(){return this.$themeLocaleConfig.openNewWindowText||"(opens new window)"}}},Gt=(n(152),n(153),Object(jt.a)(qt,(function(){var e=this._self._c;return e("span",[e("svg",{staticClass:"icon outbound",attrs:{xmlns:"http://www.w3.org/2000/svg","aria-hidden":"true",focusable:"false",x:"0px",y:"0px",viewBox:"0 0 100 100",width:"15",height:"15"}},[e("path",{attrs:{fill:"currentColor",d:"M18.8,85.1h56l0,0c2.2,0,4-1.8,4-4v-32h-8v28h-48v-48h28v-8h-32l0,0c-2.2,0-4,1.8-4,4v56C14.8,83.3,16.6,85.1,18.8,85.1z"}}),this._v(" "),e("polygon",{attrs:{fill:"currentColor",points:"45.7,48.7 51.3,54.3 77.2,28.5 77.2,37.2 85.2,37.2 85.2,14.9 62.8,14.9 62.8,22.9 71.5,22.9"}})]),this._v(" "),e("span",{staticClass:"sr-only"},[this._v(this._s(this.openInNewWindowTitle))])])}),[],!1,null,null,null).exports),Wt={functional:!0,render(e,{parent:t,children:n}){if(t._isMounted)return n;t.$once("hook:mounted",()=>{t.$forceUpdate()})}};r.a.config.productionTip=!1,r.a.use(Ge),r.a.use(Jt),r.a.mixin(function(e,t,n=r.a){!function(e){e.locales&&Object.keys(e.locales).forEach(t=>{e.locales[t].path=t});Object.freeze(e)}(t),n.$vuepress.$set("siteData",t);const o=new(e(n.$vuepress.$get("siteData"))),a=Object.getOwnPropertyDescriptors(Object.getPrototypeOf(o)),i={};return Object.keys(a).reduce((e,t)=>(t.startsWith("$")&&(e[t]=a[t].get),e),i),{computed:i}}(e=>class{setPage(e){this.__page=e}get $site(){return e}get $themeConfig(){return this.$site.themeConfig}get $frontmatter(){return this.$page.frontmatter}get $localeConfig(){const{locales:e={}}=this.$site;let t,n;for(const r in e)"/"===r?n=e[r]:0===this.$page.path.indexOf(r)&&(t=e[r]);return t||n||{}}get $siteTitle(){return this.$localeConfig.title||this.$site.title||""}get $canonicalUrl(){const{canonicalUrl:e}=this.$page.frontmatter;return"string"==typeof e&&e}get $title(){const e=this.$page,{metaTitle:t}=this.$page.frontmatter;if("string"==typeof t)return t;const n=this.$siteTitle,r=e.frontmatter.home?null:e.frontmatter.title||e.title;return n?r?r+" | "+n:n:r||"VuePress"}get $description(){const e=function(e){if(e){const t=e.filter(e=>"description"===e.name)[0];if(t)return t.content}}(this.$page.frontmatter.meta);return e||(this.$page.frontmatter.description||this.$localeConfig.description||this.$site.description||"")}get $lang(){return this.$page.frontmatter.lang||this.$localeConfig.lang||"en-US"}get $localePath(){return this.$localeConfig.path||"/"}get $themeLocaleConfig(){return(this.$site.themeConfig.locales||{})[this.$localePath]||{}}get $page(){return this.__page?this.__page:function(e,t){for(let n=0;nn||(e.hash?!r.a.$vuepress.$get("disableScrollBehavior")&&{selector:decodeURIComponent(e.hash)}:{x:0,y:0})});!function(e){e.beforeEach((t,n,r)=>{if(Bt(e,t.path))r();else if(/(\/|\.html)$/.test(t.path))if(/\/$/.test(t.path)){const n=t.path.replace(/\/$/,"")+".html";Bt(e,n)?r(n):r()}else r();else{const n=t.path+"/",o=t.path+".html";Bt(e,o)?r(o):Bt(e,n)?r(n):r()}})}(n);const o={};try{await Promise.all(Dt.filter(e=>"function"==typeof e).map(t=>t({Vue:r.a,options:o,router:n,siteData:Mt,isServer:e})))}catch(e){console.error(e)}return{app:new r.a(Object.assign(o,{router:n,render:e=>e("div",{attrs:{id:"app"}},[e("RouterView",{ref:"layout"}),e("div",{class:"global-ui"},Nt.map(t=>e(t)))])})),router:n}}(!1).then(({app:e,router:t})=>{t.onReady(()=>{e.$mount("#app")})})}]); \ No newline at end of file + */function o(e,t){for(var n in t)e[n]=t[n];return e}var a=/[!'()*]/g,i=function(e){return"%"+e.charCodeAt(0).toString(16)},s=/%2C/g,l=function(e){return encodeURIComponent(e).replace(a,i).replace(s,",")};function c(e){try{return decodeURIComponent(e)}catch(e){0}return e}var u=function(e){return null==e||"object"==typeof e?e:String(e)};function p(e){var t={};return(e=e.trim().replace(/^(\?|#|&)/,""))?(e.split("&").forEach((function(e){var n=e.replace(/\+/g," ").split("="),r=c(n.shift()),o=n.length>0?c(n.join("=")):null;void 0===t[r]?t[r]=o:Array.isArray(t[r])?t[r].push(o):t[r]=[t[r],o]})),t):t}function d(e){var t=e?Object.keys(e).map((function(t){var n=e[t];if(void 0===n)return"";if(null===n)return l(t);if(Array.isArray(n)){var r=[];return n.forEach((function(e){void 0!==e&&(null===e?r.push(l(t)):r.push(l(t)+"="+l(e)))})),r.join("&")}return l(t)+"="+l(n)})).filter((function(e){return e.length>0})).join("&"):null;return t?"?"+t:""}var f=/\/?$/;function h(e,t,n,r){var o=r&&r.options.stringifyQuery,a=t.query||{};try{a=v(a)}catch(e){}var i={name:t.name||e&&e.name,meta:e&&e.meta||{},path:t.path||"/",hash:t.hash||"",query:a,params:t.params||{},fullPath:y(t,o),matched:e?g(e):[]};return n&&(i.redirectedFrom=y(n,o)),Object.freeze(i)}function v(e){if(Array.isArray(e))return e.map(v);if(e&&"object"==typeof e){var t={};for(var n in e)t[n]=v(e[n]);return t}return e}var m=h(null,{path:"/"});function g(e){for(var t=[];e;)t.unshift(e),e=e.parent;return t}function y(e,t){var n=e.path,r=e.query;void 0===r&&(r={});var o=e.hash;return void 0===o&&(o=""),(n||"/")+(t||d)(r)+o}function b(e,t,n){return t===m?e===t:!!t&&(e.path&&t.path?e.path.replace(f,"")===t.path.replace(f,"")&&(n||e.hash===t.hash&&w(e.query,t.query)):!(!e.name||!t.name)&&(e.name===t.name&&(n||e.hash===t.hash&&w(e.query,t.query)&&w(e.params,t.params))))}function w(e,t){if(void 0===e&&(e={}),void 0===t&&(t={}),!e||!t)return e===t;var n=Object.keys(e).sort(),r=Object.keys(t).sort();return n.length===r.length&&n.every((function(n,o){var a=e[n];if(r[o]!==n)return!1;var i=t[n];return null==a||null==i?a===i:"object"==typeof a&&"object"==typeof i?w(a,i):String(a)===String(i)}))}function _(e){for(var t=0;t=0&&(t=e.slice(r),e=e.slice(0,r));var o=e.indexOf("?");return o>=0&&(n=e.slice(o+1),e=e.slice(0,o)),{path:e,query:n,hash:t}}(a.path||""),d=t&&t.path||"/",f=c.path?k(c.path,d,n||a.append):d,h=function(e,t,n){void 0===t&&(t={});var r,o=n||p;try{r=o(e||"")}catch(e){r={}}for(var a in t){var i=t[a];r[a]=Array.isArray(i)?i.map(u):u(i)}return r}(c.query,a.query,r&&r.options.parseQuery),v=a.hash||c.hash;return v&&"#"!==v.charAt(0)&&(v="#"+v),{_normalized:!0,path:f,query:h,hash:v}}var q,G=function(){},W={name:"RouterLink",props:{to:{type:[String,Object],required:!0},tag:{type:String,default:"a"},custom:Boolean,exact:Boolean,exactPath:Boolean,append:Boolean,replace:Boolean,activeClass:String,exactActiveClass:String,ariaCurrentValue:{type:String,default:"page"},event:{type:[String,Array],default:"click"}},render:function(e){var t=this,n=this.$router,r=this.$route,a=n.resolve(this.to,r,this.append),i=a.location,s=a.route,l=a.href,c={},u=n.options.linkActiveClass,p=n.options.linkExactActiveClass,d=null==u?"router-link-active":u,v=null==p?"router-link-exact-active":p,m=null==this.activeClass?d:this.activeClass,g=null==this.exactActiveClass?v:this.exactActiveClass,y=s.redirectedFrom?h(null,z(s.redirectedFrom),null,n):s;c[g]=b(r,y,this.exactPath),c[m]=this.exact||this.exactPath?c[g]:function(e,t){return 0===e.path.replace(f,"/").indexOf(t.path.replace(f,"/"))&&(!t.hash||e.hash===t.hash)&&function(e,t){for(var n in t)if(!(n in e))return!1;return!0}(e.query,t.query)}(r,y);var w=c[g]?this.ariaCurrentValue:null,_=function(e){H(e)&&(t.replace?n.replace(i,G):n.push(i,G))},x={click:H};Array.isArray(this.event)?this.event.forEach((function(e){x[e]=_})):x[this.event]=_;var P={class:c},k=!this.$scopedSlots.$hasNormal&&this.$scopedSlots.default&&this.$scopedSlots.default({href:l,route:s,navigate:_,isActive:c[m],isExactActive:c[g]});if(k){if(1===k.length)return k[0];if(k.length>1||!k.length)return 0===k.length?e():e("span",{},k)}if("a"===this.tag)P.on=x,P.attrs={href:l,"aria-current":w};else{var S=function e(t){var n;if(t)for(var r=0;r-1&&(s.params[d]=n.params[d]);return s.path=V(u.path,s.params),l(u,s,i)}if(s.path){s.params={};for(var f=0;f-1}function Se(e,t){return ke(e)&&e._isRouter&&(null==t||e.type===t)}function Oe(e,t,n){var r=function(o){o>=e.length?n():e[o]?t(e[o],(function(){r(o+1)})):r(o+1)};r(0)}function Ce(e){return function(t,n,r){var o=!1,a=0,i=null;Ee(e,(function(e,t,n,s){if("function"==typeof e&&void 0===e.cid){o=!0,a++;var l,c=Te((function(t){var o;((o=t).__esModule||$e&&"Module"===o[Symbol.toStringTag])&&(t=t.default),e.resolved="function"==typeof t?t:q.extend(t),n.components[s]=t,--a<=0&&r()})),u=Te((function(e){var t="Failed to resolve async component "+s+": "+e;i||(i=ke(e)?e:new Error(t),r(i))}));try{l=e(c,u)}catch(e){u(e)}if(l)if("function"==typeof l.then)l.then(c,u);else{var p=l.component;p&&"function"==typeof p.then&&p.then(c,u)}}})),o||r()}}function Ee(e,t){return je(e.map((function(e){return Object.keys(e.components).map((function(n){return t(e.components[n],e.instances[n],e,n)}))})))}function je(e){return Array.prototype.concat.apply([],e)}var $e="function"==typeof Symbol&&"symbol"==typeof Symbol.toStringTag;function Te(e){var t=!1;return function(){for(var n=[],r=arguments.length;r--;)n[r]=arguments[r];if(!t)return t=!0,e.apply(this,n)}}var Ae=function(e,t){this.router=e,this.base=function(e){if(!e)if(Z){var t=document.querySelector("base");e=(e=t&&t.getAttribute("href")||"/").replace(/^https?:\/\/[^\/]+/,"")}else e="/";"/"!==e.charAt(0)&&(e="/"+e);return e.replace(/\/$/,"")}(t),this.current=m,this.pending=null,this.ready=!1,this.readyCbs=[],this.readyErrorCbs=[],this.errorCbs=[],this.listeners=[]};function Re(e,t,n,r){var o=Ee(e,(function(e,r,o,a){var i=function(e,t){"function"!=typeof e&&(e=q.extend(e));return e.options[t]}(e,t);if(i)return Array.isArray(i)?i.map((function(e){return n(e,r,o,a)})):n(i,r,o,a)}));return je(r?o.reverse():o)}function Ue(e,t){if(t)return function(){return e.apply(t,arguments)}}Ae.prototype.listen=function(e){this.cb=e},Ae.prototype.onReady=function(e,t){this.ready?e():(this.readyCbs.push(e),t&&this.readyErrorCbs.push(t))},Ae.prototype.onError=function(e){this.errorCbs.push(e)},Ae.prototype.transitionTo=function(e,t,n){var r,o=this;try{r=this.router.match(e,this.current)}catch(e){throw this.errorCbs.forEach((function(t){t(e)})),e}var a=this.current;this.confirmTransition(r,(function(){o.updateRoute(r),t&&t(r),o.ensureURL(),o.router.afterHooks.forEach((function(e){e&&e(r,a)})),o.ready||(o.ready=!0,o.readyCbs.forEach((function(e){e(r)})))}),(function(e){n&&n(e),e&&!o.ready&&(Se(e,be.redirected)&&a===m||(o.ready=!0,o.readyErrorCbs.forEach((function(t){t(e)}))))}))},Ae.prototype.confirmTransition=function(e,t,n){var r=this,o=this.current;this.pending=e;var a,i,s=function(e){!Se(e)&&ke(e)&&(r.errorCbs.length?r.errorCbs.forEach((function(t){t(e)})):console.error(e)),n&&n(e)},l=e.matched.length-1,c=o.matched.length-1;if(b(e,o)&&l===c&&e.matched[l]===o.matched[c])return this.ensureURL(),e.hash&&se(this.router,o,e,!1),s(((i=xe(a=o,e,be.duplicated,'Avoided redundant navigation to current location: "'+a.fullPath+'".')).name="NavigationDuplicated",i));var u=function(e,t){var n,r=Math.max(e.length,t.length);for(n=0;n0)){var t=this.router,n=t.options.scrollBehavior,r=me&&n;r&&this.listeners.push(ie());var o=function(){var n=e.current,o=Le(e.base);e.current===m&&o===e._startLocation||e.transitionTo(o,(function(e){r&&se(t,e,n,!0)}))};window.addEventListener("popstate",o),this.listeners.push((function(){window.removeEventListener("popstate",o)}))}},t.prototype.go=function(e){window.history.go(e)},t.prototype.push=function(e,t,n){var r=this,o=this.current;this.transitionTo(e,(function(e){ge(S(r.base+e.fullPath)),se(r.router,e,o,!1),t&&t(e)}),n)},t.prototype.replace=function(e,t,n){var r=this,o=this.current;this.transitionTo(e,(function(e){ye(S(r.base+e.fullPath)),se(r.router,e,o,!1),t&&t(e)}),n)},t.prototype.ensureURL=function(e){if(Le(this.base)!==this.current.fullPath){var t=S(this.base+this.current.fullPath);e?ge(t):ye(t)}},t.prototype.getCurrentLocation=function(){return Le(this.base)},t}(Ae);function Le(e){var t=window.location.pathname,n=t.toLowerCase(),r=e.toLowerCase();return!e||n!==r&&0!==n.indexOf(S(r+"/"))||(t=t.slice(e.length)),(t||"/")+window.location.search+window.location.hash}var Ie=function(e){function t(t,n,r){e.call(this,t,n),r&&function(e){var t=Le(e);if(!/^\/#/.test(t))return window.location.replace(S(e+"/#"+t)),!0}(this.base)||De()}return e&&(t.__proto__=e),t.prototype=Object.create(e&&e.prototype),t.prototype.constructor=t,t.prototype.setupListeners=function(){var e=this;if(!(this.listeners.length>0)){var t=this.router.options.scrollBehavior,n=me&&t;n&&this.listeners.push(ie());var r=function(){var t=e.current;De()&&e.transitionTo(Ne(),(function(r){n&&se(e.router,r,t,!0),me||Be(r.fullPath)}))},o=me?"popstate":"hashchange";window.addEventListener(o,r),this.listeners.push((function(){window.removeEventListener(o,r)}))}},t.prototype.push=function(e,t,n){var r=this,o=this.current;this.transitionTo(e,(function(e){Je(e.fullPath),se(r.router,e,o,!1),t&&t(e)}),n)},t.prototype.replace=function(e,t,n){var r=this,o=this.current;this.transitionTo(e,(function(e){Be(e.fullPath),se(r.router,e,o,!1),t&&t(e)}),n)},t.prototype.go=function(e){window.history.go(e)},t.prototype.ensureURL=function(e){var t=this.current.fullPath;Ne()!==t&&(e?Je(t):Be(t))},t.prototype.getCurrentLocation=function(){return Ne()},t}(Ae);function De(){var e=Ne();return"/"===e.charAt(0)||(Be("/"+e),!1)}function Ne(){var e=window.location.href,t=e.indexOf("#");return t<0?"":e=e.slice(t+1)}function Fe(e){var t=window.location.href,n=t.indexOf("#");return(n>=0?t.slice(0,n):t)+"#"+e}function Je(e){me?ge(Fe(e)):window.location.hash=e}function Be(e){me?ye(Fe(e)):window.location.replace(Fe(e))}var Ve=function(e){function t(t,n){e.call(this,t,n),this.stack=[],this.index=-1}return e&&(t.__proto__=e),t.prototype=Object.create(e&&e.prototype),t.prototype.constructor=t,t.prototype.push=function(e,t,n){var r=this;this.transitionTo(e,(function(e){r.stack=r.stack.slice(0,r.index+1).concat(e),r.index++,t&&t(e)}),n)},t.prototype.replace=function(e,t,n){var r=this;this.transitionTo(e,(function(e){r.stack=r.stack.slice(0,r.index).concat(e),t&&t(e)}),n)},t.prototype.go=function(e){var t=this,n=this.index+e;if(!(n<0||n>=this.stack.length)){var r=this.stack[n];this.confirmTransition(r,(function(){var e=t.current;t.index=n,t.updateRoute(r),t.router.afterHooks.forEach((function(t){t&&t(r,e)}))}),(function(e){Se(e,be.duplicated)&&(t.index=n)}))}},t.prototype.getCurrentLocation=function(){var e=this.stack[this.stack.length-1];return e?e.fullPath:"/"},t.prototype.ensureURL=function(){},t}(Ae),ze=function(e){void 0===e&&(e={}),this.app=null,this.apps=[],this.options=e,this.beforeHooks=[],this.resolveHooks=[],this.afterHooks=[],this.matcher=Q(e.routes||[],this);var t=e.mode||"hash";switch(this.fallback="history"===t&&!me&&!1!==e.fallback,this.fallback&&(t="hash"),Z||(t="abstract"),this.mode=t,t){case"history":this.history=new Me(this,e.base);break;case"hash":this.history=new Ie(this,e.base,this.fallback);break;case"abstract":this.history=new Ve(this,e.base);break;default:0}},qe={currentRoute:{configurable:!0}};ze.prototype.match=function(e,t,n){return this.matcher.match(e,t,n)},qe.currentRoute.get=function(){return this.history&&this.history.current},ze.prototype.init=function(e){var t=this;if(this.apps.push(e),e.$once("hook:destroyed",(function(){var n=t.apps.indexOf(e);n>-1&&t.apps.splice(n,1),t.app===e&&(t.app=t.apps[0]||null),t.app||t.history.teardown()})),!this.app){this.app=e;var n=this.history;if(n instanceof Me||n instanceof Ie){var r=function(e){n.setupListeners(),function(e){var r=n.current,o=t.options.scrollBehavior;me&&o&&"fullPath"in e&&se(t,e,r,!1)}(e)};n.transitionTo(n.getCurrentLocation(),r,r)}n.listen((function(e){t.apps.forEach((function(t){t._route=e}))}))}},ze.prototype.beforeEach=function(e){return We(this.beforeHooks,e)},ze.prototype.beforeResolve=function(e){return We(this.resolveHooks,e)},ze.prototype.afterEach=function(e){return We(this.afterHooks,e)},ze.prototype.onReady=function(e,t){this.history.onReady(e,t)},ze.prototype.onError=function(e){this.history.onError(e)},ze.prototype.push=function(e,t,n){var r=this;if(!t&&!n&&"undefined"!=typeof Promise)return new Promise((function(t,n){r.history.push(e,t,n)}));this.history.push(e,t,n)},ze.prototype.replace=function(e,t,n){var r=this;if(!t&&!n&&"undefined"!=typeof Promise)return new Promise((function(t,n){r.history.replace(e,t,n)}));this.history.replace(e,t,n)},ze.prototype.go=function(e){this.history.go(e)},ze.prototype.back=function(){this.go(-1)},ze.prototype.forward=function(){this.go(1)},ze.prototype.getMatchedComponents=function(e){var t=e?e.matched?e:this.resolve(e).route:this.currentRoute;return t?[].concat.apply([],t.matched.map((function(e){return Object.keys(e.components).map((function(t){return e.components[t]}))}))):[]},ze.prototype.resolve=function(e,t,n){var r=z(e,t=t||this.history.current,n,this),o=this.match(r,t),a=o.redirectedFrom||o.fullPath;return{location:r,route:o,href:function(e,t,n){var r="hash"===n?"#"+t:t;return e?S(e+"/"+r):r}(this.history.base,a,this.mode),normalizedTo:r,resolved:o}},ze.prototype.getRoutes=function(){return this.matcher.getRoutes()},ze.prototype.addRoute=function(e,t){this.matcher.addRoute(e,t),this.history.current!==m&&this.history.transitionTo(this.history.getCurrentLocation())},ze.prototype.addRoutes=function(e){this.matcher.addRoutes(e),this.history.current!==m&&this.history.transitionTo(this.history.getCurrentLocation())},Object.defineProperties(ze.prototype,qe);var Ge=ze;function We(e,t){return e.push(t),function(){var n=e.indexOf(t);n>-1&&e.splice(n,1)}}ze.install=function e(t){if(!e.installed||q!==t){e.installed=!0,q=t;var n=function(e){return void 0!==e},r=function(e,t){var r=e.$options._parentVnode;n(r)&&n(r=r.data)&&n(r=r.registerRouteInstance)&&r(e,t)};t.mixin({beforeCreate:function(){n(this.$options.router)?(this._routerRoot=this,this._router=this.$options.router,this._router.init(this),t.util.defineReactive(this,"_route",this._router.history.current)):this._routerRoot=this.$parent&&this.$parent._routerRoot||this,r(this,this)},destroyed:function(){r(this)}}),Object.defineProperty(t.prototype,"$router",{get:function(){return this._routerRoot._router}}),Object.defineProperty(t.prototype,"$route",{get:function(){return this._routerRoot._route}}),t.component("RouterView",x),t.component("RouterLink",W);var o=t.config.optionMergeStrategies;o.beforeRouteEnter=o.beforeRouteLeave=o.beforeRouteUpdate=o.created}},ze.version="3.6.5",ze.isNavigationFailure=Se,ze.NavigationFailureType=be,ze.START_LOCATION=m,Z&&window.Vue&&window.Vue.use(ze);var He={"components/AlgoliaSearchBox":()=>Promise.all([n.e(0),n.e(29)]).then(n.bind(null,290)),"components/DropdownLink":()=>Promise.all([n.e(0),n.e(17)]).then(n.bind(null,180)),"components/DropdownTransition":()=>Promise.all([n.e(0),n.e(30)]).then(n.bind(null,160)),"components/Home":()=>Promise.all([n.e(0),n.e(23)]).then(n.bind(null,291)),"components/NavLink":()=>n.e(38).then(n.bind(null,159)),"components/NavLinks":()=>Promise.all([n.e(0),n.e(16)]).then(n.bind(null,200)),"components/Navbar":()=>Promise.all([n.e(0),n.e(1)]).then(n.bind(null,465)),"components/Page":()=>Promise.all([n.e(0),n.e(14)]).then(n.bind(null,292)),"components/PageEdit":()=>Promise.all([n.e(0),n.e(24)]).then(n.bind(null,205)),"components/PageNav":()=>Promise.all([n.e(0),n.e(21)]).then(n.bind(null,206)),"components/Sidebar":()=>Promise.all([n.e(0),n.e(12)]).then(n.bind(null,293)),"components/SidebarButton":()=>Promise.all([n.e(0),n.e(31)]).then(n.bind(null,296)),"components/SidebarGroup":()=>Promise.all([n.e(0),n.e(3)]).then(n.bind(null,201)),"components/SidebarLink":()=>Promise.all([n.e(0),n.e(25)]).then(n.bind(null,181)),"components/SidebarLinks":()=>Promise.all([n.e(0),n.e(3)]).then(n.bind(null,176)),"components/VersionChooser":()=>Promise.all([n.e(0),n.e(20)]).then(n.bind(null,294)),"components/VersioningMixin":()=>n.e(52).then(n.bind(null,164)),"global-components/Badge":()=>Promise.all([n.e(0),n.e(4)]).then(n.bind(null,490)),"layouts/404":()=>n.e(7).then(n.bind(null,477)),"layouts/Layout":()=>Promise.all([n.e(0),n.e(1),n.e(2)]).then(n.bind(null,478)),NotFound:()=>n.e(7).then(n.bind(null,477)),Layout:()=>Promise.all([n.e(0),n.e(1),n.e(2)]).then(n.bind(null,478))},Ze={"v-3ec20de4":()=>n.e(54).then(n.bind(null,491)),"v-31596d2d":()=>n.e(55).then(n.bind(null,492)),"v-26232766":()=>n.e(56).then(n.bind(null,493)),"v-4155eb1e":()=>n.e(58).then(n.bind(null,494)),"v-5e0de9fe":()=>n.e(59).then(n.bind(null,495)),"v-418e1b4d":()=>n.e(60).then(n.bind(null,496)),"v-5e94256a":()=>n.e(57).then(n.bind(null,497)),"v-63a2d53d":()=>n.e(61).then(n.bind(null,498)),"v-6bf62e0d":()=>n.e(41).then(n.bind(null,499)),"v-d80ea866":()=>n.e(62).then(n.bind(null,500)),"v-4899abd1":()=>n.e(63).then(n.bind(null,501)),"v-4081eb72":()=>n.e(64).then(n.bind(null,502)),"v-0059cb2a":()=>n.e(66).then(n.bind(null,503)),"v-5e5c94cd":()=>n.e(65).then(n.bind(null,504)),"v-25dd3de6":()=>n.e(67).then(n.bind(null,505)),"v-6993aee6":()=>n.e(68).then(n.bind(null,506)),"v-cfac61a6":()=>n.e(69).then(n.bind(null,507)),"v-3359623e":()=>n.e(42).then(n.bind(null,508)),"v-37dbaaa0":()=>n.e(71).then(n.bind(null,509)),"v-6aca4be5":()=>n.e(70).then(n.bind(null,510)),"v-7758ae27":()=>n.e(72).then(n.bind(null,511)),"v-9f635184":()=>n.e(18).then(n.bind(null,512)),"v-5fd8f1ad":()=>n.e(13).then(n.bind(null,513)),"v-f5de2fb4":()=>n.e(73).then(n.bind(null,514)),"v-43de507e":()=>n.e(74).then(n.bind(null,515)),"v-654015de":()=>n.e(75).then(n.bind(null,516)),"v-75018026":()=>n.e(43).then(n.bind(null,517)),"v-dc734f12":()=>n.e(77).then(n.bind(null,518)),"v-8d587926":()=>n.e(76).then(n.bind(null,519)),"v-1772ad2d":()=>n.e(78).then(n.bind(null,520)),"v-2840d4fe":()=>n.e(80).then(n.bind(null,521)),"v-253cefad":()=>n.e(79).then(n.bind(null,522)),"v-1b45967e":()=>n.e(81).then(n.bind(null,523)),"v-021062ed":()=>n.e(82).then(n.bind(null,524)),"v-97aa86e6":()=>n.e(44).then(n.bind(null,525)),"v-4af2bfca":()=>n.e(84).then(n.bind(null,526)),"v-1a823cb0":()=>n.e(46).then(n.bind(null,527)),"v-00153acd":()=>n.e(85).then(n.bind(null,528)),"v-9a2a2626":()=>n.e(86).then(n.bind(null,529)),"v-560d08d2":()=>n.e(47).then(n.bind(null,530)),"v-04d2236d":()=>n.e(45).then(n.bind(null,531)),"v-ef2073ec":()=>n.e(15).then(n.bind(null,532)),"v-ffc79ec2":()=>n.e(87).then(n.bind(null,533)),"v-c71b5aa6":()=>n.e(88).then(n.bind(null,534)),"v-592eaa86":()=>n.e(48).then(n.bind(null,535)),"v-1005bb66":()=>n.e(89).then(n.bind(null,536)),"v-e35c5e24":()=>n.e(83).then(n.bind(null,537)),"v-186cd6ed":()=>n.e(90).then(n.bind(null,538)),"v-0ee3f026":()=>n.e(91).then(n.bind(null,539)),"v-2997b752":()=>n.e(92).then(n.bind(null,540)),"v-24966ce6":()=>n.e(49).then(n.bind(null,541)),"v-f9778ae6":()=>n.e(94).then(n.bind(null,542)),"v-4fe4e126":()=>n.e(93).then(n.bind(null,543)),"v-45d803ab":()=>n.e(50).then(n.bind(null,544)),"v-d2a018a6":()=>n.e(95).then(n.bind(null,545)),"v-9ddae032":()=>n.e(96).then(n.bind(null,546)),"v-2fcee9ad":()=>n.e(98).then(n.bind(null,547)),"v-3f85032d":()=>n.e(97).then(n.bind(null,548)),"v-525dec3e":()=>n.e(99).then(n.bind(null,549)),"v-0e5e57cd":()=>n.e(100).then(n.bind(null,550)),"v-6e6b7e2d":()=>n.e(101).then(n.bind(null,551)),"v-06e0a8ca":()=>n.e(102).then(n.bind(null,552)),"v-1227575e":()=>n.e(103).then(n.bind(null,553)),"v-59d340ad":()=>n.e(51).then(n.bind(null,554)),"v-00d62ee6":()=>n.e(104).then(n.bind(null,555)),"v-221bfb8d":()=>n.e(105).then(n.bind(null,556)),"v-3eeef04a":()=>n.e(106).then(n.bind(null,557)),"v-857a96a6":()=>n.e(107).then(n.bind(null,558)),"v-10d9ffb7":()=>n.e(108).then(n.bind(null,559)),"v-8850e2c4":()=>n.e(110).then(n.bind(null,560)),"v-d5007282":()=>n.e(109).then(n.bind(null,561)),"v-64c18f4d":()=>n.e(111).then(n.bind(null,562)),"v-9adb302a":()=>n.e(112).then(n.bind(null,563))};function Ke(e){const t=Object.create(null);return function(n){return t[n]||(t[n]=e(n))}}const Xe=/-(\w)/g,Qe=Ke(e=>e.replace(Xe,(e,t)=>t?t.toUpperCase():"")),Ye=/\B([A-Z])/g,et=Ke(e=>e.replace(Ye,"-$1").toLowerCase()),tt=Ke(e=>e.charAt(0).toUpperCase()+e.slice(1));function nt(e,t){if(!t)return;if(e(t))return e(t);return t.includes("-")?e(tt(Qe(t))):e(tt(t))||e(et(t))}const rt=Object.assign({},He,Ze),ot=e=>rt[e],at=e=>Ze[e],it=e=>He[e],st=e=>r.a.component(e);function lt(e){return nt(at,e)}function ct(e){return nt(it,e)}function ut(e){return nt(ot,e)}function pt(e){return nt(st,e)}function dt(...e){return Promise.all(e.filter(e=>e).map(async e=>{if(!pt(e)&&ut(e)){const t=await ut(e)();r.a.component(e,t.default)}}))}function ft(e,t){"undefined"!=typeof window&&window.__VUEPRESS__&&(window.__VUEPRESS__[e]=t)}var ht=n(47),vt=n.n(ht),mt=n(48),gt=n.n(mt),yt={created(){if(this.siteMeta=this.$site.headTags.filter(([e])=>"meta"===e).map(([e,t])=>t),this.$ssrContext){const t=this.getMergedMetaTags();this.$ssrContext.title=this.$title,this.$ssrContext.lang=this.$lang,this.$ssrContext.pageMeta=(e=t)?e.map(e=>{let t="{t+=` ${n}="${gt()(e[n])}"`}),t+">"}).join("\n "):"",this.$ssrContext.canonicalLink=wt(this.$canonicalUrl)}var e},mounted(){this.currentMetaTags=[...document.querySelectorAll("meta")],this.updateMeta(),this.updateCanonicalLink()},methods:{updateMeta(){document.title=this.$title,document.documentElement.lang=this.$lang;const e=this.getMergedMetaTags();this.currentMetaTags=_t(e,this.currentMetaTags)},getMergedMetaTags(){const e=this.$page.frontmatter.meta||[];return vt()([{name:"description",content:this.$description}],e,this.siteMeta,xt)},updateCanonicalLink(){bt(),this.$canonicalUrl&&document.head.insertAdjacentHTML("beforeend",wt(this.$canonicalUrl))}},watch:{$page(){this.updateMeta(),this.updateCanonicalLink()}},beforeDestroy(){_t(null,this.currentMetaTags),bt()}};function bt(){const e=document.querySelector("link[rel='canonical']");e&&e.remove()}function wt(e=""){return e?``:""}function _t(e,t){if(t&&[...t].filter(e=>e.parentNode===document.head).forEach(e=>document.head.removeChild(e)),e)return e.map(e=>{const t=document.createElement("meta");return Object.keys(e).forEach(n=>{t.setAttribute(n,e[n])}),document.head.appendChild(t),t})}function xt(e){for(const t of["name","property","itemprop"])if(e.hasOwnProperty(t))return e[t]+t;return JSON.stringify(e)}var Pt=n(13),kt=n.n(Pt),St={mounted(){kt.a.configure({showSpinner:!1}),this.$router.beforeEach((e,t,n)=>{e.path===t.path||r.a.component(e.name)||kt.a.start(),n()}),this.$router.afterEach(()=>{kt.a.done(),this.isSidebarOpen=!1})}},Ot=n(49),Ct={mounted(){window.addEventListener("scroll",this.onScroll)},methods:{onScroll:n.n(Ot)()((function(){this.setActiveHash()}),300),setActiveHash(){const e=[].slice.call(document.querySelectorAll(".sidebar-link")),t=[].slice.call(document.querySelectorAll(".header-anchor")).filter(t=>e.some(e=>e.hash===t.hash)),n=Math.max(window.pageYOffset,document.documentElement.scrollTop,document.body.scrollTop),r=Math.max(document.documentElement.scrollHeight,document.body.scrollHeight),o=window.innerHeight+n;for(let e=0;e=a.parentElement.offsetTop+10&&(!i||n{this.$nextTick(()=>{this.$vuepress.$set("disableScrollBehavior",!1)})})}}}},beforeDestroy(){window.removeEventListener("scroll",this.onScroll)}},Et={props:{parent:Object,code:String,options:{align:String,color:String,backgroundTransition:Boolean,backgroundColor:String,successText:String,staticIcon:Boolean}},data:()=>({success:!1,originalBackground:null,originalTransition:null}),computed:{alignStyle(){let e={};return e[this.options.align]="7.5px",e},iconClass(){return this.options.staticIcon?"":"hover"}},mounted(){this.originalTransition=this.parent.style.transition,this.originalBackground=this.parent.style.background},beforeDestroy(){this.parent.style.transition=this.originalTransition,this.parent.style.background=this.originalBackground},methods:{hexToRgb(e){let t=/^#?([a-f\d]{2})([a-f\d]{2})([a-f\d]{2})$/i.exec(e);return t?{r:parseInt(t[1],16),g:parseInt(t[2],16),b:parseInt(t[3],16)}:null},copyToClipboard(e){if(navigator.clipboard)navigator.clipboard.writeText(this.code).then(()=>{this.setSuccessTransitions()},()=>{});else{let e=document.createElement("textarea");document.body.appendChild(e),e.value=this.code,e.select(),document.execCommand("Copy"),e.remove(),this.setSuccessTransitions()}},setSuccessTransitions(){if(clearTimeout(this.successTimeout),this.options.backgroundTransition){this.parent.style.transition="background 350ms";let e=this.hexToRgb(this.options.backgroundColor);this.parent.style.background=`rgba(${e.r}, ${e.g}, ${e.b}, 0.1)`}this.success=!0,this.successTimeout=setTimeout(()=>{this.options.backgroundTransition&&(this.parent.style.background=this.originalBackground,this.parent.style.transition=this.originalTransition),this.success=!1},500)}}},jt=(n(146),n(4)),$t=Object(jt.a)(Et,(function(){var e=this,t=e._self._c;return t("div",{staticClass:"code-copy"},[t("svg",{class:e.iconClass,style:e.alignStyle,attrs:{xmlns:"http://www.w3.org/2000/svg",width:"24",height:"24",viewBox:"0 0 24 24"},on:{click:e.copyToClipboard}},[t("path",{attrs:{fill:"none",d:"M0 0h24v24H0z"}}),e._v(" "),t("path",{attrs:{fill:e.options.color,d:"M16 1H4c-1.1 0-2 .9-2 2v14h2V3h12V1zm-1 4l6 6v10c0 1.1-.9 2-2 2H7.99C6.89 23 6 22.1 6 21l.01-14c0-1.1.89-2 1.99-2h7zm-1 7h5.5L14 6.5V12z"}})]),e._v(" "),t("span",{class:e.success?"success":"",style:e.alignStyle},[e._v("\n "+e._s(e.options.successText)+"\n ")])])}),[],!1,null,"49140617",null).exports,Tt=(n(147),[yt,St,Ct,{updated(){this.update()},methods:{update(){setTimeout(()=>{document.querySelectorAll('div[class*="language-"] pre').forEach(e=>{if(e.classList.contains("code-copy-added"))return;let t=new(r.a.extend($t));t.options={align:"bottom",color:"#27b1ff",backgroundTransition:!0,backgroundColor:"#0075b8",successText:"Copied!",staticIcon:!1},t.code=e.innerText,t.parent=e,t.$mount(),e.classList.add("code-copy-added"),e.appendChild(t.$el)})},100)}}}]),At={name:"GlobalLayout",computed:{layout(){const e=this.getLayout();return ft("layout",e),r.a.component(e)}},methods:{getLayout(){if(this.$page.path){const e=this.$page.frontmatter.layout;return e&&(this.$vuepress.getLayoutAsyncComponent(e)||this.$vuepress.getVueComponent(e))?e:"Layout"}return"NotFound"}}},Rt=Object(jt.a)(At,(function(){return(0,this._self._c)(this.layout,{tag:"component"})}),[],!1,null,null,null).exports;!function(e,t,n){switch(t){case"components":e[t]||(e[t]={}),Object.assign(e[t],n);break;case"mixins":e[t]||(e[t]=[]),e[t].push(...n);break;default:throw new Error("Unknown option name.")}}(Rt,"mixins",Tt);const Ut=[{name:"v-3ec20de4",path:"/",component:Rt,beforeEnter:(e,t,n)=>{dt("Layout","v-3ec20de4").then(n)}},{path:"/index.html",redirect:"/"},{name:"v-31596d2d",path:"/about.html",component:Rt,beforeEnter:(e,t,n)=>{dt("Layout","v-31596d2d").then(n)}},{name:"v-26232766",path:"/contact.html",component:Rt,beforeEnter:(e,t,n)=>{dt("Layout","v-26232766").then(n)}},{name:"v-4155eb1e",path:"/documentation/0.4/developers/",component:Rt,beforeEnter:(e,t,n)=>{dt("Layout","v-4155eb1e").then(n)}},{path:"/documentation/0.4/developers/index.html",redirect:"/documentation/0.4/developers/"},{name:"v-5e0de9fe",path:"/documentation/0.4/developers/api/",component:Rt,beforeEnter:(e,t,n)=>{dt("Layout","v-5e0de9fe").then(n)}},{path:"/documentation/0.4/developers/api/index.html",redirect:"/documentation/0.4/developers/api/"},{name:"v-418e1b4d",path:"/documentation/0.4/developers/api/errors.html",component:Rt,beforeEnter:(e,t,n)=>{dt("Layout","v-418e1b4d").then(n)}},{name:"v-5e94256a",path:"/documentation/0.4/",component:Rt,beforeEnter:(e,t,n)=>{dt("Layout","v-5e94256a").then(n)}},{path:"/documentation/0.4/index.html",redirect:"/documentation/0.4/"},{name:"v-63a2d53d",path:"/documentation/0.4/developers/api/reference.html",component:Rt,beforeEnter:(e,t,n)=>{dt("Layout","v-63a2d53d").then(n)}},{name:"v-6bf62e0d",path:"/documentation/0.4/developers/arch.html",component:Rt,beforeEnter:(e,t,n)=>{dt("Layout","v-6bf62e0d").then(n)}},{name:"v-d80ea866",path:"/documentation/0.4/developers/backends/getting-started.html",component:Rt,beforeEnter:(e,t,n)=>{dt("Layout","v-d80ea866").then(n)}},{name:"v-4899abd1",path:"/documentation/0.4/developers/backends/udfs.html",component:Rt,beforeEnter:(e,t,n)=>{dt("Layout","v-4899abd1").then(n)}},{name:"v-4081eb72",path:"/documentation/0.4/developers/clients/getting-started.html",component:Rt,beforeEnter:(e,t,n)=>{dt("Layout","v-4081eb72").then(n)}},{name:"v-0059cb2a",path:"/documentation/0.4/developers/examples/",component:Rt,beforeEnter:(e,t,n)=>{dt("Layout","v-0059cb2a").then(n)}},{path:"/documentation/0.4/developers/examples/index.html",redirect:"/documentation/0.4/developers/examples/"},{name:"v-5e5c94cd",path:"/documentation/0.4/developers/clients/library-guidelines.html",component:Rt,beforeEnter:(e,t,n)=>{dt("Layout","v-5e5c94cd").then(n)}},{name:"v-25dd3de6",path:"/documentation/0.4/developers/examples/poc.html",component:Rt,beforeEnter:(e,t,n)=>{dt("Layout","v-25dd3de6").then(n)}},{name:"v-6993aee6",path:"/documentation/0.4/getting-started.html",component:Rt,beforeEnter:(e,t,n)=>{dt("Layout","v-6993aee6").then(n)}},{name:"v-cfac61a6",path:"/documentation/0.4/processes.html",component:Rt,beforeEnter:(e,t,n)=>{dt("Layout","v-cfac61a6").then(n)}},{name:"v-3359623e",path:"/documentation/0.4/glossary.html",component:Rt,beforeEnter:(e,t,n)=>{dt("Layout","v-3359623e").then(n)}},{name:"v-37dbaaa0",path:"/documentation/1.0/",component:Rt,beforeEnter:(e,t,n)=>{dt("Layout","v-37dbaaa0").then(n)}},{path:"/documentation/1.0/index.html",redirect:"/documentation/1.0/"},{name:"v-6aca4be5",path:"/documentation/0.4/udfs.html",component:Rt,beforeEnter:(e,t,n)=>{dt("Layout","v-6aca4be5").then(n)}},{name:"v-7758ae27",path:"/documentation/1.0/authentication.html",component:Rt,beforeEnter:(e,t,n)=>{dt("Layout","v-7758ae27").then(n)}},{name:"v-9f635184",path:"/documentation/1.0/cookbook/",component:Rt,beforeEnter:(e,t,n)=>{dt("Layout","v-9f635184").then(n)}},{path:"/documentation/1.0/cookbook/index.html",redirect:"/documentation/1.0/cookbook/"},{name:"v-5fd8f1ad",path:"/documentation/1.0/datacubes.html",component:Rt,beforeEnter:(e,t,n)=>{dt("Layout","v-5fd8f1ad").then(n)}},{name:"v-f5de2fb4",path:"/documentation/1.0/datacubes/",component:Rt,beforeEnter:(e,t,n)=>{dt("Layout","v-f5de2fb4").then(n)}},{path:"/documentation/1.0/datacubes/index.html",redirect:"/documentation/1.0/datacubes/"},{name:"v-43de507e",path:"/documentation/1.0/developers/",component:Rt,beforeEnter:(e,t,n)=>{dt("Layout","v-43de507e").then(n)}},{path:"/documentation/1.0/developers/index.html",redirect:"/documentation/1.0/developers/"},{name:"v-654015de",path:"/documentation/1.0/developers/api/",component:Rt,beforeEnter:(e,t,n)=>{dt("Layout","v-654015de").then(n)}},{path:"/documentation/1.0/developers/api/index.html",redirect:"/documentation/1.0/developers/api/"},{name:"v-75018026",path:"/documentation/1.0/developers/arch.html",component:Rt,beforeEnter:(e,t,n)=>{dt("Layout","v-75018026").then(n)}},{name:"v-dc734f12",path:"/documentation/1.0/developers/api/reference.html",component:Rt,beforeEnter:(e,t,n)=>{dt("Layout","v-dc734f12").then(n)}},{name:"v-8d587926",path:"/documentation/1.0/developers/api/errors.html",component:Rt,beforeEnter:(e,t,n)=>{dt("Layout","v-8d587926").then(n)}},{name:"v-1772ad2d",path:"/documentation/1.0/developers/backends/getting-started.html",component:Rt,beforeEnter:(e,t,n)=>{dt("Layout","v-1772ad2d").then(n)}},{name:"v-2840d4fe",path:"/documentation/1.0/developers/backends/xarray.html",component:Rt,beforeEnter:(e,t,n)=>{dt("Layout","v-2840d4fe").then(n)}},{name:"v-253cefad",path:"/documentation/1.0/developers/backends/performance.html",component:Rt,beforeEnter:(e,t,n)=>{dt("Layout","v-253cefad").then(n)}},{name:"v-1b45967e",path:"/documentation/1.0/developers/clients/getting-started.html",component:Rt,beforeEnter:(e,t,n)=>{dt("Layout","v-1b45967e").then(n)}},{name:"v-021062ed",path:"/documentation/1.0/developers/clients/library-guidelines.html",component:Rt,beforeEnter:(e,t,n)=>{dt("Layout","v-021062ed").then(n)}},{name:"v-97aa86e6",path:"/documentation/1.0/developers/profiles/api.html",component:Rt,beforeEnter:(e,t,n)=>{dt("Layout","v-97aa86e6").then(n)}},{name:"v-4af2bfca",path:"/documentation/1.0/glossary.html",component:Rt,beforeEnter:(e,t,n)=>{dt("Layout","v-4af2bfca").then(n)}},{name:"v-1a823cb0",path:"/documentation/1.0/javascript/",component:Rt,beforeEnter:(e,t,n)=>{dt("Layout","v-1a823cb0").then(n)}},{path:"/documentation/1.0/javascript/index.html",redirect:"/documentation/1.0/javascript/"},{name:"v-00153acd",path:"/documentation/1.0/processes.html",component:Rt,beforeEnter:(e,t,n)=>{dt("Layout","v-00153acd").then(n)}},{name:"v-9a2a2626",path:"/documentation/1.0/python/client-side-processing.html",component:Rt,beforeEnter:(e,t,n)=>{dt("Layout","v-9a2a2626").then(n)}},{name:"v-560d08d2",path:"/documentation/1.0/python/",component:Rt,beforeEnter:(e,t,n)=>{dt("Layout","v-560d08d2").then(n)}},{path:"/documentation/1.0/python/index.html",redirect:"/documentation/1.0/python/"},{name:"v-04d2236d",path:"/documentation/1.0/developers/profiles/processes.html",component:Rt,beforeEnter:(e,t,n)=>{dt("Layout","v-04d2236d").then(n)}},{name:"v-ef2073ec",path:"/documentation/1.0/qgis/",component:Rt,beforeEnter:(e,t,n)=>{dt("Layout","v-ef2073ec").then(n)}},{path:"/documentation/1.0/qgis/index.html",redirect:"/documentation/1.0/qgis/"},{name:"v-ffc79ec2",path:"/documentation/1.0/udfs.html",component:Rt,beforeEnter:(e,t,n)=>{dt("Layout","v-ffc79ec2").then(n)}},{name:"v-c71b5aa6",path:"/documentation/code-of-conduct.html",component:Rt,beforeEnter:(e,t,n)=>{dt("Layout","v-c71b5aa6").then(n)}},{name:"v-592eaa86",path:"/documentation/1.0/r/",component:Rt,beforeEnter:(e,t,n)=>{dt("Layout","v-592eaa86").then(n)}},{path:"/documentation/1.0/r/index.html",redirect:"/documentation/1.0/r/"},{name:"v-1005bb66",path:"/documentation/software-guidelines.html",component:Rt,beforeEnter:(e,t,n)=>{dt("Layout","v-1005bb66").then(n)}},{name:"v-e35c5e24",path:"/documentation/1.0/developers/profiles/",component:Rt,beforeEnter:(e,t,n)=>{dt("Layout","v-e35c5e24").then(n)}},{path:"/documentation/1.0/developers/profiles/index.html",redirect:"/documentation/1.0/developers/profiles/"},{name:"v-186cd6ed",path:"/events/igarrs2021.html",component:Rt,beforeEnter:(e,t,n)=>{dt("Layout","v-186cd6ed").then(n)}},{name:"v-0ee3f026",path:"/news/2017-12-05-welcome.html",component:Rt,beforeEnter:(e,t,n)=>{dt("Layout","v-0ee3f026").then(n)}},{name:"v-2997b752",path:"/news/2017-12-18-VITO_meeting.html",component:Rt,beforeEnter:(e,t,n)=>{dt("Layout","v-2997b752").then(n)}},{name:"v-24966ce6",path:"/news/2018-01-31-WWU_meeting.html",component:Rt,beforeEnter:(e,t,n)=>{dt("Layout","v-24966ce6").then(n)}},{name:"v-f9778ae6",path:"/news/2018-05-23-user-requirements-survey-launched.html",component:Rt,beforeEnter:(e,t,n)=>{dt("Layout","v-f9778ae6").then(n)}},{name:"v-4fe4e126",path:"/news/2018-03-15-poc.html",component:Rt,beforeEnter:(e,t,n)=>{dt("Layout","v-4fe4e126").then(n)}},{name:"v-45d803ab",path:"/news/2019-03-07-openeo-api-040.html",component:Rt,beforeEnter:(e,t,n)=>{dt("Layout","v-45d803ab").then(n)}},{name:"v-d2a018a6",path:"/news/2018-10-30-year-one-review-meeting.html",component:Rt,beforeEnter:(e,t,n)=>{dt("Layout","v-d2a018a6").then(n)}},{name:"v-9ddae032",path:"/news/2019-10-07-EO-big-data-hackaton.html",component:Rt,beforeEnter:(e,t,n)=>{dt("Layout","v-9ddae032").then(n)}},{name:"v-2fcee9ad",path:"/news/2020-07-31-openeo-api-released.html",component:Rt,beforeEnter:(e,t,n)=>{dt("Layout","v-2fcee9ad").then(n)}},{name:"v-3f85032d",path:"/news/2020-07-31-lessons-learned.html",component:Rt,beforeEnter:(e,t,n)=>{dt("Layout","v-3f85032d").then(n)}},{name:"v-525dec3e",path:"/news/2020-09-02-openeo-user-workshop.html",component:Rt,beforeEnter:(e,t,n)=>{dt("Layout","v-525dec3e").then(n)}},{name:"v-0e5e57cd",path:"/news/2020-11-30-openeo-api-101-released.html",component:Rt,beforeEnter:(e,t,n)=>{dt("Layout","v-0e5e57cd").then(n)}},{name:"v-6e6b7e2d",path:"/news/2021-05-17-openeo-api-110-released.html",component:Rt,beforeEnter:(e,t,n)=>{dt("Layout","v-6e6b7e2d").then(n)}},{name:"v-06e0a8ca",path:"/news/2021-11-08-r-client-on-cran.html",component:Rt,beforeEnter:(e,t,n)=>{dt("Layout","v-06e0a8ca").then(n)}},{name:"v-1227575e",path:"/news/2022-04-08-psc-meetings.html",component:Rt,beforeEnter:(e,t,n)=>{dt("Layout","v-1227575e").then(n)}},{name:"v-59d340ad",path:"/news/2022-05-12-r-client-v120.html",component:Rt,beforeEnter:(e,t,n)=>{dt("Layout","v-59d340ad").then(n)}},{name:"v-00d62ee6",path:"/news/2022-07-07-monthly-dev-calls.html",component:Rt,beforeEnter:(e,t,n)=>{dt("Layout","v-00d62ee6").then(n)}},{name:"v-221bfb8d",path:"/news/2022-11-17-r-client-v130.html",component:Rt,beforeEnter:(e,t,n)=>{dt("Layout","v-221bfb8d").then(n)}},{name:"v-3eeef04a",path:"/news/2023-05-25-new-openeo-versions-120-200rc1%20copy.html",component:Rt,beforeEnter:(e,t,n)=>{dt("Layout","v-3eeef04a").then(n)}},{path:"/news/2023-05-25-new-openeo-versions-120-200rc1 copy.html",redirect:"/news/2023-05-25-new-openeo-versions-120-200rc1%20copy.html"},{path:"/news/2023-05-25-new-openeo-versions-120-200rc1 copy.html",redirect:"/news/2023-05-25-new-openeo-versions-120-200rc1%20copy.html"},{name:"v-857a96a6",path:"/news/2023-12-06-openeo-submitted-to-ogc.html",component:Rt,beforeEnter:(e,t,n)=>{dt("Layout","v-857a96a6").then(n)}},{name:"v-10d9ffb7",path:"/news/2024-02-06-openeo-ogc-rfc.html",component:Rt,beforeEnter:(e,t,n)=>{dt("Layout","v-10d9ffb7").then(n)}},{name:"v-8850e2c4",path:"/news/",component:Rt,beforeEnter:(e,t,n)=>{dt("Layout","v-8850e2c4").then(n)}},{path:"/news/index.html",redirect:"/news/"},{name:"v-d5007282",path:"/news/2024-03-22_mooc_cubeandclouds.html",component:Rt,beforeEnter:(e,t,n)=>{dt("Layout","v-d5007282").then(n)}},{name:"v-64c18f4d",path:"/psc.html",component:Rt,beforeEnter:(e,t,n)=>{dt("Layout","v-64c18f4d").then(n)}},{name:"v-9adb302a",path:"/software.html",component:Rt,beforeEnter:(e,t,n)=>{dt("Layout","v-9adb302a").then(n)}},{path:"*",component:Rt}],Mt={title:"openEO",description:"openEO develops an open API to connect various clients to big EO cloud back-ends in a simple and unified way.",base:"/",headTags:[],pages:[{title:"Home",frontmatter:{home:!0},regularPath:"/",relativePath:"README.md",key:"v-3ec20de4",path:"/",lastUpdated:"7/26/2024, 6:48:28 PM",lastUpdatedTimestamp:1722019708e3,codeSwitcherOptions:{groups:{default:{py:"Python",r:"R",js:"JavaScript"}}}},{title:"About",frontmatter:{},regularPath:"/about.html",relativePath:"about.md",key:"v-31596d2d",path:"/about.html",headers:[{level:2,title:"openEO?",slug:"openeo"},{level:2,title:"Why an API?",slug:"why-an-api"},{level:2,title:"More information",slug:"more-information"}],lastUpdated:"7/26/2024, 6:48:28 PM",lastUpdatedTimestamp:1722019708e3,codeSwitcherOptions:{groups:{default:{py:"Python",r:"R",js:"JavaScript"}}}},{title:"Contact",frontmatter:{sidebar:!1},regularPath:"/contact.html",relativePath:"contact.md",key:"v-26232766",path:"/contact.html",lastUpdated:"7/26/2024, 6:48:28 PM",lastUpdatedTimestamp:1722019708e3,codeSwitcherOptions:{groups:{default:{py:"Python",r:"R",js:"JavaScript"}}}},{title:"Introduction",frontmatter:{},regularPath:"/documentation/0.4/developers/",relativePath:"documentation/0.4/developers/README.md",key:"v-4155eb1e",path:"/documentation/0.4/developers/",headers:[{level:2,title:"Additional information",slug:"additional-information"}],lastUpdated:"7/26/2024, 6:48:28 PM",lastUpdatedTimestamp:1722019708e3,codeSwitcherOptions:{groups:{default:{py:"Python",r:"R",js:"JavaScript"}}}},{frontmatter:{iframe:"https://api.openeo.org/v/0.4.2/"},regularPath:"/documentation/0.4/developers/api/",relativePath:"documentation/0.4/developers/api/README.md",key:"v-5e0de9fe",path:"/documentation/0.4/developers/api/",lastUpdated:"7/26/2024, 6:48:28 PM",lastUpdatedTimestamp:1722019708e3,codeSwitcherOptions:{groups:{default:{py:"Python",r:"R",js:"JavaScript"}}}},{title:"Status and error handling",frontmatter:{},regularPath:"/documentation/0.4/developers/api/errors.html",relativePath:"documentation/0.4/developers/api/errors.md",key:"v-418e1b4d",path:"/documentation/0.4/developers/api/errors.html",headers:[{level:2,title:"JSON error object",slug:"json-error-object"},{level:2,title:"Standardized status codes",slug:"standardized-status-codes"},{level:2,title:"openEO error codes",slug:"openeo-error-codes"}],lastUpdated:"7/26/2024, 6:48:28 PM",lastUpdatedTimestamp:1722019708e3,codeSwitcherOptions:{groups:{default:{py:"Python",r:"R",js:"JavaScript"}}}},{title:"openEO Documentation",frontmatter:{},regularPath:"/documentation/0.4/",relativePath:"documentation/0.4/README.md",key:"v-5e94256a",path:"/documentation/0.4/",lastUpdated:"7/26/2024, 6:48:28 PM",lastUpdatedTimestamp:1722019708e3,codeSwitcherOptions:{groups:{default:{py:"Python",r:"R",js:"JavaScript"}}}},{frontmatter:{fullpage:!0,stripCSS:!0},regularPath:"/documentation/0.4/developers/api/reference.html",relativePath:"documentation/0.4/developers/api/reference.md",key:"v-63a2d53d",path:"/documentation/0.4/developers/api/reference.html",lastUpdated:"7/26/2024, 6:48:28 PM",lastUpdatedTimestamp:1722019708e3,codeSwitcherOptions:{groups:{default:{py:"Python",r:"R",js:"JavaScript"}}}},{title:"Architecture",frontmatter:{},regularPath:"/documentation/0.4/developers/arch.html",relativePath:"documentation/0.4/developers/arch.md",key:"v-6bf62e0d",path:"/documentation/0.4/developers/arch.html",lastUpdated:"7/26/2024, 6:48:28 PM",lastUpdatedTimestamp:1722019708e3,codeSwitcherOptions:{groups:{default:{py:"Python",r:"R",js:"JavaScript"}}}},{title:"Getting started for back-end providers",frontmatter:{},regularPath:"/documentation/0.4/developers/backends/getting-started.html",relativePath:"documentation/0.4/developers/backends/getting-started.md",key:"v-d80ea866",path:"/documentation/0.4/developers/backends/getting-started.html",lastUpdated:"7/26/2024, 6:48:28 PM",lastUpdatedTimestamp:1722019708e3,codeSwitcherOptions:{groups:{default:{py:"Python",r:"R",js:"JavaScript"}}}},{title:"User-defined functions",frontmatter:{},regularPath:"/documentation/0.4/developers/backends/udfs.html",relativePath:"documentation/0.4/developers/backends/udfs.md",key:"v-4899abd1",path:"/documentation/0.4/developers/backends/udfs.html",lastUpdated:"7/26/2024, 6:48:28 PM",lastUpdatedTimestamp:1722019708e3,codeSwitcherOptions:{groups:{default:{py:"Python",r:"R",js:"JavaScript"}}}},{title:"Getting started for client developers",frontmatter:{},regularPath:"/documentation/0.4/developers/clients/getting-started.html",relativePath:"documentation/0.4/developers/clients/getting-started.md",key:"v-4081eb72",path:"/documentation/0.4/developers/clients/getting-started.html",headers:[{level:2,title:"Client library developers",slug:"client-library-developers"},{level:2,title:"Applications and Software plugins",slug:"applications-and-software-plugins"}],lastUpdated:"7/26/2024, 6:48:28 PM",lastUpdatedTimestamp:1722019708e3,codeSwitcherOptions:{groups:{default:{py:"Python",r:"R",js:"JavaScript"}}}},{title:"Examples",frontmatter:{},regularPath:"/documentation/0.4/developers/examples/",relativePath:"documentation/0.4/developers/examples/README.md",key:"v-0059cb2a",path:"/documentation/0.4/developers/examples/",lastUpdated:"7/26/2024, 6:48:28 PM",lastUpdatedTimestamp:1722019708e3,codeSwitcherOptions:{groups:{default:{py:"Python",r:"R",js:"JavaScript"}}}},{title:"Client library development guidelines",frontmatter:{},regularPath:"/documentation/0.4/developers/clients/library-guidelines.html",relativePath:"documentation/0.4/developers/clients/library-guidelines.md",key:"v-5e5c94cd",path:"/documentation/0.4/developers/clients/library-guidelines.html",headers:[{level:2,title:"Conventions",slug:"conventions"},{level:3,title:"Casing",slug:"casing"},{level:3,title:"Scopes",slug:"scopes"},{level:3,title:"Scope categories",slug:"scope-categories"},{level:3,title:"Parameters",slug:"parameters"},{level:2,title:"Method mappings",slug:"method-mappings"},{level:3,title:"Scope: openEO (root category)",slug:"scope-openeo-root-category"},{level:4,title:"Parameters",slug:"parameters-2"},{level:3,title:"Scope: Connection (API category)",slug:"scope-connection-api-category"},{level:4,title:"Parameters",slug:"parameters-3"},{level:3,title:"Scope Capabilities (Content category)",slug:"scope-capabilities-content-category"},{level:4,title:"Parameters",slug:"parameters-4"},{level:3,title:"Scope: File (API category)",slug:"scope-file-api-category"},{level:4,title:"Parameters",slug:"parameters-5"},{level:3,title:"Scope: Job (API category)",slug:"scope-job-api-category"},{level:4,title:"Parameters",slug:"parameters-6"},{level:3,title:"Scope: ProcessGraph (API category)",slug:"scope-processgraph-api-category"},{level:3,title:"Scope: Service (API category)",slug:"scope-service-api-category"},{level:2,title:"Processes",slug:"processes"},{level:2,title:"Workflow example",slug:"workflow-example"},{level:3,title:"R (functional style)",slug:"r-functional-style"},{level:3,title:"Python (mixed style)",slug:"python-mixed-style"},{level:3,title:"Java (object oriented style)",slug:"java-object-oriented-style"},{level:3,title:"PHP (procedural style)",slug:"php-procedural-style"}],lastUpdated:"7/26/2024, 6:48:28 PM",lastUpdatedTimestamp:1722019708e3,codeSwitcherOptions:{groups:{default:{py:"Python",r:"R",js:"JavaScript"}}}},{title:"Examples (proof of concept)",frontmatter:{},regularPath:"/documentation/0.4/developers/examples/poc.html",relativePath:"documentation/0.4/developers/examples/poc.md",key:"v-25dd3de6",path:"/documentation/0.4/developers/examples/poc.html",headers:[{level:2,title:"Use Case 1",slug:"use-case-1"},{level:2,title:"Use Case 2",slug:"use-case-2"},{level:2,title:"Use Case 3",slug:"use-case-3"}],lastUpdated:"7/26/2024, 6:48:28 PM",lastUpdatedTimestamp:1722019708e3,codeSwitcherOptions:{groups:{default:{py:"Python",r:"R",js:"JavaScript"}}}},{title:"Getting started for users",frontmatter:{},regularPath:"/documentation/0.4/getting-started.html",relativePath:"documentation/0.4/getting-started.md",key:"v-6993aee6",path:"/documentation/0.4/getting-started.html",headers:[{level:2,title:"Contribute",slug:"contribute"}],lastUpdated:"7/26/2024, 6:48:28 PM",lastUpdatedTimestamp:1722019708e3,codeSwitcherOptions:{groups:{default:{py:"Python",r:"R",js:"JavaScript"}}}},{frontmatter:{fullpage:!0,stripCSS:!0},regularPath:"/documentation/0.4/processes.html",relativePath:"documentation/0.4/processes.md",key:"v-cfac61a6",path:"/documentation/0.4/processes.html",lastUpdated:"7/26/2024, 6:48:28 PM",lastUpdatedTimestamp:1722019708e3,codeSwitcherOptions:{groups:{default:{py:"Python",r:"R",js:"JavaScript"}}}},{title:"Glossary",frontmatter:{},regularPath:"/documentation/0.4/glossary.html",relativePath:"documentation/0.4/glossary.md",key:"v-3359623e",path:"/documentation/0.4/glossary.html",headers:[{level:2,title:"General terms",slug:"general-terms"},{level:2,title:"Processes and process graphs",slug:"processes-and-process-graphs"},{level:2,title:"EO data (Collections)",slug:"eo-data-collections"},{level:2,title:"Spatial data cubes",slug:"spatial-data-cubes"},{level:3,title:"apply: processes that do not change dimensions",slug:"apply-processes-that-do-not-change-dimensions"},{level:3,title:"filter: subsetting dimensions by dimension value selection",slug:"filter-subsetting-dimensions-by-dimension-value-selection"},{level:3,title:"reduce: removing dimensions entirely by computation",slug:"reduce-removing-dimensions-entirely-by-computation"},{level:3,title:"aggregate: reducing resolution",slug:"aggregate-reducing-resolution"},{level:3,title:"resample: changing data cube geometry",slug:"resample-changing-data-cube-geometry"},{level:2,title:"User-defined function (UDF)",slug:"user-defined-function-udf"},{level:2,title:"Data Processing modes",slug:"data-processing-modes"}],lastUpdated:"7/26/2024, 6:48:28 PM",lastUpdatedTimestamp:1722019708e3,codeSwitcherOptions:{groups:{default:{py:"Python",r:"R",js:"JavaScript"}}}},{title:"Introduction",frontmatter:{},regularPath:"/documentation/1.0/",relativePath:"documentation/1.0/README.md",key:"v-37dbaaa0",path:"/documentation/1.0/",headers:[{level:2,title:"Contribute",slug:"contribute"}],lastUpdated:"7/26/2024, 6:48:28 PM",lastUpdatedTimestamp:1722019708e3,codeSwitcherOptions:{groups:{default:{py:"Python",r:"R",js:"JavaScript"}}}},{title:"User-defined functions",frontmatter:{},regularPath:"/documentation/0.4/udfs.html",relativePath:"documentation/0.4/udfs.md",key:"v-6aca4be5",path:"/documentation/0.4/udfs.html",lastUpdated:"7/26/2024, 6:48:28 PM",lastUpdatedTimestamp:1722019708e3,codeSwitcherOptions:{groups:{default:{py:"Python",r:"R",js:"JavaScript"}}}},{title:"Authentication",frontmatter:{},regularPath:"/documentation/1.0/authentication.html",relativePath:"documentation/1.0/authentication.md",key:"v-7758ae27",path:"/documentation/1.0/authentication.html",headers:[{level:2,title:"HTTP Basic",slug:"http-basic"},{level:2,title:"OpenID Connect",slug:"openid-connect"},{level:3,title:"Authorization Code Flow",slug:"authorization-code-flow"},{level:3,title:"Device Flow",slug:"device-flow"},{level:3,title:"Client Credentials Flow",slug:"client-credentials-flow"},{level:3,title:"Resource Owner Password flow",slug:"resource-owner-password-flow"},{level:3,title:"Refresh Token Flow",slug:"refresh-token-flow"}],lastUpdated:"7/26/2024, 6:48:28 PM",lastUpdatedTimestamp:1722019708e3,codeSwitcherOptions:{groups:{default:{py:"Python",r:"R",js:"JavaScript"}}}},{title:"openEO Cookbook",frontmatter:{sidebarDepth:3},regularPath:"/documentation/1.0/cookbook/",relativePath:"documentation/1.0/cookbook/README.md",key:"v-9f635184",path:"/documentation/1.0/cookbook/",headers:[{level:2,title:"Chapter 1",slug:"chapter-1"},{level:3,title:"Connecting to a back-end",slug:"connecting-to-a-back-end"},{level:3,title:"Input: load_collection",slug:"input-load-collection"},{level:3,title:"Filter Bands: filter_bands",slug:"filter-bands-filter-bands"},{level:3,title:"Temporal Mean: reduce_dimension",slug:"temporal-mean-reduce-dimension"},{level:3,title:"Scale All Pixels Linearly: apply, linear_scale_range",slug:"scale-all-pixels-linearly-apply-linear-scale-range"},{level:3,title:"Spatial Aggregation: aggregate_spatial",slug:"spatial-aggregation-aggregate-spatial"},{level:3,title:"Output: save_result",slug:"output-save-result"},{level:4,title:"Raster Formats: GTiff, NetCDF",slug:"raster-formats-gtiff-netcdf"},{level:4,title:"Raster Formats: PNG",slug:"raster-formats-png"},{level:4,title:"Text Formats: JSON, CSV",slug:"text-formats-json-csv"},{level:3,title:"Output: Process as JSON",slug:"output-process-as-json"},{level:2,title:"Chapter 2",slug:"chapter-2"},{level:3,title:"Bandmath",slug:"bandmath"},{level:4,title:"Example 1: NDVI",slug:"example-1-ndvi"},{level:4,title:"Example 2: EVI",slug:"example-2-evi"},{level:3,title:"Masks: mask",slug:"masks-mask"},{level:4,title:"Mask Out Specific Values",slug:"mask-out-specific-values"},{level:4,title:"Thresholds",slug:"thresholds"},{level:3,title:"Pixel Operations: apply",slug:"pixel-operations-apply"},{level:3,title:"Image Kernels: apply_kernel",slug:"image-kernels-apply-kernel"},{level:2,title:"Endnote",slug:"endnote"}],lastUpdated:"7/26/2024, 6:48:28 PM",lastUpdatedTimestamp:1722019708e3,codeSwitcherOptions:{groups:{default:{py:"Python",r:"R",js:"JavaScript"}}}},{title:"Datacubes",frontmatter:{},regularPath:"/documentation/1.0/datacubes.html",relativePath:"documentation/1.0/datacubes.md",key:"v-5fd8f1ad",path:"/documentation/1.0/datacubes.html",headers:[{level:2,title:"What are Datacubes?",slug:"what-are-datacubes"},{level:2,title:"Dimensions",slug:"dimensions"},{level:3,title:"Applying Processes on Dimensions",slug:"applying-processes-on-dimensions"},{level:3,title:"Resolution",slug:"resolution"},{level:3,title:"Coordinate Reference System as a Dimension",slug:"coordinate-reference-system-as-a-dimension"},{level:2,title:"Values in a datacube",slug:"values-in-a-datacube"},{level:2,title:"Processes on Datacubes",slug:"processes-on-datacubes"},{level:3,title:"Filter",slug:"filter"},{level:3,title:"Apply",slug:"apply"},{level:3,title:"Resample",slug:"resample"},{level:3,title:"Reduce",slug:"reduce"},{level:3,title:"Aggregate",slug:"aggregate"}],lastUpdated:"7/26/2024, 6:48:28 PM",lastUpdatedTimestamp:1722019708e3,codeSwitcherOptions:{groups:{default:{py:"Python",r:"R",js:"JavaScript"}}}},{title:"Datacube Documentation",frontmatter:{},regularPath:"/documentation/1.0/datacubes/",relativePath:"documentation/1.0/datacubes/README.md",key:"v-f5de2fb4",path:"/documentation/1.0/datacubes/",lastUpdated:"7/26/2024, 6:48:28 PM",lastUpdatedTimestamp:1722019708e3,codeSwitcherOptions:{groups:{default:{py:"Python",r:"R",js:"JavaScript"}}}},{title:"Introduction",frontmatter:{},regularPath:"/documentation/1.0/developers/",relativePath:"documentation/1.0/developers/README.md",key:"v-43de507e",path:"/documentation/1.0/developers/",headers:[{level:2,title:"Additional information",slug:"additional-information"}],lastUpdated:"7/26/2024, 6:48:28 PM",lastUpdatedTimestamp:1722019708e3,codeSwitcherOptions:{groups:{default:{py:"Python",r:"R",js:"JavaScript"}}}},{frontmatter:{},regularPath:"/documentation/1.0/developers/api/",relativePath:"documentation/1.0/developers/api/README.md",key:"v-654015de",path:"/documentation/1.0/developers/api/",lastUpdated:"7/26/2024, 6:48:28 PM",lastUpdatedTimestamp:1722019708e3,codeSwitcherOptions:{groups:{default:{py:"Python",r:"R",js:"JavaScript"}}}},{title:"Architecture",frontmatter:{},regularPath:"/documentation/1.0/developers/arch.html",relativePath:"documentation/1.0/developers/arch.md",key:"v-75018026",path:"/documentation/1.0/developers/arch.html",lastUpdated:"7/26/2024, 6:48:28 PM",lastUpdatedTimestamp:1722019708e3,codeSwitcherOptions:{groups:{default:{py:"Python",r:"R",js:"JavaScript"}}}},{frontmatter:{fullpage:!0,stripCSS:!0},regularPath:"/documentation/1.0/developers/api/reference.html",relativePath:"documentation/1.0/developers/api/reference.md",key:"v-dc734f12",path:"/documentation/1.0/developers/api/reference.html",lastUpdated:"7/26/2024, 6:48:28 PM",lastUpdatedTimestamp:1722019708e3,codeSwitcherOptions:{groups:{default:{py:"Python",r:"R",js:"JavaScript"}}}},{title:"openEO error codes",frontmatter:{},regularPath:"/documentation/1.0/developers/api/errors.html",relativePath:"documentation/1.0/developers/api/errors.md",key:"v-8d587926",path:"/documentation/1.0/developers/api/errors.html",lastUpdated:"7/26/2024, 6:48:28 PM",lastUpdatedTimestamp:1722019708e3,codeSwitcherOptions:{groups:{default:{py:"Python",r:"R",js:"JavaScript"}}}},{title:"Getting started for service (back-end) providers",frontmatter:{},regularPath:"/documentation/1.0/developers/backends/getting-started.html",relativePath:"documentation/1.0/developers/backends/getting-started.md",key:"v-1772ad2d",path:"/documentation/1.0/developers/backends/getting-started.html",lastUpdated:"7/26/2024, 6:48:28 PM",lastUpdatedTimestamp:1722019708e3,codeSwitcherOptions:{groups:{default:{py:"Python",r:"R",js:"JavaScript"}}}},{title:"Getting started with openEO and Xarray and Dask",frontmatter:{},regularPath:"/documentation/1.0/developers/backends/xarray.html",relativePath:"documentation/1.0/developers/backends/xarray.md",key:"v-2840d4fe",path:"/documentation/1.0/developers/backends/xarray.html",headers:[{level:2,title:"Process Graph Parser for Python",slug:"process-graph-parser-for-python"},{level:2,title:"Python Processes for openEO",slug:"python-processes-for-openeo"},{level:2,title:"The loadcollection and saveresult process",slug:"the-load-collection-and-save-result-process"},{level:3,title:"Connection to ODC and STAC",slug:"connection-to-odc-and-stac"},{level:2,title:"openEO Client Side Processing",slug:"openeo-client-side-processing"},{level:2,title:"Adding a new process",slug:"adding-a-new-process"},{level:3,title:"Add the process spec",slug:"add-the-process-spec"},{level:3,title:"Add the process implementation",slug:"add-the-process-implementation"},{level:2,title:"HTTP REST Interface",slug:"http-rest-interface"}],lastUpdated:"7/26/2024, 6:48:28 PM",lastUpdatedTimestamp:1722019708e3,codeSwitcherOptions:{groups:{default:{py:"Python",r:"R",js:"JavaScript"}}}},{title:"Performance guide for openEO backends",frontmatter:{},regularPath:"/documentation/1.0/developers/backends/performance.html",relativePath:"documentation/1.0/developers/backends/performance.md",key:"v-253cefad",path:"/documentation/1.0/developers/backends/performance.html",headers:[{level:2,title:"openEO API vision on performance & scalability",slug:"openeo-api-vision-on-performance-scalability"},{level:3,title:"Bringing the processing to the data",slug:"bringing-the-processing-to-the-data"},{level:3,title:"Datacube processing",slug:"datacube-processing"},{level:2,title:"Process graph execution",slug:"process-graph-execution"},{level:2,title:"Performance FAQ",slug:"performance-faq"},{level:3,title:"I have a highly optimized workflow, can openEO expose it?",slug:"i-have-a-highly-optimized-workflow-can-openeo-expose-it"},{level:3,title:"Can openEO be as fast as a hand-written workflow?",slug:"can-openeo-be-as-fast-as-a-hand-written-workflow"}],lastUpdated:"7/26/2024, 6:48:28 PM",lastUpdatedTimestamp:1722019708e3,codeSwitcherOptions:{groups:{default:{py:"Python",r:"R",js:"JavaScript"}}}},{title:"Getting started for client developers",frontmatter:{},regularPath:"/documentation/1.0/developers/clients/getting-started.html",relativePath:"documentation/1.0/developers/clients/getting-started.md",key:"v-1b45967e",path:"/documentation/1.0/developers/clients/getting-started.html",headers:[{level:2,title:"Client library developers",slug:"client-library-developers"},{level:2,title:"Applications and Software plugins",slug:"applications-and-software-plugins"}],lastUpdated:"7/26/2024, 6:48:28 PM",lastUpdatedTimestamp:1722019708e3,codeSwitcherOptions:{groups:{default:{py:"Python",r:"R",js:"JavaScript"}}}},{title:"Client library development guidelines",frontmatter:{},regularPath:"/documentation/1.0/developers/clients/library-guidelines.html",relativePath:"documentation/1.0/developers/clients/library-guidelines.md",key:"v-021062ed",path:"/documentation/1.0/developers/clients/library-guidelines.html",headers:[{level:2,title:"Conventions",slug:"conventions"},{level:3,title:"Casing",slug:"casing"},{level:3,title:"Scopes",slug:"scopes"},{level:3,title:"Scope categories",slug:"scope-categories"},{level:3,title:"Parameters",slug:"parameters"},{level:2,title:"Method mappings",slug:"method-mappings"},{level:3,title:"Scope: openEO (root category)",slug:"scope-openeo-root-category"},{level:4,title:"Parameters",slug:"parameters-2"},{level:3,title:"Scope: Connection (API category)",slug:"scope-connection-api-category"},{level:4,title:"Parameters",slug:"parameters-3"},{level:3,title:"Scope Capabilities (Content category)",slug:"scope-capabilities-content-category"},{level:4,title:"Parameters",slug:"parameters-4"},{level:3,title:"Scope: File (API category)",slug:"scope-file-api-category"},{level:4,title:"Parameters",slug:"parameters-5"},{level:3,title:"Scope: Job (API category)",slug:"scope-job-api-category"},{level:4,title:"Parameters",slug:"parameters-6"},{level:3,title:"Scope: UserProcess (API category)",slug:"scope-userprocess-api-category"},{level:3,title:"Scope: Service (API category)",slug:"scope-service-api-category"},{level:2,title:"Processes",slug:"processes"},{level:2,title:"Workflow example",slug:"workflow-example"},{level:3,title:"R (functional style)",slug:"r-functional-style"},{level:3,title:"Python (mixed style)",slug:"python-mixed-style"},{level:3,title:"Java (object oriented style)",slug:"java-object-oriented-style"},{level:3,title:"PHP (procedural style)",slug:"php-procedural-style"}],lastUpdated:"7/26/2024, 6:48:28 PM",lastUpdatedTimestamp:1722019708e3,codeSwitcherOptions:{groups:{default:{py:"Python",r:"R",js:"JavaScript"}}}},{title:"API Profiles",frontmatter:{},regularPath:"/documentation/1.0/developers/profiles/api.html",relativePath:"documentation/1.0/developers/profiles/api.md",key:"v-97aa86e6",path:"/documentation/1.0/developers/profiles/api.html",headers:[{level:2,title:"Requirements per Profile",slug:"requirements-per-profile"},{level:3,title:"L1: Minimal",slug:"l1-minimal"},{level:4,title:"API fundamentals",slug:"api-fundamentals"},{level:4,title:"Well-known Discovery",slug:"well-known-discovery"},{level:4,title:"Capabilities",slug:"capabilities"},{level:4,title:"File Formats",slug:"file-formats"},{level:4,title:"Authentication",slug:"authentication"},{level:4,title:"Pre-defined Processes",slug:"pre-defined-processes"},{level:4,title:"Collections",slug:"collections"},{level:4,title:"Data Processing",slug:"data-processing"},{level:3,title:"L1A: Minimal - Synchronous Processing",slug:"l1a-minimal-synchronous-processing"},{level:4,title:"Synchronous Processing",slug:"synchronous-processing"},{level:3,title:"L1B: Minimal - Batch Jobs",slug:"l1b-minimal-batch-jobs"},{level:4,title:"Batch Jobs",slug:"batch-jobs"},{level:4,title:"Batch Jobs > Results",slug:"batch-jobs-results"},{level:3,title:"L1C: Minimal - Secondary Web Services",slug:"l1c-minimal-secondary-web-services"},{level:4,title:"Secondary Web Service Discovery",slug:"secondary-web-service-discovery"},{level:4,title:"Secondary Web Services",slug:"secondary-web-services"},{level:3,title:"L2: Recommended",slug:"l2-recommended"},{level:4,title:"API fundamentals",slug:"api-fundamentals-2"},{level:4,title:"Well-known Discovery",slug:"well-known-discovery-2"},{level:4,title:"Capabilities",slug:"capabilities-2"},{level:4,title:"File Formats",slug:"file-formats-2"},{level:4,title:"Authentication",slug:"authentication-2"},{level:4,title:"User Account",slug:"user-account"},{level:4,title:"Pre-defined Processes",slug:"pre-defined-processes-2"},{level:4,title:"Collections",slug:"collections-2"},{level:4,title:"User-defined processes",slug:"user-defined-processes"},{level:4,title:"Data Processing",slug:"data-processing-2"},{level:4,title:"Batch Jobs",slug:"batch-jobs-2"},{level:4,title:"Batch Jobs > Logs",slug:"batch-jobs-logs"},{level:4,title:"Batch Jobs > Results",slug:"batch-jobs-results-2"},{level:4,title:"Synchronous Processing",slug:"synchronous-processing-2"},{level:3,title:"L3: Advanced",slug:"l3-advanced"},{level:4,title:"API fundamentals",slug:"api-fundamentals-3"},{level:4,title:"Well-known Discovery",slug:"well-known-discovery-3"},{level:4,title:"Conformance Classes",slug:"conformance-classes"},{level:4,title:"Authentication",slug:"authentication-3"},{level:4,title:"Pre-defined Processes",slug:"pre-defined-processes-3"},{level:4,title:"Collections",slug:"collections-3"},{level:4,title:"User-defined processes",slug:"user-defined-processes-2"},{level:4,title:"Validation",slug:"validation"},{level:4,title:"Batch Jobs",slug:"batch-jobs-3"},{level:4,title:"Batch Jobs > Logs",slug:"batch-jobs-logs-2"},{level:4,title:"Batch Jobs > Estimates",slug:"batch-jobs-estimates"},{level:4,title:"Batch Jobs > Results",slug:"batch-jobs-results-3"},{level:4,title:"Synchronous Processing",slug:"synchronous-processing-3"},{level:3,title:"L3-UDF: UDF",slug:"l3-udf-udf"},{level:4,title:"UDF Runtimes",slug:"udf-runtimes"},{level:3,title:"L3-FS: File Storage",slug:"l3-fs-file-storage"},{level:4,title:"File Storage",slug:"file-storage"},{level:3,title:"L3-SWS: Secondary Web Services",slug:"l3-sws-secondary-web-services"},{level:4,title:"Secondary Web Service Discovery",slug:"secondary-web-service-discovery-2"},{level:4,title:"Secondary Web Services",slug:"secondary-web-services-2"},{level:3,title:"L4: Above and Beyond",slug:"l4-above-and-beyond"},{level:4,title:"Secondary Web Services",slug:"secondary-web-services-3"},{level:4,title:"Secondary Web Services > Logs",slug:"secondary-web-services-logs"},{level:4,title:"Batch Jobs",slug:"batch-jobs-4"},{level:4,title:"Batch Jobs > Estimates",slug:"batch-jobs-estimates-2"},{level:4,title:"Batch Jobs > Results",slug:"batch-jobs-results-4"}],lastUpdated:"7/26/2024, 6:48:28 PM",lastUpdatedTimestamp:1722019708e3,codeSwitcherOptions:{groups:{default:{py:"Python",r:"R",js:"JavaScript"}}}},{title:"Glossary",frontmatter:{},regularPath:"/documentation/1.0/glossary.html",relativePath:"documentation/1.0/glossary.md",key:"v-4af2bfca",path:"/documentation/1.0/glossary.html",headers:[{level:2,title:"General terms",slug:"general-terms"},{level:2,title:"Processes",slug:"processes"},{level:2,title:"EO data (Collections)",slug:"eo-data-collections"},{level:2,title:"Spatial datacubes",slug:"spatial-datacubes"},{level:2,title:"Vector data",slug:"vector-data"},{level:2,title:"User-defined function (UDF)",slug:"user-defined-function-udf"},{level:2,title:"Data Processing modes",slug:"data-processing-modes"}],lastUpdated:"7/26/2024, 6:48:28 PM",lastUpdatedTimestamp:1722019708e3,codeSwitcherOptions:{groups:{default:{py:"Python",r:"R",js:"JavaScript"}}}},{title:"JavaScript Client",frontmatter:{},regularPath:"/documentation/1.0/javascript/",relativePath:"documentation/1.0/javascript/index.md",key:"v-1a823cb0",path:"/documentation/1.0/javascript/",headers:[{level:2,title:"Installation",slug:"installation"},{level:2,title:"Exploring a back-end",slug:"exploring-a-back-end"},{level:3,title:"Collections",slug:"collections"},{level:3,title:"Processes",slug:"processes"},{level:2,title:"Authentication",slug:"authentication"},{level:3,title:"Basic Authentication",slug:"basic-authentication"},{level:3,title:"OpenID Connect Authentication",slug:"openid-connect-authentication"},{level:2,title:"Creating a (user-defined) process",slug:"creating-a-user-defined-process"},{level:2,title:"Batch Job Management",slug:"batch-job-management"},{level:2,title:"Full Example",slug:"full-example"},{level:2,title:"User Defined Functions",slug:"user-defined-functions"},{level:2,title:"Additional Information",slug:"additional-information"}],lastUpdated:"7/26/2024, 6:48:28 PM",lastUpdatedTimestamp:1722019708e3,codeSwitcherOptions:{groups:{default:{py:"Python",r:"R",js:"JavaScript"}}}},{frontmatter:{fullpage:!0,stripCSS:!0},regularPath:"/documentation/1.0/processes.html",relativePath:"documentation/1.0/processes.md",key:"v-00153acd",path:"/documentation/1.0/processes.html",lastUpdated:"7/26/2024, 6:48:28 PM",lastUpdatedTimestamp:1722019708e3,codeSwitcherOptions:{groups:{default:{py:"Python",r:"R",js:"JavaScript"}}}},{title:"Get started with the openEO Python Client Client Side Processing",frontmatter:{},regularPath:"/documentation/1.0/python/client-side-processing.html",relativePath:"documentation/1.0/python/client-side-processing.md",key:"v-9a2a2626",path:"/documentation/1.0/python/client-side-processing.html",headers:[{level:2,title:"Background",slug:"background"},{level:2,title:"Installation",slug:"installation"},{level:2,title:"Usage",slug:"usage"},{level:3,title:"STAC Collections and Items",slug:"stac-collections-and-items"},{level:3,title:"Local Collections",slug:"local-collections"},{level:3,title:"Local Processing",slug:"local-processing"},{level:2,title:"Client-Side Processing Example Notebooks",slug:"client-side-processing-example-notebooks"},{level:2,title:"Additional Information",slug:"additional-information"}],lastUpdated:"7/26/2024, 6:48:28 PM",lastUpdatedTimestamp:1722019708e3,codeSwitcherOptions:{groups:{default:{py:"Python",r:"R",js:"JavaScript"}}}},{title:"Python Client",frontmatter:{},regularPath:"/documentation/1.0/python/",relativePath:"documentation/1.0/python/index.md",key:"v-560d08d2",path:"/documentation/1.0/python/",headers:[{level:2,title:"Installation",slug:"installation"},{level:2,title:"Exploring a back-end",slug:"exploring-a-back-end"},{level:3,title:"Collections",slug:"collections"},{level:3,title:"Processes",slug:"processes"},{level:2,title:"Authentication",slug:"authentication"},{level:3,title:"Basic Authentication",slug:"basic-authentication"},{level:3,title:"OpenID Connect Authentication",slug:"openid-connect-authentication"},{level:2,title:"Working with Datacube",slug:"working-with-datacube"},{level:3,title:"Creating a Datacube",slug:"creating-a-datacube"},{level:3,title:"Applying processes",slug:"applying-processes"},{level:3,title:"Defining output format",slug:"defining-output-format"},{level:2,title:"Execution",slug:"execution"},{level:3,title:"Batch job execution",slug:"batch-job-execution"},{level:2,title:"Full Example",slug:"full-example"},{level:2,title:"User Defined Functions",slug:"user-defined-functions"},{level:2,title:"Additional Information",slug:"additional-information"}],lastUpdated:"7/26/2024, 6:48:28 PM",lastUpdatedTimestamp:1722019708e3,codeSwitcherOptions:{groups:{default:{py:"Python",r:"R",js:"JavaScript"}}}},{title:"Process Profiles",frontmatter:{},regularPath:"/documentation/1.0/developers/profiles/processes.html",relativePath:"documentation/1.0/developers/profiles/processes.md",key:"v-04d2236d",path:"/documentation/1.0/developers/profiles/processes.html",headers:[{level:2,title:"Requirements per Profile",slug:"requirements-per-profile"},{level:3,title:"L1: Minimal",slug:"l1-minimal"},{level:3,title:"L2: Recommended",slug:"l2-recommended"},{level:3,title:"L2A: Recommended Raster",slug:"l2a-recommended-raster"},{level:3,title:"L2B: Recommended Vector",slug:"l2b-recommended-vector"},{level:3,title:"L2-Date: Date & Time manipulation",slug:"l2-date-date-time-manipulation"},{level:3,title:"L2-Text: Text manipulation",slug:"l2-text-text-manipulation"},{level:3,title:"L3: Advanced",slug:"l3-advanced"},{level:3,title:"L3-ML: Machine Learning",slug:"l3-ml-machine-learning"},{level:3,title:"L3-UDF: User-Defined Functions",slug:"l3-udf-user-defined-functions"},{level:3,title:"L3-Clim: Cimatology",slug:"l3-clim-cimatology"},{level:3,title:"L3-ARD: Analysis-Ready Data",slug:"l3-ard-analysis-ready-data"},{level:3,title:"L4: Above and Beyond",slug:"l4-above-and-beyond"}],lastUpdated:"7/26/2024, 6:48:28 PM",lastUpdatedTimestamp:1722019708e3,codeSwitcherOptions:{groups:{default:{py:"Python",r:"R",js:"JavaScript"}}}},{title:"QGIS Plugin",frontmatter:{},regularPath:"/documentation/1.0/qgis/",relativePath:"documentation/1.0/qgis/index.md",key:"v-ef2073ec",path:"/documentation/1.0/qgis/",headers:[{level:2,title:"Installation",slug:"installation"},{level:2,title:"Connecting",slug:"connecting"},{level:2,title:"Exploring a backend",slug:"exploring-a-backend"},{level:2,title:"Job Management",slug:"job-management"},{level:3,title:"Creating new Jobs",slug:"creating-new-jobs"},{level:3,title:"Adapting existing Jobs",slug:"adapting-existing-jobs"},{level:4,title:"Process Argument Helper",slug:"process-argument-helper"},{level:2,title:"Service Management",slug:"service-management"},{level:2,title:"Additional Information",slug:"additional-information"}],lastUpdated:"7/26/2024, 6:48:28 PM",lastUpdatedTimestamp:1722019708e3,codeSwitcherOptions:{groups:{default:{py:"Python",r:"R",js:"JavaScript"}}}},{title:"User-defined functions",frontmatter:{},regularPath:"/documentation/1.0/udfs.html",relativePath:"documentation/1.0/udfs.md",key:"v-ffc79ec2",path:"/documentation/1.0/udfs.html",headers:[{level:2,title:"Users",slug:"users"},{level:3,title:"JavaScript",slug:"javascript"},{level:3,title:"Python",slug:"python"},{level:3,title:"QGIS",slug:"qgis"},{level:3,title:"R",slug:"r"},{level:3,title:"Web Editor",slug:"web-editor"},{level:2,title:"Back-ends",slug:"back-ends"}],lastUpdated:"7/26/2024, 6:48:28 PM",lastUpdatedTimestamp:1722019708e3,codeSwitcherOptions:{groups:{default:{py:"Python",r:"R",js:"JavaScript"}}}},{title:"Contributor Code of Conduct",frontmatter:{},regularPath:"/documentation/code-of-conduct.html",relativePath:"documentation/code-of-conduct.md",key:"v-c71b5aa6",path:"/documentation/code-of-conduct.html",lastUpdated:"7/26/2024, 6:48:28 PM",lastUpdatedTimestamp:1722019708e3,codeSwitcherOptions:{groups:{default:{py:"Python",r:"R",js:"JavaScript"}}}},{title:"R Client",frontmatter:{},regularPath:"/documentation/1.0/r/",relativePath:"documentation/1.0/r/index.md",key:"v-592eaa86",path:"/documentation/1.0/r/",headers:[{level:2,title:"Useful links",slug:"useful-links"},{level:2,title:"Installation",slug:"installation"},{level:2,title:"Exploring a back-end",slug:"exploring-a-back-end"},{level:3,title:"Collections",slug:"collections"},{level:3,title:"Processes",slug:"processes"},{level:2,title:"Authentication",slug:"authentication"},{level:3,title:"Basic Authentication",slug:"basic-authentication"},{level:3,title:"OpenID Connect Authentication",slug:"openid-connect-authentication"},{level:2,title:"Creating a (user-defined) process",slug:"creating-a-user-defined-process"},{level:2,title:"Batch Job Management",slug:"batch-job-management"},{level:2,title:"Full Example",slug:"full-example"},{level:2,title:"User Defined Functions",slug:"user-defined-functions"}],lastUpdated:"7/26/2024, 6:48:28 PM",lastUpdatedTimestamp:1722019708e3,codeSwitcherOptions:{groups:{default:{py:"Python",r:"R",js:"JavaScript"}}}},{title:"Software Development Guidelines",frontmatter:{},regularPath:"/documentation/software-guidelines.html",relativePath:"documentation/software-guidelines.md",key:"v-1005bb66",path:"/documentation/software-guidelines.html",headers:[{level:2,title:"Software quality guidelines",slug:"software-quality-guidelines"},{level:2,title:"Software documentation guidelines",slug:"software-documentation-guidelines"},{level:2,title:"Software review",slug:"software-review"},{level:2,title:"Test-driven development",slug:"test-driven-development"},{level:2,title:"Continuous integration",slug:"continuous-integration"},{level:2,title:"Additional guidelines",slug:"additional-guidelines"}],lastUpdated:"7/26/2024, 6:48:28 PM",lastUpdatedTimestamp:1722019708e3,codeSwitcherOptions:{groups:{default:{py:"Python",r:"R",js:"JavaScript"}}}},{title:"openEO Profiles",frontmatter:{},regularPath:"/documentation/1.0/developers/profiles/",relativePath:"documentation/1.0/developers/profiles/README.md",key:"v-e35c5e24",path:"/documentation/1.0/developers/profiles/",lastUpdated:"7/26/2024, 6:48:28 PM",lastUpdatedTimestamp:1722019708e3,codeSwitcherOptions:{groups:{default:{py:"Python",r:"R",js:"JavaScript"}}}},{title:"IEEE IGARRS 2021 HD-3: Hands-on openEO: access cloud platforms using your preferred programming language",frontmatter:{},regularPath:"/events/igarrs2021.html",relativePath:"events/igarrs2021.md",key:"v-186cd6ed",path:"/events/igarrs2021.html",headers:[{level:2,title:"Agenda",slug:"agenda"},{level:2,title:"Python client",slug:"python-client"},{level:3,title:"Logging in",slug:"logging-in"},{level:3,title:"openEO in Python intro",slug:"openeo-in-python-intro"},{level:2,title:"R client",slug:"r-client"},{level:2,title:"openEO user interfaces",slug:"openeo-user-interfaces"},{level:2,title:"Use cases",slug:"use-cases"}],lastUpdated:"7/26/2024, 6:48:28 PM",lastUpdatedTimestamp:1722019708e3,codeSwitcherOptions:{groups:{default:{py:"Python",r:"R",js:"JavaScript"}}}},{title:"Welcome to openEO!",frontmatter:{news:!0,title:"Welcome to openEO!",date:"2017-12-05T00:00:00.000Z",author:"Edzer Pebesma"},regularPath:"/news/2017-12-05-welcome.html",relativePath:"news/2017-12-05-welcome.md",key:"v-0ee3f026",path:"/news/2017-12-05-welcome.html",lastUpdated:"7/26/2024, 6:48:28 PM",lastUpdatedTimestamp:1722019708e3,codeSwitcherOptions:{groups:{default:{py:"Python",r:"R",js:"JavaScript"}}}},{title:"First week of intensive collaboration: Dec 4-6, 2017",frontmatter:{news:!0,title:"First week of intensive collaboration: Dec 4-6, 2017",date:"2017-12-18T00:00:00.000Z",author:"Edzer Pebesma"},regularPath:"/news/2017-12-18-VITO_meeting.html",relativePath:"news/2017-12-18-VITO_meeting.md",key:"v-2997b752",path:"/news/2017-12-18-VITO_meeting.html",lastUpdated:"7/26/2024, 6:48:28 PM",lastUpdatedTimestamp:1722019708e3,codeSwitcherOptions:{groups:{default:{py:"Python",r:"R",js:"JavaScript"}}}},{title:"Second week of intensive collaboration: Jan 22-24, 2018",frontmatter:{news:!0,title:"Second week of intensive collaboration: Jan 22-24, 2018",date:"2018-01-31T00:00:00.000Z",author:"Marius Appel"},regularPath:"/news/2018-01-31-WWU_meeting.html",relativePath:"news/2018-01-31-WWU_meeting.md",key:"v-24966ce6",path:"/news/2018-01-31-WWU_meeting.html",lastUpdated:"7/26/2024, 6:48:28 PM",lastUpdatedTimestamp:1722019708e3,codeSwitcherOptions:{groups:{default:{py:"Python",r:"R",js:"JavaScript"}}}},{title:"User Requirements Survey for openEO launched",frontmatter:{news:!0,title:"User Requirements Survey for openEO launched",date:"2018-05-23T00:00:00.000Z",author:"Sarah Carter"},regularPath:"/news/2018-05-23-user-requirements-survey-launched.html",relativePath:"news/2018-05-23-user-requirements-survey-launched.md",key:"v-f9778ae6",path:"/news/2018-05-23-user-requirements-survey-launched.html",lastUpdated:"7/26/2024, 6:48:28 PM",lastUpdatedTimestamp:1722019708e3,codeSwitcherOptions:{groups:{default:{py:"Python",r:"R",js:"JavaScript"}}}},{title:"openEO proves its concept",frontmatter:{news:!0,title:"openEO proves its concept",date:"2018-03-17T00:00:00.000Z",author:"Edzer Pebesma, the openEO consortium"},regularPath:"/news/2018-03-15-poc.html",relativePath:"news/2018-03-15-poc.md",key:"v-4fe4e126",path:"/news/2018-03-15-poc.html",headers:[{level:2,title:"The problem",slug:"the-problem"},{level:2,title:"Why an API?",slug:"why-an-api"},{level:2,title:"First results",slug:"first-results"},{level:2,title:"The three use cases",slug:"the-three-use-cases"},{level:2,title:"Links to the client and back-end implementations",slug:"links-to-the-client-and-back-end-implementations"},{level:2,title:"Proof-of-concept videos",slug:"proof-of-concept-videos"},{level:3,title:"R client and WCPS back-end, use case 1",slug:"r-client-and-wcps-back-end-use-case-1"},{level:3,title:"Grass GIS back-end, use cases 1, 2 and 3",slug:"grass-gis-back-end-use-cases-1-2-and-3"},{level:3,title:"R client and R back-end, use-case 1",slug:"r-client-and-r-back-end-use-case-1"},{level:3,title:"R client and R back-end, use case 3",slug:"r-client-and-r-back-end-use-case-3"},{level:3,title:"openEO Web Editor (JS client) with three back-ends (use case 1)",slug:"openeo-web-editor-js-client-with-three-back-ends-use-case-1"},{level:3,title:"openEO Web Editor (JS client) with R back-end (use case 3)",slug:"openeo-web-editor-js-client-with-r-back-end-use-case-3"},{level:3,title:"Python client with GeoPySpark back-end (use case 1)",slug:"python-client-with-geopyspark-back-end-use-case-1"},{level:3,title:"openEO Web Editor (JS client) with Google Earth Engine back-end (use case 1)",slug:"openeo-web-editor-js-client-with-google-earth-engine-back-end-use-case-1"},{level:2,title:"Links to documents",slug:"links-to-documents"},{level:2,title:"Next steps",slug:"next-steps"},{level:2,title:"Getting involved",slug:"getting-involved"}],lastUpdated:"7/26/2024, 6:48:28 PM",lastUpdatedTimestamp:1722019708e3,codeSwitcherOptions:{groups:{default:{py:"Python",r:"R",js:"JavaScript"}}}},{title:"openEO API v0.4.0 released",frontmatter:{news:!0,title:"openEO API v0.4.0 released",date:"2019-03-07T00:00:00.000Z",author:"Matthias Mohr"},regularPath:"/news/2019-03-07-openeo-api-040.html",relativePath:"news/2019-03-07-openeo-api-040.md",key:"v-45d803ab",path:"/news/2019-03-07-openeo-api-040.html",headers:[{level:2,title:"New process catalogue and process graph changes",slug:"new-process-catalogue-and-process-graph-changes"},{level:2,title:"Other improvements",slug:"other-improvements"},{level:2,title:"Next steps",slug:"next-steps"}],lastUpdated:"7/26/2024, 6:48:28 PM",lastUpdatedTimestamp:1722019708e3,codeSwitcherOptions:{groups:{default:{py:"Python",r:"R",js:"JavaScript"}}}},{title:"openEO year one review meeting",frontmatter:{news:!0,title:"openEO year one review meeting",date:"2018-10-30T00:00:00.000Z",author:"Matthias Schramm"},regularPath:"/news/2018-10-30-year-one-review-meeting.html",relativePath:"news/2018-10-30-year-one-review-meeting.md",key:"v-d2a018a6",path:"/news/2018-10-30-year-one-review-meeting.html",lastUpdated:"7/26/2024, 6:48:28 PM",lastUpdatedTimestamp:1722019708e3,codeSwitcherOptions:{groups:{default:{py:"Python",r:"R",js:"JavaScript"}}}},{title:"H2020 EO Big Data Hackathon Nov 7-8",frontmatter:{news:!0,title:"H2020 EO Big Data Hackathon Nov 7-8",date:"2019-10-07T00:00:00.000Z",author:"Edzer Pebesma"},regularPath:"/news/2019-10-07-EO-big-data-hackaton.html",relativePath:"news/2019-10-07-EO-big-data-hackaton.md",key:"v-9ddae032",path:"/news/2019-10-07-EO-big-data-hackaton.html",lastUpdated:"7/26/2024, 6:48:28 PM",lastUpdatedTimestamp:1722019708e3,codeSwitcherOptions:{groups:{default:{py:"Python",r:"R",js:"JavaScript"}}}},{title:"Stable release of the openEO API and Processes (v1.0.0)",frontmatter:{news:!0,title:"Stable release of the openEO API and Processes (v1.0.0)",date:"2020-07-31T00:00:00.000Z",author:"Matthias Mohr"},regularPath:"/news/2020-07-31-openeo-api-released.html",relativePath:"news/2020-07-31-openeo-api-released.md",key:"v-2fcee9ad",path:"/news/2020-07-31-openeo-api-released.html",headers:[{level:2,title:"Processes",slug:"processes"},{level:2,title:"STAC and OGC APIs",slug:"stac-and-ogc-apis"},{level:2,title:"User-defined Functions (UDFs)",slug:"user-defined-functions-udfs"},{level:2,title:"Other improvements",slug:"other-improvements"},{level:2,title:"Limitations",slug:"limitations"},{level:2,title:"Next steps",slug:"next-steps"}],lastUpdated:"7/26/2024, 6:48:28 PM",lastUpdatedTimestamp:1722019708e3,codeSwitcherOptions:{groups:{default:{py:"Python",r:"R",js:"JavaScript"}}}},{title:"Lessons learned while developing the openEO API",frontmatter:{news:!0,title:"Lessons learned while developing the openEO API",date:"2020-07-31T00:00:00.000Z",author:"Matthias Mohr"},regularPath:"/news/2020-07-31-lessons-learned.html",relativePath:"news/2020-07-31-lessons-learned.md",key:"v-3f85032d",path:"/news/2020-07-31-lessons-learned.html",headers:[{level:2,title:"1. Collection Names",slug:"_1-collection-names"},{level:2,title:"2. Other Names",slug:"_2-other-names"},{level:2,title:"3. Chunked Collections",slug:"_3-chunked-collections"},{level:2,title:"4. What to specify?",slug:"_4-what-to-specify"},{level:3,title:"File Formats",slug:"file-formats"},{level:2,title:"5. Authentication",slug:"_5-authentication"},{level:2,title:"6. Debugging Experience",slug:"_6-debugging-experience"},{level:2,title:"7. Defining interoperable Processes",slug:"_7-defining-interoperable-processes"},{level:2,title:"Conclusion",slug:"conclusion"}],lastUpdated:"7/26/2024, 6:48:28 PM",lastUpdatedTimestamp:1722019708e3,codeSwitcherOptions:{groups:{default:{py:"Python",r:"R",js:"JavaScript"}}}},{title:"openEO Virtual User Workshop",frontmatter:{news:!0,title:"openEO Virtual User Workshop",date:"2020-09-02T00:00:00.000Z",author:"Matthias Schramm"},regularPath:"/news/2020-09-02-openeo-user-workshop.html",relativePath:"news/2020-09-02-openeo-user-workshop.md",key:"v-525dec3e",path:"/news/2020-09-02-openeo-user-workshop.html",headers:[{level:3,title:"UPDATE:",slug:"update"}],lastUpdated:"7/26/2024, 6:48:28 PM",lastUpdatedTimestamp:1722019708e3,codeSwitcherOptions:{groups:{default:{py:"Python",r:"R",js:"JavaScript"}}}},{title:"openEO API v1.0.1 released",frontmatter:{news:!0,title:"openEO API v1.0.1 released",date:"2020-11-30T00:00:00.000Z",author:"Matthias Mohr"},regularPath:"/news/2020-11-30-openeo-api-101-released.html",relativePath:"news/2020-11-30-openeo-api-101-released.md",key:"v-0e5e57cd",path:"/news/2020-11-30-openeo-api-101-released.html",lastUpdated:"7/26/2024, 6:48:28 PM",lastUpdatedTimestamp:1722019708e3,codeSwitcherOptions:{groups:{default:{py:"Python",r:"R",js:"JavaScript"}}}},{title:"openEO API v1.1.0 released",frontmatter:{news:!0,title:"openEO API v1.1.0 released",date:"2021-05-17T00:00:00.000Z",author:"Matthias Mohr"},regularPath:"/news/2021-05-17-openeo-api-110-released.html",relativePath:"news/2021-05-17-openeo-api-110-released.md",key:"v-6e6b7e2d",path:"/news/2021-05-17-openeo-api-110-released.html",lastUpdated:"7/26/2024, 6:48:28 PM",lastUpdatedTimestamp:1722019708e3,codeSwitcherOptions:{groups:{default:{py:"Python",r:"R",js:"JavaScript"}}}},{title:"R Client on CRAN",frontmatter:{news:!0,title:"R Client on CRAN",date:"2021-11-08T00:00:00.000Z",author:"Matthias Mohr"},regularPath:"/news/2021-11-08-r-client-on-cran.html",relativePath:"news/2021-11-08-r-client-on-cran.md",key:"v-06e0a8ca",path:"/news/2021-11-08-r-client-on-cran.html",lastUpdated:"7/26/2024, 6:48:28 PM",lastUpdatedTimestamp:1722019708e3,codeSwitcherOptions:{groups:{default:{py:"Python",r:"R",js:"JavaScript"}}}},{title:"openEO PSC meetings",frontmatter:{news:!0,title:"openEO PSC meetings",date:"2022-04-08T00:00:00.000Z",author:"Matthias Mohr"},regularPath:"/news/2022-04-08-psc-meetings.html",relativePath:"news/2022-04-08-psc-meetings.md",key:"v-1227575e",path:"/news/2022-04-08-psc-meetings.html",lastUpdated:"7/26/2024, 6:48:28 PM",lastUpdatedTimestamp:1722019708e3,codeSwitcherOptions:{groups:{default:{py:"Python",r:"R",js:"JavaScript"}}}},{title:"R Client v1.2.0 has been released",frontmatter:{news:!0,title:"R Client v1.2.0 has been released",date:"2022-05-12T00:00:00.000Z",author:"Matthias Mohr, Florian Lahn"},regularPath:"/news/2022-05-12-r-client-v120.html",relativePath:"news/2022-05-12-r-client-v120.md",key:"v-59d340ad",path:"/news/2022-05-12-r-client-v120.html",lastUpdated:"7/26/2024, 6:48:28 PM",lastUpdatedTimestamp:1722019708e3,codeSwitcherOptions:{groups:{default:{py:"Python",r:"R",js:"JavaScript"}}}},{title:"Monthly openEO community meeting",frontmatter:{news:!0,title:"Monthly openEO community meeting",date:"2022-07-07T00:00:00.000Z",author:"Matthias Mohr"},regularPath:"/news/2022-07-07-monthly-dev-calls.html",relativePath:"news/2022-07-07-monthly-dev-calls.md",key:"v-00d62ee6",path:"/news/2022-07-07-monthly-dev-calls.html",lastUpdated:"7/26/2024, 6:48:28 PM",lastUpdatedTimestamp:1722019708e3,codeSwitcherOptions:{groups:{default:{py:"Python",r:"R",js:"JavaScript"}}}},{title:"R Client v1.3.0 has been released",frontmatter:{news:!0,title:"R Client v1.3.0 has been released",date:"2022-11-17T00:00:00.000Z",author:"Matthias Mohr, Peter J. Zellner, Florian Lahn"},regularPath:"/news/2022-11-17-r-client-v130.html",relativePath:"news/2022-11-17-r-client-v130.md",key:"v-221bfb8d",path:"/news/2022-11-17-r-client-v130.html",headers:[{level:2,title:"Better support for sf",slug:"better-support-for-sf"},{level:2,title:"New Vignettes",slug:"new-vignettes"}],lastUpdated:"7/26/2024, 6:48:28 PM",lastUpdatedTimestamp:1722019708e3,codeSwitcherOptions:{groups:{default:{py:"Python",r:"R",js:"JavaScript"}}}},{title:"New releases for openEO API and openEO Processes, focus on vector data",frontmatter:{news:!0,title:"New releases for openEO API and openEO Processes, focus on vector data",date:"2023-05-25T00:00:00.000Z",author:"Matthias Mohr"},regularPath:"/news/2023-05-25-new-openeo-versions-120-200rc1%20copy.html",relativePath:"news/2023-05-25-new-openeo-versions-120-200rc1 copy.md",key:"v-3eeef04a",path:"/news/2023-05-25-new-openeo-versions-120-200rc1%20copy.html",headers:[{level:2,title:"openEO API v1.2.0",slug:"openeo-api-v1-2-0"},{level:2,title:"openEO Processes v2.0.0-rc.1",slug:"openeo-processes-v2-0-0-rc-1"}],lastUpdated:"7/26/2024, 6:48:28 PM",lastUpdatedTimestamp:1722019708e3,codeSwitcherOptions:{groups:{default:{py:"Python",r:"R",js:"JavaScript"}}}},{title:"openEO submitted to OGC for consideration as an OGC community standard",frontmatter:{news:!0,title:"openEO submitted to OGC for consideration as an OGC community standard",date:"2023-12-06T00:00:00.000Z",author:"Matthias Mohr"},regularPath:"/news/2023-12-06-openeo-submitted-to-ogc.html",relativePath:"news/2023-12-06-openeo-submitted-to-ogc.md",key:"v-857a96a6",path:"/news/2023-12-06-openeo-submitted-to-ogc.html",lastUpdated:"7/26/2024, 6:48:28 PM",lastUpdatedTimestamp:1722019708e3,codeSwitcherOptions:{groups:{default:{py:"Python",r:"R",js:"JavaScript"}}}},{title:"OGC seeks public comment on the adoption of openEO as a Community Standard",frontmatter:{news:!0,title:"OGC seeks public comment on the adoption of openEO as a Community Standard",date:"2024-02-06T00:00:00.000Z",author:"Matthias Mohr"},regularPath:"/news/2024-02-06-openeo-ogc-rfc.html",relativePath:"news/2024-02-06-openeo-ogc-rfc.md",key:"v-10d9ffb7",path:"/news/2024-02-06-openeo-ogc-rfc.html",lastUpdated:"7/26/2024, 6:48:28 PM",lastUpdatedTimestamp:1722019708e3,codeSwitcherOptions:{groups:{default:{py:"Python",r:"R",js:"JavaScript"}}}},{title:"News",frontmatter:{sidebar:!1},regularPath:"/news/",relativePath:"news/README.md",key:"v-8850e2c4",path:"/news/",lastUpdated:"7/26/2024, 6:48:28 PM",lastUpdatedTimestamp:1722019708e3,codeSwitcherOptions:{groups:{default:{py:"Python",r:"R",js:"JavaScript"}}}},{title:"MOOC Cubes and Clouds - open for registration",frontmatter:{news:!0,title:"MOOC Cubes and Clouds - open for registration",date:"2024-03-22T00:00:00.000Z",author:"Peter Zellner"},regularPath:"/news/2024-03-22_mooc_cubeandclouds.html",relativePath:"news/2024-03-22_mooc_cubeandclouds.md",key:"v-d5007282",path:"/news/2024-03-22_mooc_cubeandclouds.html",lastUpdated:"7/26/2024, 6:48:28 PM",lastUpdatedTimestamp:1722019708e3,codeSwitcherOptions:{groups:{default:{py:"Python",r:"R",js:"JavaScript"}}}},{title:"openEO Project Steering Committee",frontmatter:{},regularPath:"/psc.html",relativePath:"psc.md",key:"v-64c18f4d",path:"/psc.html",headers:[{level:2,title:"Members",slug:"members"},{level:2,title:"Detailed Process",slug:"detailed-process"},{level:3,title:"When is Vote Required?",slug:"when-is-vote-required"},{level:3,title:"Final remarks",slug:"final-remarks"},{level:2,title:"Committee Membership",slug:"committee-membership"},{level:3,title:"Adding Members",slug:"adding-members"},{level:3,title:"Stepping Down",slug:"stepping-down"},{level:2,title:"History",slug:"history"}],codeSwitcherOptions:{groups:{default:{py:"Python",r:"R",js:"JavaScript"}}}},{title:"Software",frontmatter:{},regularPath:"/software.html",relativePath:"software.md",key:"v-9adb302a",path:"/software.html",headers:[{level:2,title:"Clients",slug:"clients"},{level:2,title:"Back-ends",slug:"back-ends"},{level:2,title:"Specification",slug:"specification"},{level:2,title:"Ecosystem",slug:"ecosystem"}],lastUpdated:"7/26/2024, 6:48:28 PM",lastUpdatedTimestamp:1722019708e3,codeSwitcherOptions:{groups:{default:{py:"Python",r:"R",js:"JavaScript"}}}}],themeConfig:{apiVersion:"1.2.0",versions:[{folder:"1.0",path:"/documentation/1.0/",title:"1.x",apiTag:"1.2.0",processesTag:"2.0.0-rc.1",apiVersions:["1.0.0","1.0.1","1.1.0","1.2.0"],userNav:[{text:"Introduction",link:"index.html"},{text:"Glossary",link:"glossary.html"},{text:"Datacubes",link:"datacubes.html"},{text:"Getting Started",items:[{text:"JavaScript",link:"javascript/index.html"},{text:"Python",link:"python/index.html"},{text:"QGIS",link:"qgis/index.html"},{text:"R",link:"r/index.html"},{text:"Client-Side Processing (Python)",link:"python/client-side-processing.html"}]},{text:"Processes",link:"processes.html"},{text:"Cookbook",link:"cookbook/index.html"},{text:"Authentication",link:"authentication.html"},{text:"UDFs",link:"udfs.html"}],devNav:[{text:"Introduction",link:"developers/index.html"},{text:"Glossary",link:"glossary.html"},{text:"Architecture",link:"developers/arch.html"},{text:"Service Providers",items:[{text:"Getting Started",link:"developers/backends/getting-started.html"},{text:"Performance Guide",link:"developers/backends/performance.html"},{text:"Xarray / Dask Guide",link:"developers/backends/xarray.html"},{text:"Profiles",link:"developers/profiles/index.html"}]},{text:"Client Developers",items:[{text:"Getting Started",link:"developers/clients/getting-started.html"},{text:"Library Guidelines",link:"developers/clients/library-guidelines.html"}]},{text:"API",items:[{text:"Reference",link:"developers/api/reference.html"},{text:"Profiles",link:"developers/profiles/api.html"}]},{text:"Processes",items:[{text:"Reference",link:"processes.html"},{text:"Profiles",link:"developers/profiles/processes.html"}]},{text:"Error Codes",link:"developers/api/errors.html"},{text:"Authentication",link:"authentication.html"},{text:"UDFs",link:"udfs.html"}]},{folder:"0.4",path:"/documentation/0.4/",title:"0.4",apiTag:"0.4.2",apiFormat:"json",processesTag:"0.4.2",apiVersions:["0.4.0","0.4.1","0.4.2"],userNav:[{text:"Getting Started",link:"getting-started.html"},{text:"Glossary",link:"glossary.html"},{text:"Processes",link:"processes.html"},{text:"UDFs",link:"udfs.html"}],devNav:[{text:"Introduction",link:"developers/index.html"},{text:"Glossary",link:"glossary.html"},{text:"Architecture",link:"developers/arch.html"},{text:"Service Providers",items:[{text:"Getting Started",link:"developers/backends/getting-started.html"},{text:"UDFs",link:"developers/backends/udfs.html"}]},{text:"Client Developers",items:[{text:"Getting Started",link:"developers/clients/getting-started.html"},{text:"Library Guidelines",link:"developers/clients/library-guidelines.html"}]},{text:"API",items:[{text:"Specification",link:"developers/api/reference.html"},{text:"Further documentation",link:"developers/api/index.html"}]},{text:"Processes",link:"processes.html"},{text:"Error Codes",link:"developers/api/errors.html"},{text:"Examples",link:"developers/examples/"}]}],defaultVersion:0,docPath:"/documentation/1.0/",logo:"/images/openeo_navbar_logo.png",editLinks:!0,docsRepo:"Open-EO/openeo.org",algolia:{appId:"3J2STFK847",apiKey:"b12d6cb143c2ddadfa8989c962d1a049",indexName:"openeo"},nav:[{text:"Home",link:"/"},{text:"About",link:"/about.html"},{text:"News",link:"/news/"},{text:"Software",link:"/software.html"},{text:"Services / Hub",link:"https://hub.openeo.org"},{text:"User Documentation",userNav:!0,items:[]},{text:"Developers",devNav:!0,items:[]},{text:"PSC",link:"/psc.html"},{text:"Contact",link:"/contact.html"}],sidebar:"auto"}},Lt=n(148),It=Lt.themeConfig.versions[Lt.themeConfig.defaultVersion];"undefined"!=typeof window&&(window.global=window);n(149);r.a.component("ApiSpec",()=>n.e(39).then(n.bind(null,479))),r.a.component("Channels",()=>Promise.all([n.e(0),n.e(27)]).then(n.bind(null,480))),r.a.component("ErrorCodes",()=>n.e(19).then(n.bind(null,481))),r.a.component("InlineFrame",()=>Promise.all([n.e(0),n.e(28)]).then(n.bind(null,482))),r.a.component("News",()=>n.e(40).then(n.bind(null,483))),r.a.component("ProcessesSpec",()=>Promise.all([n.e(0),n.e(26)]).then(n.bind(null,484))),r.a.component("Badge",()=>Promise.all([n.e(0),n.e(4)]).then(n.bind(null,490)));n(150),n(151);r.a.component("CodeSwitcher",()=>n.e(53).then(n.bind(null,485)));var Dt=[({router:e,Vue:t})=>{t.config.ignoredElements=["redoc"],e.addRoutes([{path:"/documentation",redirect:It.path},{path:"/about",redirect:"about.html"},{path:"/software",redirect:"software.html"},{path:"/contact",redirect:"contact.html"},{path:"/glossary",redirect:It.path+"glossary.html"},{path:"/documentation/1.0/developers/backends/opendatacube.html",redirect:"/documentation/1.0/developers/backends/xarray.html"}])},{},({Vue:e})=>{e.mixin({computed:{$dataBlock(){return this.$options.__data__block__}}})},{},{},{},{},{},({Vue:e})=>{e.component("CodeCopy",$t)}],Nt=[];class Ft extends class{constructor(){this.store=new r.a({data:{state:{}}})}$get(e){return this.store.state[e]}$set(e,t){r.a.set(this.store.state,e,t)}$emit(...e){this.store.$emit(...e)}$on(...e){this.store.$on(...e)}}{}Object.assign(Ft.prototype,{getPageAsyncComponent:lt,getLayoutAsyncComponent:ct,getAsyncComponent:ut,getVueComponent:pt});var Jt={install(e){const t=new Ft;e.$vuepress=t,e.prototype.$vuepress=t}};function Bt(e,t){const n=t.toLowerCase();return e.options.routes.some(e=>e.path.toLowerCase()===n)}var Vt={props:{pageKey:String,slotKey:{type:String,default:"default"}},render(e){const t=this.pageKey||this.$parent.$page.key;return ft("pageKey",t),r.a.component(t)||r.a.component(t,lt(t)),r.a.component(t)?e(t):e("")}},zt={functional:!0,props:{slotKey:String,required:!0},render:(e,{props:t,slots:n})=>e("div",{class:["content__"+t.slotKey]},n()[t.slotKey])},qt={computed:{openInNewWindowTitle(){return this.$themeLocaleConfig.openNewWindowText||"(opens new window)"}}},Gt=(n(152),n(153),Object(jt.a)(qt,(function(){var e=this._self._c;return e("span",[e("svg",{staticClass:"icon outbound",attrs:{xmlns:"http://www.w3.org/2000/svg","aria-hidden":"true",focusable:"false",x:"0px",y:"0px",viewBox:"0 0 100 100",width:"15",height:"15"}},[e("path",{attrs:{fill:"currentColor",d:"M18.8,85.1h56l0,0c2.2,0,4-1.8,4-4v-32h-8v28h-48v-48h28v-8h-32l0,0c-2.2,0-4,1.8-4,4v56C14.8,83.3,16.6,85.1,18.8,85.1z"}}),this._v(" "),e("polygon",{attrs:{fill:"currentColor",points:"45.7,48.7 51.3,54.3 77.2,28.5 77.2,37.2 85.2,37.2 85.2,14.9 62.8,14.9 62.8,22.9 71.5,22.9"}})]),this._v(" "),e("span",{staticClass:"sr-only"},[this._v(this._s(this.openInNewWindowTitle))])])}),[],!1,null,null,null).exports),Wt={functional:!0,render(e,{parent:t,children:n}){if(t._isMounted)return n;t.$once("hook:mounted",()=>{t.$forceUpdate()})}};r.a.config.productionTip=!1,r.a.use(Ge),r.a.use(Jt),r.a.mixin(function(e,t,n=r.a){!function(e){e.locales&&Object.keys(e.locales).forEach(t=>{e.locales[t].path=t});Object.freeze(e)}(t),n.$vuepress.$set("siteData",t);const o=new(e(n.$vuepress.$get("siteData"))),a=Object.getOwnPropertyDescriptors(Object.getPrototypeOf(o)),i={};return Object.keys(a).reduce((e,t)=>(t.startsWith("$")&&(e[t]=a[t].get),e),i),{computed:i}}(e=>class{setPage(e){this.__page=e}get $site(){return e}get $themeConfig(){return this.$site.themeConfig}get $frontmatter(){return this.$page.frontmatter}get $localeConfig(){const{locales:e={}}=this.$site;let t,n;for(const r in e)"/"===r?n=e[r]:0===this.$page.path.indexOf(r)&&(t=e[r]);return t||n||{}}get $siteTitle(){return this.$localeConfig.title||this.$site.title||""}get $canonicalUrl(){const{canonicalUrl:e}=this.$page.frontmatter;return"string"==typeof e&&e}get $title(){const e=this.$page,{metaTitle:t}=this.$page.frontmatter;if("string"==typeof t)return t;const n=this.$siteTitle,r=e.frontmatter.home?null:e.frontmatter.title||e.title;return n?r?r+" | "+n:n:r||"VuePress"}get $description(){const e=function(e){if(e){const t=e.filter(e=>"description"===e.name)[0];if(t)return t.content}}(this.$page.frontmatter.meta);return e||(this.$page.frontmatter.description||this.$localeConfig.description||this.$site.description||"")}get $lang(){return this.$page.frontmatter.lang||this.$localeConfig.lang||"en-US"}get $localePath(){return this.$localeConfig.path||"/"}get $themeLocaleConfig(){return(this.$site.themeConfig.locales||{})[this.$localePath]||{}}get $page(){return this.__page?this.__page:function(e,t){for(let n=0;nn||(e.hash?!r.a.$vuepress.$get("disableScrollBehavior")&&{selector:decodeURIComponent(e.hash)}:{x:0,y:0})});!function(e){e.beforeEach((t,n,r)=>{if(Bt(e,t.path))r();else if(/(\/|\.html)$/.test(t.path))if(/\/$/.test(t.path)){const n=t.path.replace(/\/$/,"")+".html";Bt(e,n)?r(n):r()}else r();else{const n=t.path+"/",o=t.path+".html";Bt(e,o)?r(o):Bt(e,n)?r(n):r()}})}(n);const o={};try{await Promise.all(Dt.filter(e=>"function"==typeof e).map(t=>t({Vue:r.a,options:o,router:n,siteData:Mt,isServer:e})))}catch(e){console.error(e)}return{app:new r.a(Object.assign(o,{router:n,render:e=>e("div",{attrs:{id:"app"}},[e("RouterView",{ref:"layout"}),e("div",{class:"global-ui"},Nt.map(t=>e(t)))])})),router:n}}(!1).then(({app:e,router:t})=>{t.onReady(()=>{e.$mount("#app")})})}]); \ No newline at end of file diff --git a/contact.html b/contact.html index ec1411c0c..c76fb20c8 100644 --- a/contact.html +++ b/contact.html @@ -8,8 +8,8 @@ - - + +
- + diff --git a/documentation/0.4/developers/api/errors.html b/documentation/0.4/developers/api/errors.html index 81cfbb6a8..184d6e80c 100644 --- a/documentation/0.4/developers/api/errors.html +++ b/documentation/0.4/developers/api/errors.html @@ -8,8 +8,8 @@ - - + +
- + diff --git a/documentation/0.4/developers/api/index.html b/documentation/0.4/developers/api/index.html index 4cfdedbc1..51dc73fc7 100644 --- a/documentation/0.4/developers/api/index.html +++ b/documentation/0.4/developers/api/index.html @@ -8,8 +8,8 @@ - - + +
- + diff --git a/documentation/0.4/developers/api/reference.html b/documentation/0.4/developers/api/reference.html index ed93d098d..28d59ff56 100644 --- a/documentation/0.4/developers/api/reference.html +++ b/documentation/0.4/developers/api/reference.html @@ -8,8 +8,8 @@ - - + +
- + diff --git a/documentation/0.4/developers/arch.html b/documentation/0.4/developers/arch.html index 909a283ea..457f9712d 100644 --- a/documentation/0.4/developers/arch.html +++ b/documentation/0.4/developers/arch.html @@ -8,8 +8,8 @@ - - + +
- + diff --git a/documentation/0.4/developers/backends/getting-started.html b/documentation/0.4/developers/backends/getting-started.html index a891aa52c..092d6ce30 100644 --- a/documentation/0.4/developers/backends/getting-started.html +++ b/documentation/0.4/developers/backends/getting-started.html @@ -8,8 +8,8 @@ - - + +
- + diff --git a/documentation/0.4/developers/backends/udfs.html b/documentation/0.4/developers/backends/udfs.html index a6a98ed64..3c82b8c33 100644 --- a/documentation/0.4/developers/backends/udfs.html +++ b/documentation/0.4/developers/backends/udfs.html @@ -8,8 +8,8 @@ - - + +
- + diff --git a/documentation/0.4/developers/clients/getting-started.html b/documentation/0.4/developers/clients/getting-started.html index 751ef3b5d..8625fcacf 100644 --- a/documentation/0.4/developers/clients/getting-started.html +++ b/documentation/0.4/developers/clients/getting-started.html @@ -8,8 +8,8 @@ - - + +
- + diff --git a/documentation/0.4/developers/clients/library-guidelines.html b/documentation/0.4/developers/clients/library-guidelines.html index 679530ff7..9c2d86ebc 100644 --- a/documentation/0.4/developers/clients/library-guidelines.html +++ b/documentation/0.4/developers/clients/library-guidelines.html @@ -8,8 +8,8 @@ - - + +
- + diff --git a/documentation/0.4/developers/examples/index.html b/documentation/0.4/developers/examples/index.html index 2975d95ce..dc1e81fc3 100644 --- a/documentation/0.4/developers/examples/index.html +++ b/documentation/0.4/developers/examples/index.html @@ -8,8 +8,8 @@ - - + +
- + diff --git a/documentation/0.4/developers/examples/poc.html b/documentation/0.4/developers/examples/poc.html index 829f10540..446b59d0d 100644 --- a/documentation/0.4/developers/examples/poc.html +++ b/documentation/0.4/developers/examples/poc.html @@ -8,8 +8,8 @@ - - + +
- + diff --git a/documentation/0.4/developers/index.html b/documentation/0.4/developers/index.html index 7307a0512..240970135 100644 --- a/documentation/0.4/developers/index.html +++ b/documentation/0.4/developers/index.html @@ -8,8 +8,8 @@ - - + +
- + diff --git a/documentation/0.4/getting-started.html b/documentation/0.4/getting-started.html index 99a4b6ba1..7aaf3b3c0 100644 --- a/documentation/0.4/getting-started.html +++ b/documentation/0.4/getting-started.html @@ -8,8 +8,8 @@ - - + +
- + diff --git a/documentation/0.4/glossary.html b/documentation/0.4/glossary.html index 6d666731e..eeda084a5 100644 --- a/documentation/0.4/glossary.html +++ b/documentation/0.4/glossary.html @@ -8,8 +8,8 @@ - - + +
- + diff --git a/documentation/0.4/index.html b/documentation/0.4/index.html index a7d0a18c5..9c8d24103 100644 --- a/documentation/0.4/index.html +++ b/documentation/0.4/index.html @@ -8,8 +8,8 @@ - - + +
- + diff --git a/documentation/0.4/processes.html b/documentation/0.4/processes.html index b5730fd3d..8d077a382 100644 --- a/documentation/0.4/processes.html +++ b/documentation/0.4/processes.html @@ -8,8 +8,8 @@ - - + +
- + diff --git a/documentation/0.4/udfs.html b/documentation/0.4/udfs.html index 7e1c58906..03d2cfe71 100644 --- a/documentation/0.4/udfs.html +++ b/documentation/0.4/udfs.html @@ -8,8 +8,8 @@ - - + +
- + diff --git a/documentation/1.0/authentication.html b/documentation/1.0/authentication.html index 1e0108db7..ff5edad3b 100644 --- a/documentation/1.0/authentication.html +++ b/documentation/1.0/authentication.html @@ -8,8 +8,8 @@ - - + +
- + diff --git a/documentation/1.0/cookbook/index.html b/documentation/1.0/cookbook/index.html index fca0b8d6b..113ddbe40 100644 --- a/documentation/1.0/cookbook/index.html +++ b/documentation/1.0/cookbook/index.html @@ -8,8 +8,8 @@ - - + +
- + diff --git a/documentation/1.0/datacubes.html b/documentation/1.0/datacubes.html index ab21c49a9..ae8b71721 100644 --- a/documentation/1.0/datacubes.html +++ b/documentation/1.0/datacubes.html @@ -8,8 +8,8 @@ - - + +
- + diff --git a/documentation/1.0/datacubes/index.html b/documentation/1.0/datacubes/index.html index c5577bfe1..7e3e445bc 100644 --- a/documentation/1.0/datacubes/index.html +++ b/documentation/1.0/datacubes/index.html @@ -8,8 +8,8 @@ - - + +
- + diff --git a/documentation/1.0/developers/api/errors.html b/documentation/1.0/developers/api/errors.html index 86228f64a..4f35ed354 100644 --- a/documentation/1.0/developers/api/errors.html +++ b/documentation/1.0/developers/api/errors.html @@ -8,8 +8,8 @@ - - + +
- + diff --git a/documentation/1.0/developers/api/index.html b/documentation/1.0/developers/api/index.html index 09ca688e1..653fd3270 100644 --- a/documentation/1.0/developers/api/index.html +++ b/documentation/1.0/developers/api/index.html @@ -8,8 +8,8 @@ - - + +
- + diff --git a/documentation/1.0/developers/api/reference.html b/documentation/1.0/developers/api/reference.html index b5fbbcf6b..aa8917eae 100644 --- a/documentation/1.0/developers/api/reference.html +++ b/documentation/1.0/developers/api/reference.html @@ -8,8 +8,8 @@ - - + +
- + diff --git a/documentation/1.0/developers/arch.html b/documentation/1.0/developers/arch.html index 7fa3c25ba..97076df41 100644 --- a/documentation/1.0/developers/arch.html +++ b/documentation/1.0/developers/arch.html @@ -8,8 +8,8 @@ - - + +
- + diff --git a/documentation/1.0/developers/backends/getting-started.html b/documentation/1.0/developers/backends/getting-started.html index 3f8ad9bd5..693d1f3b6 100644 --- a/documentation/1.0/developers/backends/getting-started.html +++ b/documentation/1.0/developers/backends/getting-started.html @@ -8,8 +8,8 @@ - - + +
- + diff --git a/documentation/1.0/developers/backends/performance.html b/documentation/1.0/developers/backends/performance.html index 162c0896b..88585488e 100644 --- a/documentation/1.0/developers/backends/performance.html +++ b/documentation/1.0/developers/backends/performance.html @@ -8,8 +8,8 @@ - - + +
- + diff --git a/documentation/1.0/developers/backends/xarray.html b/documentation/1.0/developers/backends/xarray.html index 146001449..e52c509c8 100644 --- a/documentation/1.0/developers/backends/xarray.html +++ b/documentation/1.0/developers/backends/xarray.html @@ -8,8 +8,8 @@ - - + +
- + diff --git a/documentation/1.0/developers/clients/getting-started.html b/documentation/1.0/developers/clients/getting-started.html index 930f0730e..4e8ec217f 100644 --- a/documentation/1.0/developers/clients/getting-started.html +++ b/documentation/1.0/developers/clients/getting-started.html @@ -8,8 +8,8 @@ - - + +
- + diff --git a/documentation/1.0/developers/clients/library-guidelines.html b/documentation/1.0/developers/clients/library-guidelines.html index 9c04d3b4f..a2da8cfc6 100644 --- a/documentation/1.0/developers/clients/library-guidelines.html +++ b/documentation/1.0/developers/clients/library-guidelines.html @@ -8,8 +8,8 @@ - - + +
- + diff --git a/documentation/1.0/developers/index.html b/documentation/1.0/developers/index.html index 40bf719fd..7a4dcca7f 100644 --- a/documentation/1.0/developers/index.html +++ b/documentation/1.0/developers/index.html @@ -8,8 +8,8 @@ - - + +
- + diff --git a/documentation/1.0/developers/profiles/api.html b/documentation/1.0/developers/profiles/api.html index bfc49268b..a03eb90cd 100644 --- a/documentation/1.0/developers/profiles/api.html +++ b/documentation/1.0/developers/profiles/api.html @@ -8,8 +8,8 @@ - - + +
- + diff --git a/documentation/1.0/developers/profiles/index.html b/documentation/1.0/developers/profiles/index.html index f4888ba5a..6088fa0e5 100644 --- a/documentation/1.0/developers/profiles/index.html +++ b/documentation/1.0/developers/profiles/index.html @@ -8,8 +8,8 @@ - - + +
- + diff --git a/documentation/1.0/developers/profiles/processes.html b/documentation/1.0/developers/profiles/processes.html index 0cecb4e06..d5d8f8125 100644 --- a/documentation/1.0/developers/profiles/processes.html +++ b/documentation/1.0/developers/profiles/processes.html @@ -8,8 +8,8 @@ - - + +
- + diff --git a/documentation/1.0/glossary.html b/documentation/1.0/glossary.html index 5aa7e2953..4480bd2a6 100644 --- a/documentation/1.0/glossary.html +++ b/documentation/1.0/glossary.html @@ -8,8 +8,8 @@ - - + +
- + diff --git a/documentation/1.0/index.html b/documentation/1.0/index.html index 6a81a9855..df692a334 100644 --- a/documentation/1.0/index.html +++ b/documentation/1.0/index.html @@ -8,8 +8,8 @@ - - + +
- + diff --git a/documentation/1.0/javascript/index.html b/documentation/1.0/javascript/index.html index ed0276c6d..3b23eb85d 100644 --- a/documentation/1.0/javascript/index.html +++ b/documentation/1.0/javascript/index.html @@ -8,8 +8,8 @@ - - + +
- + diff --git a/documentation/1.0/processes.html b/documentation/1.0/processes.html index db1c564ae..42823b582 100644 --- a/documentation/1.0/processes.html +++ b/documentation/1.0/processes.html @@ -8,8 +8,8 @@ - - + +
- + diff --git a/documentation/1.0/python/client-side-processing.html b/documentation/1.0/python/client-side-processing.html index f241c5657..a28ca312e 100644 --- a/documentation/1.0/python/client-side-processing.html +++ b/documentation/1.0/python/client-side-processing.html @@ -8,8 +8,8 @@ - - + +
- + diff --git a/documentation/1.0/python/index.html b/documentation/1.0/python/index.html index 223ce1250..68c9c37b3 100644 --- a/documentation/1.0/python/index.html +++ b/documentation/1.0/python/index.html @@ -8,8 +8,8 @@ - - + +
- + diff --git a/documentation/1.0/qgis/index.html b/documentation/1.0/qgis/index.html index e856a4fc3..f04fe750a 100644 --- a/documentation/1.0/qgis/index.html +++ b/documentation/1.0/qgis/index.html @@ -8,8 +8,8 @@ - - + +
- + diff --git a/documentation/1.0/r/index.html b/documentation/1.0/r/index.html index dfc19c49b..a67f85ae2 100644 --- a/documentation/1.0/r/index.html +++ b/documentation/1.0/r/index.html @@ -8,8 +8,8 @@ - - + +
- + diff --git a/documentation/1.0/udfs.html b/documentation/1.0/udfs.html index 7378f293e..9f202738f 100644 --- a/documentation/1.0/udfs.html +++ b/documentation/1.0/udfs.html @@ -8,8 +8,8 @@ - - + +
- + diff --git a/documentation/code-of-conduct.html b/documentation/code-of-conduct.html index 65b7efa35..d1ff21c9e 100644 --- a/documentation/code-of-conduct.html +++ b/documentation/code-of-conduct.html @@ -8,8 +8,8 @@ - - + +
- + diff --git a/documentation/software-guidelines.html b/documentation/software-guidelines.html index a6eca7ee2..ddce27efb 100644 --- a/documentation/software-guidelines.html +++ b/documentation/software-guidelines.html @@ -8,8 +8,8 @@ - - + +
- + diff --git a/events/igarrs2021.html b/events/igarrs2021.html index 4b5037b03..d212292a8 100644 --- a/events/igarrs2021.html +++ b/events/igarrs2021.html @@ -8,8 +8,8 @@ - - + + - + diff --git a/news/2017-12-05-welcome.html b/news/2017-12-05-welcome.html index 1c511bba8..0414eb5cc 100644 --- a/news/2017-12-05-welcome.html +++ b/news/2017-12-05-welcome.html @@ -8,8 +8,8 @@ - - + + - + diff --git a/news/2017-12-18-VITO_meeting.html b/news/2017-12-18-VITO_meeting.html index 7aa8830c2..a24c59321 100644 --- a/news/2017-12-18-VITO_meeting.html +++ b/news/2017-12-18-VITO_meeting.html @@ -8,8 +8,8 @@ - - + +
- + diff --git a/news/2018-01-31-WWU_meeting.html b/news/2018-01-31-WWU_meeting.html index 3c411e42a..9cc1e4712 100644 --- a/news/2018-01-31-WWU_meeting.html +++ b/news/2018-01-31-WWU_meeting.html @@ -8,8 +8,8 @@ - - + +
- + diff --git a/news/2018-03-15-poc.html b/news/2018-03-15-poc.html index a944257a5..bc69d2e9d 100644 --- a/news/2018-03-15-poc.html +++ b/news/2018-03-15-poc.html @@ -8,8 +8,8 @@ - - + +
- + diff --git a/news/2018-05-23-user-requirements-survey-launched.html b/news/2018-05-23-user-requirements-survey-launched.html index 5c7550bb5..12f43d511 100644 --- a/news/2018-05-23-user-requirements-survey-launched.html +++ b/news/2018-05-23-user-requirements-survey-launched.html @@ -8,8 +8,8 @@ - - + +
- + diff --git a/news/2018-10-30-year-one-review-meeting.html b/news/2018-10-30-year-one-review-meeting.html index 172de395f..06e556416 100644 --- a/news/2018-10-30-year-one-review-meeting.html +++ b/news/2018-10-30-year-one-review-meeting.html @@ -8,8 +8,8 @@ - - + +
- + diff --git a/news/2019-03-07-openeo-api-040.html b/news/2019-03-07-openeo-api-040.html index e2461182d..465ac7f19 100644 --- a/news/2019-03-07-openeo-api-040.html +++ b/news/2019-03-07-openeo-api-040.html @@ -8,8 +8,8 @@ - - + +
- + diff --git a/news/2019-10-07-EO-big-data-hackaton.html b/news/2019-10-07-EO-big-data-hackaton.html index 4b4fe4f94..5d8f3729c 100644 --- a/news/2019-10-07-EO-big-data-hackaton.html +++ b/news/2019-10-07-EO-big-data-hackaton.html @@ -8,8 +8,8 @@ - - + +
- + diff --git a/news/2020-07-31-lessons-learned.html b/news/2020-07-31-lessons-learned.html index f4f6ef140..4aa877cbe 100644 --- a/news/2020-07-31-lessons-learned.html +++ b/news/2020-07-31-lessons-learned.html @@ -8,8 +8,8 @@ - - + +
- + diff --git a/news/2020-07-31-openeo-api-released.html b/news/2020-07-31-openeo-api-released.html index 21d1ef199..a3a962466 100644 --- a/news/2020-07-31-openeo-api-released.html +++ b/news/2020-07-31-openeo-api-released.html @@ -8,8 +8,8 @@ - - + +
- + diff --git a/news/2020-09-02-openeo-user-workshop.html b/news/2020-09-02-openeo-user-workshop.html index 5dd00c8b7..5b8d12c2d 100644 --- a/news/2020-09-02-openeo-user-workshop.html +++ b/news/2020-09-02-openeo-user-workshop.html @@ -8,8 +8,8 @@ - - + +
- + diff --git a/news/2020-11-30-openeo-api-101-released.html b/news/2020-11-30-openeo-api-101-released.html index f526a7f69..9d5bea5ce 100644 --- a/news/2020-11-30-openeo-api-101-released.html +++ b/news/2020-11-30-openeo-api-101-released.html @@ -8,8 +8,8 @@ - - + + - + diff --git a/news/2021-05-17-openeo-api-110-released.html b/news/2021-05-17-openeo-api-110-released.html index 39001091d..fc952b719 100644 --- a/news/2021-05-17-openeo-api-110-released.html +++ b/news/2021-05-17-openeo-api-110-released.html @@ -8,8 +8,8 @@ - - + + - + diff --git a/news/2021-11-08-r-client-on-cran.html b/news/2021-11-08-r-client-on-cran.html index 94eb8a6f2..771c8ffb5 100644 --- a/news/2021-11-08-r-client-on-cran.html +++ b/news/2021-11-08-r-client-on-cran.html @@ -8,8 +8,8 @@ - - + +
- + diff --git a/news/2022-04-08-psc-meetings.html b/news/2022-04-08-psc-meetings.html index d97008e54..f738ba755 100644 --- a/news/2022-04-08-psc-meetings.html +++ b/news/2022-04-08-psc-meetings.html @@ -8,8 +8,8 @@ - - + +
- + diff --git a/news/2022-05-12-r-client-v120.html b/news/2022-05-12-r-client-v120.html index 39920be22..b5c3cf8f0 100644 --- a/news/2022-05-12-r-client-v120.html +++ b/news/2022-05-12-r-client-v120.html @@ -8,8 +8,8 @@ - - + +
- + diff --git a/news/2022-07-07-monthly-dev-calls.html b/news/2022-07-07-monthly-dev-calls.html index f7a3220d1..01f8baa96 100644 --- a/news/2022-07-07-monthly-dev-calls.html +++ b/news/2022-07-07-monthly-dev-calls.html @@ -8,8 +8,8 @@ - - + + - + diff --git a/news/2022-11-17-r-client-v130.html b/news/2022-11-17-r-client-v130.html index 8d31b2c8a..c1cb7334d 100644 --- a/news/2022-11-17-r-client-v130.html +++ b/news/2022-11-17-r-client-v130.html @@ -8,8 +8,8 @@ - - + +
- + diff --git a/news/2023-05-25-new-openeo-versions-120-200rc1 copy.html b/news/2023-05-25-new-openeo-versions-120-200rc1 copy.html index ad7928058..619307ad7 100644 --- a/news/2023-05-25-new-openeo-versions-120-200rc1 copy.html +++ b/news/2023-05-25-new-openeo-versions-120-200rc1 copy.html @@ -8,8 +8,8 @@ - - + +
- + diff --git a/news/2023-12-06-openeo-submitted-to-ogc.html b/news/2023-12-06-openeo-submitted-to-ogc.html index 92944807b..c279a8d69 100644 --- a/news/2023-12-06-openeo-submitted-to-ogc.html +++ b/news/2023-12-06-openeo-submitted-to-ogc.html @@ -8,8 +8,8 @@ - - + +
- + diff --git a/news/2024-02-06-openeo-ogc-rfc.html b/news/2024-02-06-openeo-ogc-rfc.html index 8c01d59e6..95a50f4f3 100644 --- a/news/2024-02-06-openeo-ogc-rfc.html +++ b/news/2024-02-06-openeo-ogc-rfc.html @@ -8,8 +8,8 @@ - - + + - + diff --git a/news/2024-03-22_mooc_cubeandclouds.html b/news/2024-03-22_mooc_cubeandclouds.html index c0bbedfca..9f1cd92c9 100644 --- a/news/2024-03-22_mooc_cubeandclouds.html +++ b/news/2024-03-22_mooc_cubeandclouds.html @@ -8,8 +8,8 @@ - - + +
- + diff --git a/news/index.html b/news/index.html index 9a9ff8ae2..2d0ceabdc 100644 --- a/news/index.html +++ b/news/index.html @@ -8,8 +8,8 @@ - - + +
- + diff --git a/psc.html b/psc.html index 39fca5997..d7d52ea67 100644 --- a/psc.html +++ b/psc.html @@ -8,8 +8,8 @@ - - + +
- + diff --git a/software.html b/software.html index 2dde2c6e5..2515925f8 100644 --- a/software.html +++ b/software.html @@ -8,8 +8,8 @@ - - + +