Skip to main content

Create your first GLDF

Overview

In this step-by-step guide, we will create a simple GLDF file.

Prerequisites

  • You need to know how to pack and unpack ZIP archives.
  • You need a Text or XML Editor. Please see Requirements for recommendations and more information.

Structure of a GLDF file

GLDF is a container and ZIP-Archive file, simply renamed from .zip to .gldf. It contains the main product.xml file in the root directory, with all manufacturer and product information. And associated files like images, photometries and more in subdirectories (called Assets). To learn more about the GLDF container and its structure, please see About GLDF Container.

Preparation

To create your first gldf file, follow these steps:

  • Create a root directory named product
  • Create an empty XML file named product.xml and place it in this root directory.
    We will edit this file further below.
  • Create three subdirectories named geo, image, and ldc.
  • Download the Eulumdat photometry and store it in the ldc directory.
  • Download the L3D geometry and store it in the geo directory.
  • Download the PNG image and store it in the image directory.

Your directory should look like this now:

GLDF directory structure with subdirectories

The product.xml file

The heart of a GLDF file is the product.xml file, located in the root of the zip archive. It contains all the manufacturer and product information written in XML. The GLDF XML Schema (XSD) defines the exact structure of the XML code in product.xml. You can validate your XML file against this XSD to ensure your GLDF has no errors.

At top level, GLDF XML begins with a Root element, which in turn contains three child elements:

  • Header
  • GeneralDefinitions
  • ProductDefinitions

Please see XML hierarchy for more information.

Step 1: Basic XML structure

The following example highlights the Root element mentioned above, with its three child elements Header, GeneralDefinitions and ProductDefinitions. Open the just created product.xml file in your favorite text editor and add the following code. Most elements are empty or contain placeholder text at this stage. We will gradually expand them further below.

<?xml version="1.0" encoding="UTF-8"?>
<Root xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:noNamespaceSchemaLocation="https://gldf.io/xsd/gldf/1.0.0-rc.3/gldf.xsd">
<Header>
<Manufacturer>Your Coompany Name</Manufacturer>
<FormatVersion major="1" minor="0" pre-release="3" />
<CreatedWithApplication>Your Code Editor</CreatedWithApplication>
<GldfCreationTimeCode>2023-10-23T16:30:00Z</GldfCreationTimeCode>
<UniqueGldfId>Your unique Gldf Id</UniqueGldfId>
</Header>
<GeneralDefinitions>
<!-- No general definitions yet -->
</GeneralDefinitions>
<ProductDefinitions>
<ProductMetaData>
<UniqueProductId>Your unique Product Id</UniqueProductId>
<ProductNumber>
<Locale language="en"></Locale>
</ProductNumber>
<Name>
<Locale language="en"></Locale>
</Name>
</ProductMetaData>
<Variants>
<Variant id="variant-1">
<Name>
<Locale language="en"></Locale>
</Name>
</Variant>
</Variants>
</ProductDefinitions>
</Root>

If you are using a code editor that supports XML Schema validation, you should now be able to validate the XML code against the XSD (see Requirements).

Step 2: Manufacturer Metadata

The first step for each GLDF is to define some metadata in the Header element. It contains information about the GLDF file itself and the manufacturer of the product. In this example, we will keep things simple and concentrate on only mandatory elements of the Header element. In a real GLDF, however, it is always advisable to specify further data, such as contact information and more. A complete description about the possible Header content is provided here.

For this example, let's assume we are working for the luminaire manufacturer ACME lighting and are writing this GLDF using the Visual Studio Code editor. The current GLDF version is 1.0-rc.3 and today is the 23rd of October. We generate a worldwide unique Id for this GLDF using the UUID Online Generator.

Replace your Header part in your product.xml with this concrete data:

<Header>
<Manufacturer>ACME lighting</Manufacturer>
<FormatVersion major="1" minor="0" pre-release="3" />
<CreatedWithApplication>Visual Studio Code</CreatedWithApplication>
<GldfCreationTimeCode>2023-10-23T16:30:00Z</GldfCreationTimeCode>
<UniqueGldfId>159248fe-2ec4-4021-b68f-42ce491b8edf</UniqueGldfId>
</Header>
info

The meaning and importance of UniqueGldfId is described here: Unique Ids.

General Definitions

