-
Notifications
You must be signed in to change notification settings - Fork 9
/
Copy pathIVOAArchitecture.tex
1437 lines (1269 loc) · 55.2 KB
/
IVOAArchitecture.tex
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
504
505
506
507
508
509
510
511
512
513
514
515
516
517
518
519
520
521
522
523
524
525
526
527
528
529
530
531
532
533
534
535
536
537
538
539
540
541
542
543
544
545
546
547
548
549
550
551
552
553
554
555
556
557
558
559
560
561
562
563
564
565
566
567
568
569
570
571
572
573
574
575
576
577
578
579
580
581
582
583
584
585
586
587
588
589
590
591
592
593
594
595
596
597
598
599
600
601
602
603
604
605
606
607
608
609
610
611
612
613
614
615
616
617
618
619
620
621
622
623
624
625
626
627
628
629
630
631
632
633
634
635
636
637
638
639
640
641
642
643
644
645
646
647
648
649
650
651
652
653
654
655
656
657
658
659
660
661
662
663
664
665
666
667
668
669
670
671
672
673
674
675
676
677
678
679
680
681
682
683
684
685
686
687
688
689
690
691
692
693
694
695
696
697
698
699
700
701
702
703
704
705
706
707
708
709
710
711
712
713
714
715
716
717
718
719
720
721
722
723
724
725
726
727
728
729
730
731
732
733
734
735
736
737
738
739
740
741
742
743
744
745
746
747
748
749
750
751
752
753
754
755
756
757
758
759
760
761
762
763
764
765
766
767
768
769
770
771
772
773
774
775
776
777
778
779
780
781
782
783
784
785
786
787
788
789
790
791
792
793
794
795
796
797
798
799
800
801
802
803
804
805
806
807
808
809
810
811
812
813
814
815
816
817
818
819
820
821
822
823
824
825
826
827
828
829
830
831
832
833
834
835
836
837
838
839
840
841
842
843
844
845
846
847
848
849
850
851
852
853
854
855
856
857
858
859
860
861
862
863
864
865
866
867
868
869
870
871
872
873
874
875
876
877
878
879
880
881
882
883
884
885
886
887
888
889
890
891
892
893
894
895
896
897
898
899
900
901
902
903
904
905
906
907
908
909
910
911
912
913
914
915
916
917
918
919
920
921
922
923
924
925
926
927
928
929
930
931
932
933
934
935
936
937
938
939
940
941
942
943
944
945
946
947
948
949
950
951
952
953
954
955
956
957
958
959
960
961
962
963
964
965
966
967
968
969
970
971
972
973
974
975
976
977
978
979
980
981
982
983
984
985
986
987
988
989
990
991
992
993
994
995
996
997
998
999
1000
\documentclass[11pt,letter]{ivoa}
%\documentclass[11pt,letter]{ivoatex/ivoa}
%\input tthdefs
\input ivoatex/tthdefs
\newcommand{\xtype}[1]{\texttt{#1}}
\usepackage{longtable}
\usepackage{listings}
\lstloadlanguages{XML,sh}
\lstset{flexiblecolumns=true,basicstyle=\small,tagstyle=\ttfamily}
\usepackage[utf8]{inputenc}
\usepackage{todonotes}
\usepackage{enumerate}
\usepackage[section]{placeins}
\title{IVOA Architecture}
\ivoagroup{Technical Coordination Group}
\author{Janet Evans}
\author{Marco Molinaro}
\author{Patrick Dowler}
\author{Christophe Arviset}
\author{Severin Gaudet}
\author{IVOA Technical Coordination Group}
\editor{Janet Evans, Marco Molinaro}
\previousversion{IVOAArchitecture-2.0-20211029}
\previousversion{IVOAArchitecture-1.0-20101123}
\begin{document}
\begin{abstract}
This note describes the technical architecture of the International
Virtual Observatory Alliance
(IVOA). The description is decomposed
into three levels. Level 0 is a general, high level summary of the IVOA
Architecture.
Level 1 provides more details about components and functionalities,
still without
being overly technical. Finally, Level 2 displays how the IVOA standards
fit into
the IVOA Architecture. This architecture enables the community of
resource providers to
implement the FAIR principles: Findable, Accessible, Interoperable, and
Reusable.
\end{abstract}
\section*{Acknowledgments}
\section{IVOA Architecture Level 0}
\begin{figure}[h]
\centering
\includegraphics[width=0.9\textwidth]{archdiag0.pdf}
\caption{IVOA Architecture Level 0}
\label{fig:architecture0}
\end{figure}
Astronomy produces large amounts of data of many kinds, coming from
various sources:
science space missions, ground based telescopes, theoretical models,
compilation of
results, etc. These data are usually managed by large data centres or
smaller teams
and they provide the scientific community with data and/or computing
services
through the Internet. This is the Resource Layer.
The ``consumers'' of these data and computing services, be it individual
researchers,
research teams or computer systems, interact with the User Layer.
The Virtual Observatory (VO) is the necessary ``middle layer'' framework
connecting the
Resource Layer to the User Layer in a seamless and transparent manner.
Like the web
which enables end users and machines to access documents and services
wherever and however they are stored, the VO enables the astronomical
scientific
community to access astronomical resources wherever and however they are
stored by
the astronomical data and services providers. The VO provides a
technical framework
for the providers to enable users to discover data collections and
services
(``Findable'') and to use them for science and public outreach
(``Accessible''). To
enable these functionalities in perpetuity, it defines some core
astronomically-oriented
standards so data from different providers can be combined
(``Interoperable'') to enable
new scientific discoveries (``Reusable'').
The IVOA Architecture uses terms ``Finding'', ``Getting'', ``Using'',
and ``Sharing``;
these are collectively equivalent to ``Findable'', ``Accessible'',
``Interoperable'', and
``Reusable'': the FAIR principles have always been the basis of the IVOA
Architecture
even before the term was formally coined \citep{Wilkinson2016}. The
world wide
astronomy community has long supported sharing and reusability of data
(e.g. through standards
like FITS \citep{std:FITS}). Within the IVOA community, interoperability
has been the cornerstone
of development of standards and the concepts of reusability and
interoperability go beyond
metadata and data as they also guide the development of standards for
applications, services,
and infrastructure for research, education, and public outreach.
\section{IVOA Architecture Level 1}
Level 1 of the IVOA architecture is an extension to the Level 0,
displaying more
details about the functionalities and building blocks within the
different layers.
For completeness, part of the description is repeated from the Level 0,
so the
Level 1 description can be used as a self-contained block.
\begin{figure}[ht]
\centering
\includegraphics[width=0.9\textwidth]{archdiag1.pdf}
\caption{IVOA Architecture Level 1}
\label{fig:architecture1}
\end{figure}
Astronomy produces large amounts of data of many kinds, coming from
various sources:
science space missions, ground based telescopes, theoretical models,
compilation
of results, etc. These data are usually managed by large data centres or
smaller teams. These providers provide the scientific community with
data and
computing services through the Internet. These resources provided can
be:
\begin{enumerate}
\item data collections (images, spectra, time series, theoretical
models, catalogues, etc.)
with their associated descriptive metadata and access services.
\item storage services for users and for processing
\item computing services to process data from data collections and from
users
\end{enumerate}
This is the Resource Layer.
The ``consumers'' of these data and computing services, be it individual
researchers,
research teams or computer systems, interact with the User Layer of the
IVOA architecture.
These interactions can be through browser based applications in a
typical web browser,
standalone desktop applications or scriptable applications that can be
used in interactive
and batch mode by a computer.
The Virtual Observatory is the necessary ``middle layer'' framework that
connects the
Resource Layer to the User Layer in a seamless and transparent manner.
Like the web
that enables end users and machines to access transparently documents
and services
wherever and however they are stored, the VO enables the astronomical
scientific community
to access astronomical resources wherever and however they are stored by
the astronomical
data and services providers. The VO provides a technical framework for
the providers and
the consumers to share their data and services (``Sharing''). Registries
function as the ``yellow
pages'' of the VO, collecting metadata about data resources and
information services into a
queryable database. Like the VO resources and services themselves, the
registry is also
distributed. Replicas exist around the network, both for redundancy and
for more specialized
collections. Access to data and metadata collections is available
through Data Access Protocols,
which specify a uniform way of getting data and metadata from various
different providers.
To allow these functionalities, the definition of some core
astronomically-oriented standards
(``VO Core'') is necessary. In particular, defining common formats and
data models and using
common semantics is required to have a uniform and common description of
astronomical datasets
so they can become interoperable and queryable through standard query
languages to enable cross
analysis amongst various datasets. Additional standards are required
within the User Layer to enable
user authentication to proprietary datasets and storage elements as well
as interoperability amongst
VO applications (``Using'').
\section{IVOA Architecture Level 2}
Level 2 of the IVOA Architecture is similar to the Level 1, but adds all
the IVOA
standards in their corresponding layer. Some standards have already been
approved
and recommended (blue boxes with an outer line) while others are still a
work in progress
(blue boxes without an outer line).
\begin{figure}[ht]
\centering
\includegraphics[width=0.9\textwidth]{archdiag2.pdf}
\caption{IVOA Architecture Level 2}
\label{fig:architecture2}
\end{figure}
Note that this list (and standard status) will naturally evolve with
time. Driven by
science use cases and implementation experience, existing standards will
be updated and
new standards will be identified and added to that
Fig.~\ref{fig:architecture2}.
The following sections of this document provide a summary description of
each current standard,
including a description of where it fits in the overall IVOA
architecture along with links with
other IVOA standards. The links
(arrows) in the diagrams below indicate a ``used by'' dependency:
readers wanting to
understand the full scope of a standard will also need to review the
other standards
represented in each box of the diagrams.
The standards shown in blue boxes are the subject of the section;
boxes in light gray can be found in a different section/diagram.
In some cases, green boxes are used to show external standards that
provide an
important or notable part of the IVOA standard.
A white rounded box around several standards indicates a group of
standards that share
dependencies (to simplify the diagrams).
\section{Authentication and Authorization}
Authentication is a process by which you verify that someone is who they
claim they
are. Authorization is the process of establishing if the user (who is
already authenticated),
is permitted to have access to a resource. The authentication and
authorization architecture
is primarily an endorsement of existing
industry standards and technologies that suit the use cases of the IVOA
community. The standards
in this area provide some recommendations and ``glue'' so that
participants (application
developers, metadata and data providers, and resource providers) can
easily implement interoperable
systems.
Authentication and authorization are generally orthogonal to other
standards and there are minimal
direct dependencies on them. Implementors of other standards (e.g.
Sec.~\ref{dal} and \ref{gws})
``combine'' these A \& A recommendations where necessary to support
local policies and requirements.
\begin{figure}[ht]
\centering
\includegraphics[width=0.28\textwidth]{ivoa-arch-auth.pdf}
\caption{Authentication and Authorization Standards and Dependencies}
\label{fig:authdeps}
\end{figure}
\subsection{SSO}
The Single-Sign-On (SSO) \citep{2017ivoa.spec.0524T} profile describes
authentication mechanisms. Approved client-server
authentication mechanisms are described for the IVOA single-sign-on
profile: No Authentication;
HTTP Basic Authentication; TLS with passwords; TLS with client
certificates; Cookies; Open
Authentication; Security Assertion Markup Language; OpenID. Normative
rules are given for
the implementation of these mechanisms, mainly by reference to
pre-existing standards.
\subsection{CDP}
The Credential Delegation Protocol (CDP) \citep{2010ivoa.spec.0218P}
allows a client program to delegate a user's credentials
to a service such that the service may make requests to other services
in the name of that
user. The protocol defines a REST service that works alongside other IVOA
services to enable
such a delegation in a secure manner. In addition to defining the
specifics of the service
protocol, the standard document describes how a delegation service is
registered in an IVOA registry
along with the services it supports. The specification also explains how
one can determine
from a service registration that it requires the use of a supporting
delegation service.
\subsection{GMS}
The Group Membership Service (GMS) \citep{2022ivoa.spec.0222M}
specification describes a service interface for determining
whether a user is a member of a group. Membership information can be
used to protect access to
proprietary resources. When an authorization decision is needed (whether
to grant or deny access
to a proprietary resource), a call to GMS can be made to see if the
requesting user is a member
of the group assigned to protect the resource in question. Examples of
proprietary resources are
wide ranging but include: observation data and metadata and scarce or
limited services and
infrastructure. Because this specification details how a single group
can protect multiple,
potentially distributed, resources, it allows for the representation of
teams with common
authorization rights. The members of such teams can span multiple
organizations but can be
managed within a single service. In this way, GMS offers an
interoperable, flexible, and
scalable mechanism for sharing proprietary assets with a potentially
dynamic set of team members.
\section{Application and Format Standards}
Application and Format Standards are focused on standards that support
data formats and
protocols that enable astronomy software tools to interoperate and
communicate. IVOA
members have recognised that building a monolithic tool that attempts to
fulfil all the
requirements of all users is impractical, and it is a better use of our
limited resources
to enable individual tools to work together better. One element of this
is defining
common file formats for the exchange of data between different
applications. Another
important component is a messaging system that enables the applications
to share data
and take advantage of each other's functionality.
\begin{figure}[ht]
\centering
\includegraphics[width=0.48\textwidth]{ivoa-arch-apps.pdf}
\caption{Application and Format Standards and Dependencies}
\label{fig:appsdeps}
\end{figure}
\subsection{HiPS}
Hierarchical Progressive Survey (HiPS) \citep{2017ivoa.spec.0519F} is a
hierarchical scheme for the description, storage and
access of sky survey data. The system is based on hierarchical tiling of
sky regions at
finer and finer spatial resolution which facilitates a progressive view
of a survey, and
supports multi-resolution zooming and panning. HiPS uses the HEALPix
tessellation of the
sky as the basis for the scheme and is implemented as a simple file
structure with a direct
indexing scheme that leads to practical implementations.
\subsection{MOC}
The Multi-Order Coverage Map (MOC) \citep{2022ivoa.spec.0727F} is a
method to specify coverage as an arbitrary sky regions.
The goal is to be able to provide a very fast comparison mechanism
between coverage maps.
The mechanism is based on the HEALPix sky tessellation algorithm. It is
essentially a
simple way to map regions of the sky into hierarchically grouped
predefined cells.
\subsection{VOTable}
The VOTable \citep{2019ivoa.spec.1021O} format is an XML standard for
the interchange of data represented as a set of tables.
In this context, a table is an unordered set of rows, each of a uniform
structure, as specified
in the table description (the table metadata). Each row in a table is a
sequence of table cells,
and each of these contains either a primitive data type, or an array of
such primitives. VOTable
is derived from the Astrores format \citep{astrores}, itself modelled on
the FITS Table format
\citep{std:FITS}; VOTable was designed to be close to the FITS Binary
Table format.
\subsection{SAMP}
The Simple Application Messaging Protocol (SAMP)
\citep{2010ivoa.spec.1216B} is a messaging protocol that enables
astronomy
software tools to interoperate and communicate. SAMP supports
communication between
applications on the desktop and in web browsers, and is also intended to
form a framework
for more general messaging requirements.
\section{Semantics Standards}
An interoperable data infrastructure needs common languages in many
places: From common designations of units to labels for physical
quantities, from common names of reference frames and time scales to
mutually understandable subject categories, from relationship types
between VO resources
(``this service publishes images from A and spectra from B'') to fixed names
for the messengers that produced the signals recorded.
The VO's semantics standards provide the basis of forming such
consensual ``vocabularies'', which are, at their root, sets of labeled
concepts (which in turn are sets of entities clients deal with). We
also take care that, wherever possible, our vocabularies are
interoperable with the rest of the semantic web by adopting the W3C's
Resource Description Framework RDF.
The vocabularies themselves are usually introduced by standards that use
them and are then maintained on the VO's repository of
vocabularies\footnote{\url{http://www.ivoa.net/rdf}}. In some cases,
however, we go beyond RDF, usually because the labels have an intrinsic
syntax. In these cases, the Semantics WG issues separate standards
defining how to build and interpret these labels. Currently, this is
the case for unit strings and for the Unified Content Descriptors
discussed below.
\begin{figure}[ht]
\centering
\includegraphics[width=0.32\textwidth]{ivoa-arch-semantics.pdf}
\caption{Semantics Standards and Dependencies}
\label{fig:semdeps}
\end{figure}
\subsection{Vocabularies}
Vocabularies in the VO \citep{2023ivoa.spec.0206D} describes how to
build and use
consensus vocabularies in the Virtual Observatory. It supports both
``soft'' vocabularies based on the Simple Knowledge Organisation System
SKOS and ``hard'' vocabularies based on RDF schema, where the latter
organise their concepts in strict trees. The ``hard'' vocabularies
enable simple inference with relatively little effort on the side of
the clients. An example could be ``give me all links giving auxiliary
data for the current dataset'' in datalink, where vocabulary-aware
clients will also return links tagged as weight maps, errors, or noise
estimates.
This standard also details the maintenance of the VO's vocabulary
repository, in particular as regards adding vocabularies or concepts
within them.
\subsection{VOUnits}
VOUnits \citep{2023ivoa.spec.1215G} describes how to serialise unit
strings within the Virtual
Observatory, in particular (but by no means limited to) in the
\xmlel{unit} attribute in VOTable. It hence defines the atomic units,
prefixes applicable, and the syntax of expressions using such prefixed
atomic units.
An important design goal was consistency with other standards (BIPM,
ISO/IEC and the IAU) that are relevant in the astronomical community.
The intention is that units written to conform to VOUnits will likely
also be parsable by other well-known parsers.
\subsection{UCD}
Unified Content Descriptors (UCD) \citep{2019ivoa.spec.1007G} are a way
to
denote astronomical data
quantities. The UCD formalism first defines a list of ``atoms'', in
effect a controlled vocabulary with a hierarchy implied through dots
(e.g., \ucd{pos} denotes positions, \ucd{pos.eq} equatorial positions);
this list is currently maintained as an Endorsed Note
\citep{2023ivoa.spec.0125C}.
The atoms can then be combined into more complex labels containing
qualifications. For instance, \ucd{phot.mag;em.opt.V} denotes a
magnitude in the V band, \ucd{phot.flux;em.opt.V} a flux in the same
band. The UCD standard defines how these compound UCDs are built, and
the UCD list defines restrictions as to where in complete UCDs atoms can be
used: some atoms can only be ``primary'', others are only available
as qualifiers. For instance, \ucd{stat.error} can only appear at the
start of a UCD, which ensures that ``Error in redshift'' will be encoded
as \ucd{stat.error;src.redshift} rather than the other way round.
The UCD ecosystem is completed by another standard on how new atoms are
adopted to the list of UCDs.
\section{Registry Standards}
The IVOA Registry provides a mechanism with which VO applications can
discover and select
resources that are relevant for a particular scientific problem. The VO
specification defines
the operation of this system. It is based on a general, distributed
model composed of searchable
and publishing registries. There are three components: (a) an interface
for harvesting publishing
registries, which builds upon the Open Archives Initiative Protocol for
Metadata Harvesting.
(b) A VOResource extension for registering registry services and
description of a central list
of said IVOA registry services. (c) A Registry of Registries as the root
component of data discovery
in the VO.
\begin{figure}[ht]
\centering
\includegraphics[width=0.70\textwidth]{ivoa-arch-registry.pdf}
\caption{Registry Standards and Dependencies}
\label{fig:regdeps}
\end{figure}
There are a number of standards associated with the registry to enable
registration and discovery
of services in the Registry. Figure \ref{fig:regdeps} shows how various
Registry standards relate to each other.
\subsection{Identifier}
An IVOA Resource Identifier (or IVOA identifier or IVOA ID for short)
\citep{2016ivoa.spec.0523D} is a globally unique reference
to a resource represented in a compact, ASCII-text format. An IVOA
identifier MUST always refer to
a resource that has been registered with an IVOA-compliant registry;
that is, it should be possible
to use the ID to get a description of the resource from a compliant
registry somewhere in the VO
environment.
\subsection{VOResource}
VOResource \citep{2018ivoa.spec.0625P} describes an encoding standard
for IVOA Resource Metadata. The primary intended use of
VOResource is to provide an XML interchange format for use with resource
registries. A registry is
a repository of resource descriptions and is employed by users and
applications to discover resources.
VOResource can be used to pass descriptions from publishers to
registries and then from registries to
applications. Another intended use is as a language for services to
describe themselves directly.
\subsection{VODataService}
The VODataService \citep{2021ivoa.spec.1102D} standard makes discovery
possible. It is an encoding standard that enables one to
describe how the data underlying the resource covers the sky as well as
their frequency and time.
VODataService also enables detailed descriptions of tables that include
information useful to the
discovery of tabular data.
\subsection{Registry Interface}
The Registry Interface \citep{2018ivoa.spec.0723D} defines the
interfaces that support interactions between applications and
registries as well as between the registries themselves. It is based on
a general, distributed
model composed of searchable and publishing registries. The
specification has two main components:
(a) an interface for searching and (b) an interface for harvesting.
Finally, the Registry Interface
details the metadata used to describe registries themselves as resources
using an extension of the
VOResource metadata schema.
\subsection{Resource Metadata}
The Resource Metadata \citep{2007ivoa.spec.0302H} standard represents
the essential capability to describe what data and
computational facilities are available where, and once identified, how
to use them. The data
themselves have associated metadata (e.g., FITS keywords), and similarly
we require metadata
about data collections and data services so that VO users can easily
find information of interest.
\subsection{RegTAP}
The Registry Relational Schema for Table Access Protocol (RegTAP)
\citep{2019ivoa.spec.1011D} provides a mechanism
with which VO applications can discover and select resources - first and
foremost data and services
- that are relevant for a particular scientific problem. This
specification defines an interface
for searching this resource metadata based on the IVOA's TAP protocol.
It specifies a set of tables
that comprise a useful subset of the information contained in the
registry records, as well as the
table's data content in terms of the XML VOResource data model. The
general design of the system
is geared towards allowing easy authoring of queries.
\subsection{SimpleDALRegExt}
Describing Simple Data Access Services (SimpleDALRegExt)
\citep{2022ivoa.spec.0222D}
is part of the registry standards that make discovery of Simple DAL
services
possible (e.g., SIAP, SCS, SSAP, SLAP). SimpleDALRegExt refers to an
encoding standard for a
specialized extension of the IVOA Resource Metadata that is useful for
describing VO Simple DAL
Services. By registering a VO Application in a Registry, it gets a
unique IVOA Resource
Identifier which then can be referred to by other applications and
services.
\subsection{StandardsRegExt}
The Standards registry extension (StandardsRegExt)
\citep{2012ivoa.spec.0508H} is part of the registry standards that make
discovery of VO Standards possible.
StandardsRegExt refers to an encoding standard for a specialized
extension of the IVOA Resource
Metadata that is useful for describing a VO Standard. By registering an
IVOA Standard in a
Registry, it gets a unique IVOA Resource Identifier which then can be
referred to in other
resource descriptions, namely for services that support the standard.
\subsection{TAPRegExt}
The Table Access Protocol registry extension (TAPRegExt)
\citep{2012ivoa.spec.0827D} is part of the registry standards that make
discovery of VO TAP Services possible.
TAPRegExt refers to an encoding standard for a specialized extension of
the IVOA Resource Metadata
that is useful for describing VO Applications. By registering a VO TAP
Service in a Registry, it
gets a unique IVOA Resource Identifier which then can be referred to by
other applications and
services. In the context of registering TAP services, an important role
filled by TAPRegExt is
the communication of supported data models to the registry.
\section{Data Model Standards}
The key element for achieving interoperability among actors sharing data
is the definition
of shared standard data models. Shared data models enable rich and
robust information sharing
between heterogeneous providers and users through a standard structure,
semantics, and formats;
data models are the foundation for this exchange.
\begin{figure}[ht]
\centering
\includegraphics[width=0.62\textwidth]{ivoa-arch-dm.pdf}
\caption{Data Model Standards and Dependencies}
\label{fig:dmdeps}
\end{figure}
\subsection{VO-DML}
The VO Data Modelling Language (VO-DML) \citep{2018ivoa.spec.0910L}
defines a standard modelling language, or meta-model, for
expressing data models in the IVOA. Adopting such a uniform language for
all models allows
these to be used in a homogeneous manner and allows a consistent
definition of reuse of one
model by another. The particular language defined here includes a
consistent identification
mechanism for model which allows these to be referenced in an explicit
and uniform manner
also from other contexts, in particular from other IVOA standard formats
such as VOTable.
The language defined in this specification is named VO-DML (VO Data
Modelling Language).
VO-DML is a conceptual modelling language that is agnostic of
serializations, or physical
representations. This allows it to be designed to fit as many purposes
as possible. VO-DML
is directly based on UML, and can be seen as a particular representation
of a UML2 Profile.
VO-DML is restricted to describing static data structures and from UML
it only uses a subset
of the elements defined in its language for describing ``Class
Diagrams''. Its concepts can
be easily mapped to equivalent data modelling concepts in other
representations such as
relational databases, XML schemas and object-oriented computer
languages. VO-DML has a
representation as a simple XML dialect named VO-DML/XML that must be
used to provide the
formal representation of VO data models. VO-DML/XML aims to be concise,
explicit and
easy to parse and use in code that needs to interpret annotated data
sets. VO-DML as
described in this document is an example of a domain specific modelling
language, where the
domain here is defined as the set of data and meta-data structures
handled in the IVOA and
Astronomy at large. VO-DML provides a custom representation of such a
language and as a
side effect allows the creation and use of standards compliant data
models outside of the
IVOA standards context.
\subsection{MIVOT}
The Model Instances in VOTables (MIVOT) \citep{2023ivoa.spec.0620M}
defines a syntax to map VOTable data to any model serialized in VO-DML.
The annotation operates as a bridge between the data and the model. It
associates the column/param metadata from the VOTable to the data model
elements (class, attributes, types, etc.) of a standardized IVOA data
model, expressed in the Virtual Observatory Data Modeling Language (here
after VO-DML). It also brings up VOTable data or metadata that were
possibly missing in the table metadata. The data model elements are
grouped in an independent annotation block complying with the MIVOT XML
syntax. This annotation block is added as an extra resource element at
the top of the VOTable result resource. The MIVOT syntax allows to
describe a data structure as a hierarchy of classes. It is also able to
represent relations and composition between them. It can also build up
data model objects by aggregating instances from different tables of the
VOTable. Missing metadata can also be provided using MIVOT, for instance
by completing coordinate system description, or by providing curation
tracing. The annotation block is made of re-usable bricks that
facilitate the development of tools on both client and server sides. The
adopted design does not alter the original VOTable content. The backward
compatibility is preserved thanks to the limited impact of the
annotations on legacy clients.
\subsection{CharDM}
The Characterisation Data Model (CharDM) \citep{2008ivoa.spec.0325L}
defines the high level metadata necessary to describe the
physical parameter space of observed or simulated astronomical data
sets, such as 2D-images,
data cubes, X-ray event lists, and IFU data. This model is an
abstraction which can be used
to derive a structured description of any relevant data and thus to
facilitate its discovery
and scientific interpretation. The model aims at facilitating the
manipulation of heterogeneous
data in any VO framework or portal. A VO Characterisation instance can
include descriptions of
the data axes, the range of coordinates covered by the data, and details
of the data sampling
and resolution on each axis. These descriptions should be in terms of
physical variables,
independent of instrumental signatures as far as possible.
\subsection{ObsCoreDM}
The Observation Data Model Core Components (ObsCoreDM)
\citep{2017ivoa.spec.0509L} specifies the metadata that are necessary to
perform data
discovery when querying data centers for astronomical observations of
interest. It exposes
use-cases to be carried out, explains the model and provides guidelines
for its implementation
as a data access service based on the Table Access Protocol (TAP). It
aims at providing a
simple model easy to understand and to implement by data providers that
wish to publish their
data into the Virtual Observatory. This interface integrates data
modelling and data access
aspects in a single service named ObsTAP that will be referenced as such
in the IVOA
registries. The Observation Data Model Core Components (ObsCoreDM)
defines
the core components of queryable metadata required for global discovery
of observational data.
It is meant to allow a single query to be posed to TAP services at
multiple sites to perform
global data discovery without having to understand the details of the
services present at each
site. It defines a minimal set of basic metadata and thus allows a
reasonable cost of
implementation by data providers. As with most of the VO Data Models,
ObsCoreDM makes use of STC, Utypes,
VOUnits and UCDs. The ObsCoreDM can be serialized as a VOTable.
ObsCoreDM makes reference
to more complete data models such as Characterisation DM, Spectrum DM or
Simple Spectral Line
Data Model (SSLDM). The current specification on the contrary provides
guidelines for
implementing these concepts using the TAP protocol and answering ADQL
queries. It is
dedicated to global discovery.
\subsection{PhotDM}
The Photometry Data Model (PhotDM) \citep{2022ivoa.spec.1101S} describes
photometry filters, photometric systems, magnitude
systems, zero points and its interrelation with the other IVOA data
models through a
simple data model. Particular attention is given necessarily to optical
photometry where
specifications of magnitude systems and photometric zero points are
required to convert
photometric measurements into physical flux density units.
\subsection{ProvenanceDM}
The Provenance Data Model \citep{2020ivoa.spec.0411S} describes how
provenance information can be modelled, stored
and exchanged within the astronomical community in a standardized way.
We follow the
definition of provenance as proposed by the W3C, i.e. that ``provenance
is information
about entities, activities, and people involved in producing a piece of
data or thing,
which can be used to form assessments about its quality, reliability or
trustworthiness''.
Such provenance information in astronomy is important to enable any
scientist to trace
back the origin of a dataset (e.g. an image, spectrum, catalog or single
points in a
spectral energy distribution diagram or a light curve), a document (e.g.
an article, a
technical note) or a device (e.g. a camera, a telescope), learn about
the people and
organizations involved in a project and assess the reliability, quality
as well as the
usefulness of the dataset, document or device for her own scientific
work.
\subsection{SimDM}
The Simulation Data Model (SimDM) \citep{2012ivoa.spec.0503L} describes
numerical computer simulations of astrophysical systems.
The primary goal of this standard is to support discovery of simulations
by describing those
aspects of them that scientists might wish to query on, i.e. it is a
model for meta-data
describing simulations. This document does not propose a protocol for
using this model.
IVOA protocols are being developed and are supposed to use the model,
either in its original
form or in a form derived from the model proposed here, but more suited
to the particular protocol.
\subsection{SSLDM}
The Simple Spectral Lines Data Model (SSLDM) \citep{2010ivoa.spec.1209O}
describes spectral line transitions. The main objective of
the model is to integrate with and support the Simple Line Access
Protocol, with which it forms
a compact unit. This integration allows seamless access to Spectral Line
Transitions available
worldwide in the VO context. This model does not provide a complete
description of Atomic and
Molecular Physics, which scope is outside of this document. In the
astrophysical sense, a line
is considered as the result of a transition between two energy levels.
Under the basis of this
assumption, a whole set of objects and attributes have been derived to
define properly the
necessary information to describe lines appearing in astrophysical
contexts.
\subsection{SpectralDM}
The Spectral Data Model \citep{2023ivoa.spec.1215C} describes the
structure of spectrophotometric datasets with spectral and
temporal coordinates and associated metadata. This data model may be
used to represent spectra,
time series data, segments of SED (Spectral Energy Distributions) and
other spectral or temporal
associations.
\subsection{VOEvent}
The VOEvent model \citep{2011ivoa.spec.0711S} defines the content and
meaning of a standard information packet for
representing, transmitting, publishing and archiving information about a
transient celestial
event, with the implication that timely follow-up is of interest. The
objective is to motivate
the observation of targets-of-opportunity, to drive robotic telescopes,
to trigger archive
searches, and to alert the community. VOEvent is focused on the
reporting of photon events,
but events mediated by disparate phenomena such as neutrinos,
gravitational waves, and solar
or atmospheric particle bursts may also be reported.
Structured data is used, rather than natural language, so that automated
systems can effectively
interpret VOEvent packets. Each packet may contain zero or more of the
``who, what, where, when, how''
of a detected event, but in addition, may contain a hypothesis (a
``why'') regarding the nature of
the underlying physical cause of the event. Citations to previous
VOEvents may be used to place
each event in its correct context. Proper curation is encouraged
throughout each event's life
cycle from discovery through successive follow-ups. VOEvent packets gain
persistent identifiers
and are typically stored in databases reached via registries. VOEvent
packets may therefore
reference other packets in various ways. Packets are encouraged to be
small and to be processed
quickly. This standard does not define a transport layer or the design
of clients, repositories,
publishers or brokers; it does not cover policy issues such as who can
publish, who can build a
registry of events, who can subscribe to a particular registry, nor the
intellectual property issues.
\subsection{STC}
The Space-Time Coordinate (STC) \citep{2007ivoa.spec.1030R} metadata for
the Virtual Observatory describes the coordinate
axes of astronomical data. It details the various components, highlights
some implementation
considerations, presents a complete set of UML diagrams, and discusses
the relation between
STC and certain other parts of the Data Model. Two serializations are
discussed: XML (STC-X) and
ascii string (STC-S); the former is an integral part of the model.
\subsection{Coordinates}
The Coordinates Data Model \citep{2022ivoa.specQ1004R}
covers the following concepts: description of single and
multi-dimensional
coordinate space and coordinates within that space, coordinate frames
providing metadata describing the
origin and orientation of the coordinate space, the definition of simple
domain-specific coordinate
types for the most common use cases, and description of the coordinate
systems domain space. This
model is a refactored subset of the original STC data model.
\subsection{Measurements}
The Measurements Data Model \citep{2022ivoa.spec.1004R}
covers the description of measured or determined astronomical data
to enable the association of the determined ``value'' with corresponding
errors. In this model,
the ``value'' is given by the various coordinate types of the
coordinates data model plus a
description of the error model. This model is a refactored subset of the
original STC data model.
\subsection{ObsLocTAP}
The Observation Locator Table Access Protocol (ObsLocTAP)
\citep{2021ivoa.spec.0724S}
defines a data model for scheduled observations
and a method to run queries over compliant data, using several Virtual
Observatory technologies.
The data model builds on the ObsCore data model, removing elements
associated with dataset
access that are not available during the planning phase. In this way,
this standard is focused
on access to metadata related to the planning of a certain observatory,
more than on access to
the scientific data products. Also, the data model will be focused on
discovery of planned
observations, which is very useful information for multi-wavelength
coordination observations,
re-planning information propagation, follow-up of Targets of Opportunity
alerts, preparation
of proposals, etc. As with ObsCore, a serialisation into a relational
table is defined, which
allows users to run complex queries using the IVOA Table Access
Protocol. The document also
prescribes how to register and discover ObsLocTAP services.
\section{Data Access Standards}
\label{dal}
The data access standards define APIs for querying and accessing data
holdings.
These standards are primarily implemented by data providers so that the
community
can use agreed and shared tools to interact with the data holdings.
As shown in Fig.~\ref{fig:daldeps}, the interconnection of data
access standards is quite complicated, even without showing the general
VO landscape
dependencies. This is due to two main
factors: older standards not yet updated to rely on DALI
(Sec.~\ref{dal:dali})
and protocols providing \textit{simple access} (parametric query
solutions) to
\textit{relational tablesets} (also supported by TAP,
Sec.~\ref{dal:tap}).
Supporting the data access standards, we also have the following
standards and specific cases:
\begin{itemize}
\item ADQL: a SQL-based language to allow querying of relational
databases, including support for astronomy operations;
\item VTP: a specific transport protocol to broadcast VOEvent
messages;
\item SimDAL: a dedicated access protocol, using SimDM structure and