[Back to EML Contents](./index.html)

**Q:** What is EML?

**A:** EML stands for Ecological Metadata Language. It exists as a set
of XML Schema documents that allow for the structural expression of
metadata necessary to document a typical data set in the ecological
sciences.

**Q:** Who is responsible for EML?

**A:** The first two released versions of EML, EML 1.0 and EML 1.4.1
were developed at the National Center for Ecological Analysis and
Synthesis (NCEAS), University of California at Santa Barbara, in Santa
Barbara, California USA. The effort to produce EML 2.x (and all of the
beta releases preceding it) is organized through the EML Project, an
open source, community oriented project dedicated to providing a
high-quality metadata specification for describing data relevant to the
ecological discipline. The project is completely comprised of [voluntary
project members](https://raw.github.com/NCEAS/eml/master/members.md) who
donate their time and experience in order to advance information
management for ecology. Project decisions are made by consensus
according to the voting procedures described in the [ecoinformatics.org
Charter](http://www.ecoinformatics.org/charter.html). Significant
contributions for these recent releases have come from individuals at
NCEAS, the Long Term Ecological Research Program (CAP, NET, KBS, JRN),
and the Joseph W. Jones Ecological Research Center in Newton, GA.

**Q:** Why would I want to use EML when FGDC now supports biological
data through the CSDGM?

**A:** EML is modular and extensible.

**A:** The Content Standard for Digital Geospatial Metadata (CSDGM)
developed by the Federal Geographic Data Committee (FGDC) is a
monolithic standard, and so it is difficult to mix and match parts of it
with other standards -- mainly because of all of the spatial
requirements. So, we built EML as a series of modules that can be linked
together and can be linked to other metadata standards. This gives us
the most flexibility, and given that we can easily translate into CSDGM
compliant documents, there is little cost. Second, we're building
advanced data processing tools that can automatically parse data sets
and analyze them based on the EML metadata descriptions. Due to various
shortcomings in the FGDC standard, mostly oriented around its tight
focus on spatial data, we have found that the CSDGM isn't adequate for
these needs, e.g., how can one add machine parsable, semantically
oriented attribute tags to CSDGM? Answer, you can't, because it is
monolithic and doesn't permit dynamic ties to other metadata specs --
the only extension method is via the administrative challenge of
creating a superset of the CSDGM -- not very maintainable. In addition,
the level of granularity for metadata in FGDC is very patchy -- it goes
into great detail for spatial projections, etc., but is incredibly terse
with respect to describing methods and non-standard data formats. This
is appropriate in the spatial world where there are few data formats
(< 100, many sensor derived streams), but not so good in ecology
where there is no standardization of data formats (>>>5000,
very few sensor derived).

**Q:** Is there documentation for EML in English?

**A:** Yes, there is a [formal specification](index.html) of EML
describing its development history, architecture, and modules. The
intent of each module is described in narrative and there is a technical
description of each module in XML notation. Included as part of the
technical description is an element-by-element description of the
module. We will eventually provide examples on usage.

**Q:** Why is EML such an important development?

**A:** The last decade has witnessed a tremendous explosion of
ecological and environmental data, catalyzed by societal concerns and
facilitated by advancing technologies. These data have the potential to
greatly enhance understanding of the complexity of the biosphere.
However, broad-scale or synthetic research is stymied because data are
largely unorganized and inaccessible as a consequence of their
tremendous heterogeneity, complexity, and spatial dispersion in many
separate repositories. EML is the first content standard designed
specifically to address these issues for ecological data. Wide adoption
and use of EML will create exciting new opportunities for data
discovery, access, integration and synthesis.

**Q:** How do I get EML?

**A:** All the documents associated with the EML development effort are
available via the project web server at
<http://knb.ecoinformatics.org/software/eml/>. These projects are
licensed under the GPL (Gnu Public License) agreement and can be freely
distributed and modified.

**Q:** The EML Schema documents are quite complex. An average ecologist
probably cannot and more likely does not want to mark up content in an
XML editor. How then do you get content into EML?

**A:** The Knowledge Network for Biocomplexity project has developed a
software client specifically to address this need.
[Morpho](http://knb.ecoinformatics.org/software/) (after the butterfly
genus) is written in java (making portable across computer platforms)
combines an easy to use interface to EML with a number of tools to make
it easier for ecologists to document data. These include a
reverse-engineering wizard. Morpho is available from
<http://knb.ecoinformatics.org/software>. Morpho currently supports the
EML 2.1.0 release.

**Q:** EML contains provisions for communication. Is it possible to
document in EML dynamic online data resources?

**A:** Yes, there are provisions in the eml-physical module for
descriptions of online data resources. The eml-physical module describes
the structural characteristics of data formats as delivered over the
wire or as found in a file system. One physical object (which can be a
bytestream or an object in a file system) might contain multiple
entities (for example, this would be typical in a MS Access file that
contained multiple tables of data). However, it is typically used to
describe a file or stream that is in some text-based format such as
ASCII or UTF-8, and includes the information needed to parse the data
stream to extract the entity and its attributes from the stream. There
are 3 distribution types, online, offline, and inline. To describe an
online dataset in EML you would populate the online element with the
distribution information.

**Q:** Do I need to download special software to use EML?

**A:** No, but there is software available to work with EML. See [FAQ
7](#id.7) .

**Q:** How can I get my existing metadata into EML?

**A:** There are several approaches that can be used to convert existing
metadata into EML depending on what form your existing metadata take.

-   Case 1: If your metadata is currently in a text format (not stored
    in a database) use the following conversion methods.

    1.  Write a script (PERL, PHP, JAVA, etc.) to convert the text into
        EML compliant XML.

    2.  Convert the text metadata into XHTML (HTML that is XML
        compliant). Write an XSLT script to transform the XHTML file
        into EML compliant XML.

    3.  Use an special purpose XML editor that generates EML (
        [Morpho](http://knb.ecoinformatics.org/software) or
        [Xylographa](http://ces.asu.edu/bdi/Subjects/xylographa) ) and
        manually retype the metadata.

    4.  Use a general purpose XML development tool such as XML Spy that
        can create a sample document from an XML Schema and retype the
        metadata manually.

    5.  Use a simple text editor and do everything from scratch.

    6.  Use specialized data transformation software such as the Data
        Junction suite to extract text data and then map it into an EML
        structure.

-   Case 2: If your metadata is stored in a relational database use the
    following conversion methods.

    1.  Both Microsoft SQL Server and Oracle have utilities to generate
        XML from their database. If you use a tool like that, then you
        will have to write an XSLT script to transform the generated XML
        into EML.

    2.  Use a vendor neutral Database-to-XML generator such as
        [Cocoon](http://cocoon.apache.org/) (an Apache open source free
        tool). Cocoon can query the database, generate XML, and has a
        tool for creating the XSL Transformation scripts to convert the
        first stage XML output into EML format.

    3.  Use a specialized tool such as
        [Xanthoria](http://ces.asu.edu/bdi/Subjects/Xanthoria/) (like
        Cocoon in may respects, but is easier to use) to generate XML
        from the database. Then use a tool such as XML Spy or Stylus
        Studio to develop the XSLT script to convert the generated XML
        into EML compliant XML.

    4.  Use specialized data transformation software such as the Data
        Junction query the database and map it into an EML structure.

-   Case 3: If your metadata is already in XML but in some other form
    such as NBII or FGDC use the following conversion method.

    1.  Write an XSLT script to convert from the current format to EML
        (e.g. FGDC to EML).

NOTE: In each of the cases it may be necessary to add some additional
metadata in order to produce EML compliant documents.
[Morpho](http://knb.ecoinformatics.org/software) will automatically
create EML compliant metadata either by adding it for you or indicating
that certain fields are mandatory.

**Q:** Once I convert my metadata into EML, what do I do with it? If I
am storing all my metadata in text-based EML files, how am I supposed to
query them or use them for data management?

**A:** EML is an exchange standard for communication of metadata but it
can be used as the framework for a data management system.
[Metacat](http://knb.ecoinformatics.org/software) is a multipurpose XML
metadata and data repository that is optimized for use with EML. If you
store your metadata in a relational database management system or plan
to then there are also solutions.
[Cocoon](http://xml.apache.org/cocoon/) and
[Xanthoria](http://ces.asu.edu/bdi/Subjects/Xanthoria/) are examples of
programs that can get EML out of an RDBMS. Cocoon and Xanthoria are both
java applications that use java database connection hooks and style
sheets to retrieve and format data. Xanthoria is a light-weight solution
and the XSLT stylesheets for EML 2.0 have already been written. This
solution lets a site stick with the RDBMS system that they probably have
integrated with their site management activities, yet also have their
metadata exposed via EML.

**Q:** Does the modularity of EML mean that one description can be
shared by many documents?

**A:** In a previous version, EML packages (via RDF like triples)
supported linking across packages, so you could re-use the same document
in multiple packages. In EML 2.0.0 Release Candidate 1 we redesigned the
packaging structure to only allow linking within a single package. Thus,
one could re-use a party description or attribute list within a package,
but not across several. This is a compromise that keeps some reusability
but has fewer management problems. Along with this change is an ability
to put all metadata and data in a single document for transport -- while
still not limiting ourselves to a monolithic structure. This has
benefits (akin to db normalization) and costs (access control,
ownership, and multiple update problems).

**Q:** How are EML modules linked together?

**A:** With "id" attributes and "references" elements in each module.
Certain modules within EML allow you to identify specific sub-trees with
a unique identifier (id). This identifier can then be used in place of
content in other parts of the EML document by placing it in a
"references" element.

**A:** Our general approach in EML has been to create ComplexTypes (CT)
when we wanted a particular block to be reusable. This concept was
extended for linking modules together by adding an optional attribute
named "id" of type "xs:string" for each ComplexType. This allows us to
uniquely address each block defined by a CT. For the "ResourceBase" CT,
this id element replaces the "identifier" element and acts as the
overall identifier for the package. The content model for each CT is a
choice between the existing content model and a new element named
"references" of type "xs:string". This element is used to hold a
reference to an existing sub-tree identified by its id. This
relationship between the "references" element and the "id" identifiers
is enforced by defining a "key" for the "id" elements and a "keyref" for
the "references" elements. This use of a key and keyref differs slightly
from the XML Schema case because in XML Schema, keys can not be null,
whereas we want people to be able to optionally omit the "id" attribute.
Consequently, we have incorporated the rules about the correspondence
between keys and keyrefs into the EML specification, but not into the
schemas directly. Thus, in order to validate that an EML document is
valid EML, you must use a parser that understands the referencing system
in EML and can check that it is used correctly. An example system that
handles this key validation is shipped with the EML distribution (see
the "EML Parser"). Here's a fragment of an example xml doc to
illustrate:

```xml
<creator id="id.p1">
  <individualName><surName>Jones</surName></individualName>
</creator>
<associatedParty>
  <references>id.p1</references>
  <role>lackey</role>
</associatedParty>
<contact>
  <references>id.p1</references>
</contact>
```            

This even works for types that extend other types as long as the
subclass is the one that does the referencing (e.g., associatedParty can
reference creator, but not vice versa).

**Q:** Can I put data into EML as well as metadata?

**A:** Yes, there are provisions in the eml-physical module for
inclusion of data. The module describes the structural characteristics
of data formats as delivered over the wire or as found in a file system.
One physical object (which can be a bytestream or an object in a file
system) might contain multiple entities (for example, this would be
typical in a MS Access file that contained multiple tables of data).
However, it is typically used to describe a file or stream that is in
some text-based format such as ASCII or UTF-8, and includes the
information needed to parse the data stream to extract the entity and
its attributes from the stream. There are 3 distribution types, online,
offline, and inline. To include data in EML you would populate the
inline element with the data file described in the data format element.
The data that is in the inline element should conform to the description
provided by the eml-physical module. Binary data files can be included
using Base64 encoding.

**Q:** What can I do with my EML structured metadata?

**A:** Tools are currently being developed to allow automated
heterogeneous data integration, analytical processing and quality
testing based on EML metadata. In general, using a metadata standard
such as EML will lessen your data entropy and make it more useful to you
and others in the future.

**Q:** Can I validate my EML documents against the DTD?

**A:** No. As of EML 2.0.0 we are no longer creating DTDs as part of the
EML release. Only [XML Schemas](http://www.w3.org/XML/Schema) will be
released. Even then, there are some EML rules which are not expressible
in XML Schema and for which you must use a specialized validator, such
as the "EML Parser" that ships with the distribution.

**Q:** Are there required elements in EML?

**A:** Yes, although we've made every attempt to limit required elements
in the cause of flexibility there are a number of pieces of information
required to make sense of the metadata document. To make the metadata
more useful we do have recommended usages on the modules. See
specification for details about required fields and recommended usage.
In the future we may provide usage compliance information such that if
you want your data and metadata to be useful in a particular analytical
context you will be provided with those elements of EML that are
required for that purpose.

**Q:** There appear to be multiple places to put some types of metadata
in EML. How do I know which of these places is the right place for my
information?

**A:** The [EML Specification](index.html) describes each element in a
detailed normative manner. EML is hierarchical so where you use
different elements is very important. For instance, if you use a
TemporalCoverage element and reference it to a dataset element, you are
saying that that entire dataset took place during that time. If,
instead, you reference it to a dataTable, you are saying that only that
table was covered by that time period. You must gauge exactly what you
are trying to describe in the structure that you are using. Questions
about possible bugs in the definitions of elements can be posed via
email to the [eml-dev mailing list](mailto:eml-dev@ecoinformatics.org)

**Q:** The differences between "method" and "protocol" seem to be very
subtle in EML. How do I distinguish between the two?

**A:** The eml-methods module describes the methods followed in the
creation of the dataset being described, including description of field,
laboratory and processing steps, sampling methods and units, quality
control procedures. The eml-methods module is used to describe the
"actual" procedures that are used in the creation or the subsequent
processing of a dataset. Likewise, eml-methods is used to describe
processes that have been used to define / improve the quality of a data
file, or to identify potential problems with the data file. The
eml-protocol module is intended to be used to document a "prescribed"
procedure, whereas the eml-method module is used to describe procedures
that were actually performed. The distinction is that the use of the
term "protocol" is used in the "prescriptive" sense, and the term
"method" is used in the "descriptive" sense. This distinction allows
managers to build a protocol library of well-known, established
protocols (procedures), but also document what procedure was truly
performed in relation to the established protocol. The method may have
diverged from the protocol purposefully, or perhaps incidentally, but
the procedural lineage is still preserved and understandable.

The eml-methods module, like other modules, may be referenced via the
&lt;references&gt; tag. This allows a method to be described once, and
then used as a reference in other locations within the EML document via
it's ID.

**Q:** How can 'references' be treated in XSLT transformations of EML?

**A:** XSLT can be used to transform EML to other formats, but the
treatment of 'references' elements is somewhat complicated. A text file
describing the details of one method for handling the 'references'
elements is available at
<http://knb.ecoinformatics.org/software/eml/eml-2.0.1/references_XSLT.txt>

**Q:** How do the elements of the Dublin Core Metadata Initiative map
onto EML?

**A:** EML attempts to capture the metadata elements of the Dublin Core
in its specification, while still maintaining the flexibility to be able
to document the full range of ecological resources. More detailed
information on the representation of the Dublin Core elements in EML can
be found at
<http://knb.ecoinformatics.org/software/eml/eml-2.0.1/eml-dublinCore.html>

**Q:** I'm interested in contributing to EML. Can I?

**A:** We welcome contributions to this work in any form. Individuals
who invest substantial amounts of time and make valuable contributions
to the development and maintenance of EML (in the opinion of current
project members) will be invited to become EML project members according
to the rules set forth in the [ecoinformatics.org
Charter](http://www.ecoinformatics.org/charter.html). Contributions can
take many forms, including the development of the EML schemas, writing
documentation, and helping with maintenance, among others.

You can contact the [eml-dev mailing
list](mailto:eml-dev@ecoinformatics.org) if you would like to make a
contribution in person-hours to this project and would like to discuss
how that might occur. In general, we want all of the help we can get!

**Q:** Where can I get EML?

**A:** You can download archived releases from
<http://knb.ecoinformatics.org/software/eml/> or you can check out the
latest development version from [GitHub](https://github.com/NCEAS/eml/)
server.

**Q:** How is EML 2.1.0 different from EML 2.0.0/1, and how do I upgrade
my documents?

**A:** There are several improvements to EML in version 2.1.0 -- too
many to put here. For more information, see the EML 2.1.0 Information
page: [Information for EML 2.1.0 Document Authors.](./eml-210info.html)
That page also contains instructions for using the transformation
stylesheet that comes with EML2.1.0 to convert v2.0.0/1 documents to
v2.1.0.