GLDF is based on a modular structure. You define blocks of the same kind of information first, which successively build on each other. For example, information about the required photometries are defined first, which then can be used in the description of lamps to describe them photometrically. A lamp in turn can be combined with the description of a ballast later. To finally describe a light output of the luminaire. Once defined, many elements can be reused this way, even mutiple times.

In the next steps, we will gradually define some of these parts as childs of the GeneralDefinitions element. And use them later in the product definitions section to form the final luminaire.

Step 3: Add Files

First, we will add Files to the GeneralDefinitions section. To use our downloaded Eulumdat file, product picture and the geometry model, we need to declare these files for later reference. We have three files, that means we need to add three File elements to the Files collection.

Replace

<!-- No general definitions yet -->

with these lines:

<Files>
<File id="ldtFile-1" contentType="ldc/eulumdat"
type="localFileName">photometry.ldt</File>
<File id="pictureFile-1" contentType="image/png"
type="localFileName">luminaire.png</File>
<File id="geometryFile-1" contentType="geo/l3d"
type="localFileName">geometry.l3d</File>
</Files>

Step 4: Add Photometry

Next, we add a Photometry definition with a LuminousEfficacy of 98.2 and define the CIE-Flux code as 44 75 94 100 100. Add these lines below the last ones you added in the last step:

<Photometries>
<Photometry id="photometry-1">
<PhotometryFileReference fileId="ldtFile-1" />
<DescriptivePhotometry>
<LuminousEfficacy>98.2</LuminousEfficacy>
<CIE-FluxCode>44 75 94 100 100</CIE-FluxCode>
</DescriptivePhotometry>
</Photometry>
</Photometries>

Step 5: Add LightSource

Now, we will add a FixedLightSource with a Name and a Description, both translated into English and German. It has a rated input power of 10.2 (W), a color rendering index of 90, and a color temperature of 2700 (K). We provide also the lifetime in hours and add maintenance factor information.

<LightSources>
<FixedLightSource id="fixedLightSource-1">
<Name>
<Locale language="en">LED 10W</Locale>
<Locale language="de">LED 10W</Locale>
</Name>
<Description>
<Locale language="en">Warm white</Locale>
<Locale language="de">Warmweiß</Locale>
</Description>
<RatedInputPower>10.2</RatedInputPower>
<ColorInformation>
<ColorRenderingIndex>90</ColorRenderingIndex>
<CorrelatedColorTemperature>2700</CorrelatedColorTemperature>
</ColorInformation>
<LightSourceMaintenance lifetime="50000">
<LedMaintenanceFactor hours="25000">0.94</LedMaintenanceFactor>
</LightSourceMaintenance>
</FixedLightSource>
</LightSources>

Step 6: Add ControlGear

Next we add a ControlGear with a Name and Description. We will also set some useful power properties.

<ControlGears>
<ControlGear id="controlGear-1">
<Name>
<Locale language="en">LED driver</Locale>
<Locale language="de">LED Vorschaltgerät</Locale>
</Name>
<Description>
<Locale language="en">LED driver 15W</Locale>
<Locale language="de">LED Vorschaltgerät 15W</Locale>
</Description>
<StandbyPower>0.7</StandbyPower>
<ConstantLightOutputStartPower>10.2</ConstantLightOutputStartPower>
<ConstantLightOutputEndPower>14.7</ConstantLightOutputEndPower>
<PowerConsumptionControls>0.8</PowerConsumptionControls>
</ControlGear>
</ControlGears>
tip

You can always check the Overview of Units if you are unsure about the input.

Step 7: Add Emitter

Now we will combine the previously defined parts in an Emitter. It can later be referenced via its id emitter-1. In the same way, we are referencing the Photometry, LightSource, and ControlGear elements via their ids. We will also set the luminous flux to 1000.

<Emitters>
<Emitter id="emitter-1">
<FixedLightEmitter>
<PhotometryReference photometryId="photometry-1" />
<LightSourceReference fixedLightSourceId="fixedLightSource-1" />
<ControlGearReference controlGearId="controlGear-1" />
<RatedLuminousFlux>1000</RatedLuminousFlux>
</FixedLightEmitter>
</Emitter>
</Emitters>

Step 8: Add Geometry

Finally, we will define a Geometry section that will reference our L3D file from the file definitions.

<Geometries>
<ModelGeometry id="geometry-1">
<GeometryFileReference fileId="geometryFile-1" />
</ModelGeometry>
</Geometries>

Current XML

Now that we have defined all the blocks inside GeneralDefinitions, our XML should look like this:

<?xml version="1.0" encoding="UTF-8"?>
<Root xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:noNamespaceSchemaLocation="https://gldf.io/xsd/gldf/1.0.0-rc.3/gldf.xsd">
<Header>
<Manufacturer>ACME lighting</Manufacturer>
<FormatVersion major="1" minor="0" pre-release="3" />
<CreatedWithApplication>Your Code Editor</CreatedWithApplication>
<GldfCreationTimeCode>2023-10-23T16:30:00Z</GldfCreationTimeCode>
<UniqueGldfId>Your unique Gldf Id</UniqueGldfId>
</Header>
<GeneralDefinitions>
<Files>
<File id="ldtFile-1" contentType="ldc/eulumdat"
type="localFileName">photometry.ldt</File>
<File id="pictureFile-1" contentType="image/png"
type="localFileName">luminaire.png</File>
<File id="geometryFile-1" contentType="geo/l3d"
type="localFileName">geometry.l3d</File>
</Files>
<Photometries>
<Photometry id="photometry-1">
<PhotometryFileReference fileId="ldtFile-1" />
<DescriptivePhotometry>
<LuminousEfficacy>98.2</LuminousEfficacy>
<CIE-FluxCode>44 75 94 100 100</CIE-FluxCode>
</DescriptivePhotometry>
</Photometry>
</Photometries>
<LightSources>
<FixedLightSource id="fixedLightSource-1">
<Name>
<Locale language="en">LED 10W</Locale>
<Locale language="de">LED 10W</Locale>
</Name>
<Description>
<Locale language="en">Warm white</Locale>
<Locale language="de">Warmweiß</Locale>
</Description>
<RatedInputPower>10.2</RatedInputPower>
<ColorInformation>
<ColorRenderingIndex>90</ColorRenderingIndex>
<CorrelatedColorTemperature>3000</CorrelatedColorTemperature>
</ColorInformation>
<LightSourceMaintenance lifetime="50000">
<LedMaintenanceFactor hours="25000">0.94</LedMaintenanceFactor>
</LightSourceMaintenance>
</FixedLightSource>
</LightSources>
<ControlGears>
<ControlGear id="controlGear-1">
<Name>
<Locale language="en">LED driver</Locale>
<Locale language="de">LED Vorschaltgerät</Locale>
</Name>
<Description>
<Locale language="en">LED driver 15W</Locale>
<Locale language="de">LED Vorschaltgerät 15W</Locale>
</Description>
<StandbyPower>0.7</StandbyPower>
<ConstantLightOutputStartPower>10.2</ConstantLightOutputStartPower>
<ConstantLightOutputEndPower>14.7</ConstantLightOutputEndPower>
<PowerConsumptionControls>0.8</PowerConsumptionControls>
</ControlGear>
</ControlGears>
<Emitters>
<Emitter id="emitter-1">
<FixedLightEmitter emergencyBehaviour="None">
<PhotometryReference photometryId="photometry-1" />
<LightSourceReference fixedLightSourceId="fixedLightSource-1" />
<ControlGearReference controlGearId="controlGear-1" />
<RatedLuminousFlux>1000</RatedLuminousFlux>
</FixedLightEmitter>
</Emitter>
</Emitters>
<Geometries>
<ModelGeometry id="geometry-1">
<GeometryFileReference fileId="geometryFile-1" />
</ModelGeometry>
</Geometries>
</GeneralDefinitions>
<ProductDefinitions>
<ProductMetaData>
<UniqueProductId>Your unique Product Id</UniqueProductId>
<ProductNumber>
<Locale language="en"></Locale>
</ProductNumber>
<Name>
<Locale language="en"></Locale>
</Name>
</ProductMetaData>
<Variants>
<Variant id="variant-1">
<Name>
<Locale language="en"></Locale>
</Name>
</Variant>
</Variants>
</ProductDefinitions>
</Root>

Product Definitions

Now that we have defined all the necessary "general parts", the next goal is to assemble them into a complete luminaire. In the ProductDefinitions section, we combine these building blocks we defined in the GeneralDefinitions section into a final product. The product definitions consists of two child elements:

  • ProductMetadata
    ProductMetadata defines global product information that applies to all variants of a GLDF. Instead of defining information multiple times for each variant, you can set the information in the global ProductMetadata instead.
  • Variants
    Variants are considered variations of a given product but not entirely different products. If your product comes in different variations like color or mounting types, you can create several variants for each version.
Warning

Do not misuse variants to combine completely unrelated products in a single GLDF file.

Step 9: Add ProductMetadata

First, likewise for the UniqueGldfId in step 2, we generate for UniqueProductId a worldwide unique product Id using the UUID Online Generator. But this time not to identify this single GLDF file, but to identify the product inside it.

<UniqueProductId>ffaeabab-f040-4a61-a6d1-e879d8f2e374</UniqueProductId>

In contrast to the UniqueGldfId, which should be generated anew for each GLDF every time, the UniqueProductId should be generated only once per product. And then reused for that product across GLDF files, should you distribute updates of it. It is also possible to simply use your product number for UniqueProductId. However, ensure, that it is really unique and doesn't change during the lifetime of your products.

We also define a product number and a product name, again translated into English and German. Finally, we add the previously defined image, and label it as a Product Picture.

Replace your ProductMetaData with the following code:

<ProductMetaData>
<UniqueProductId>ffaeabab-f040-4a61-a6d1-e879d8f2e374</UniqueProductId>
<ProductNumber>
<Locale language="en">42</Locale>
<Locale language="de">42</Locale>
</ProductNumber>
<Name>
<Locale language="en">Pendant luminaire</Locale>
<Locale language="de">Pendelleuchte</Locale>
</Name>
<Description>
<Locale language="en">Round pendant light for indoor spaces</Locale>
<Locale language="de">Runde Pendelleuchte für Innenräume</Locale>
</Description>
<Pictures>
<image imageType="Product Picture" fileId="pictureFile-1" />
</Pictures>
</ProductMetaData>

Step 10: Add a Variant

Last but not least, we will combine all the previously prepared building blocks into a Variant. Again, we add a simple Name and Description first.

The core of each Variant is the Geometry element. It combines the radiation emitting parts (light sources and sensors) with the 3D geometry of the luminaire. There are three ways in which the geometry can be represented in the GLDF:

  • The simplest case is to use the simple geometry of the photometry file
  • Another possibility is to define a simple geometry in the form of a cuboid or cylinder in the GLDF. And thus to overwrite the 3D model of the photometry.
  • The most elegant way is to provide your own 3D model with it - see 3D Introduction

In our example, we create one Variant of our luminaire. We reference the previously created Geometry and combine this it with the previously created light Emitter. Finally, we hav to tell applications, to which surface they have to attach this light emitter. In our model, this surface was named leo.

<Variant id="variant-1">
<Name>
<Locale language="en">Pendant luminaire</Locale>
<Locale language="de">Pendelleuchte</Locale>
</Name>
<Description>
<Locale language="en">Description of variant 2</Locale>
<Locale language="de">Beschreibung der Variante 2</Locale>
</Description>
<Geometry>
<ModelGeometryReference geometryId="geometry-1">
<EmitterReference emitterId="emitter-1">
<EmitterObjectExternalName>leo</EmitterObjectExternalName>
</EmitterReference>
</ModelGeometryReference>
</Geometry>
</Variant>

Step 11: Finishing up

The final XML code should look like this:

<?xml version="1.0" encoding="UTF-8"?>
<Root xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:noNamespaceSchemaLocation="https://gldf.io/xsd/gldf/1.0.0-rc.3/gldf.xsd">
<Header>
<Manufacturer>ACME lighting</Manufacturer>
<FormatVersion major="1" minor="0" pre-release="3" />
<CreatedWithApplication>Visual Studio Code</CreatedWithApplication>
<GldfCreationTimeCode>2023-10-23T16:30:00Z</GldfCreationTimeCode>
<UniqueGldfId>159248fe-2ec4-4021-b68f-42ce491b8edf</UniqueGldfId>
</Header>
<GeneralDefinitions>
<Files>
<File id="ldtFile-1" contentType="ldc/eulumdat"
type="localFileName">photometry.ldt</File>
<File id="pictureFile-1" contentType="image/png"
type="localFileName">luminaire.png</File>
<File id="geometryFile-1" contentType="geo/l3d"
type="localFileName">geometry.l3d</File>
</Files>
<Photometries>
<Photometry id="photometry-1">
<PhotometryFileReference fileId="ldtFile-1" />
<DescriptivePhotometry>
<LuminousEfficacy>98.2</LuminousEfficacy>
<CIE-FluxCode>44 75 94 100 100</CIE-FluxCode>
</DescriptivePhotometry>
</Photometry>
</Photometries>
<LightSources>
<FixedLightSource id="fixedLightSource-1">
<Name>
<Locale language="en">LED 10W</Locale>
<Locale language="de">LED 10W</Locale>
</Name>
<Description>
<Locale language="en">Warm white</Locale>
<Locale language="de">Warmweiß</Locale>
</Description>
<RatedInputPower>10.2</RatedInputPower>
<ColorInformation>
<ColorRenderingIndex>90</ColorRenderingIndex>
<CorrelatedColorTemperature>3000</CorrelatedColorTemperature>
</ColorInformation>
<LightSourceMaintenance lifetime="50000">
<LedMaintenanceFactor hours="25000">0.94</LedMaintenanceFactor>
</LightSourceMaintenance>
</FixedLightSource>
</LightSources>
<ControlGears>
<ControlGear id="controlGear-1">
<Name>
<Locale language="en">LED driver</Locale>
<Locale language="de">LED Vorschaltgerät</Locale>
</Name>
<Description>
<Locale language="en">LED driver 15W</Locale>
<Locale language="de">LED Vorschaltgerät 15W</Locale>
</Description>
<StandbyPower>0.7</StandbyPower>
<ConstantLightOutputStartPower>10.2</ConstantLightOutputStartPower>
<ConstantLightOutputEndPower>14.7</ConstantLightOutputEndPower>
<PowerConsumptionControls>0.8</PowerConsumptionControls>
</ControlGear>
</ControlGears>
<Emitters>
<Emitter id="emitter-1">
<FixedLightEmitter>
<PhotometryReference photometryId="photometry-1" />
<LightSourceReference fixedLightSourceId="fixedLightSource-1" />
<ControlGearReference controlGearId="controlGear-1" />
<RatedLuminousFlux>1000</RatedLuminousFlux>
</FixedLightEmitter>
</Emitter>
</Emitters>
<Geometries>
<ModelGeometry id="geometry-1">
<GeometryFileReference fileId="geometryFile-1" />
</ModelGeometry>
</Geometries>
</GeneralDefinitions>
<ProductDefinitions>
<ProductMetaData>
<UniqueProductId>ffaeabab-f040-4a61-a6d1-e879d8f2e374</UniqueProductId>
<ProductNumber>
<Locale language="en">42</Locale>
<Locale language="de">42</Locale>
</ProductNumber>
<Name>
<Locale language="en">Pendant luminaire</Locale>
<Locale language="de">Pendelleuchte</Locale>
</Name>
<Description>
<Locale language="en">Round pendant light for indoor spaces</Locale>
<Locale language="de">Runde Pendelleuchte für Innenräume</Locale>
</Description>
<Pictures>
<Image imageType="Product Picture" fileId="pictureFile-1" />
</Pictures>
</ProductMetaData>
<Variants>
<Variant id="variant-1">
<Name>
<Locale language="en">Pendant luminaire</Locale>
<Locale language="de">Pendelleuchte</Locale>
</Name>
<Description>
<Locale language="en">Description of variant 2</Locale>
<Locale language="de">Beschreibung der Variante 2</Locale>
</Description>
<Geometry>
<ModelGeometryReference geometryId="geometry-1">
<EmitterReference emitterId="emitter-1">
<EmitterObjectExternalName>leo</EmitterObjectExternalName>
</EmitterReference>
</ModelGeometryReference>
</Geometry>
</Variant>
</Variants>
</ProductDefinitions>
</Root>

GLDF archive

Step 12: Create the .gldf archive

Finally, compress your just created folder containing

  • The product.xml in the root directory
  • All referenced files in their corresponding subfolders

into a ZIP archive and change the extension from .zip to .gldf. Congratulations, you have now successfully created your first GLDF file. We encourage you to browse the documentation and experiment for yourself to learn how to use the full potential GLDF has to offer.

You can download the result here, should you want to compare your file.