Thank you for downloading this release of the SEDRIS Software Development Kit (SEDRIS SDK). The SEDRIS SDK is the development environment for building applications and components that can unambiguously represent and interchange environmental data.
This release has been tested on multiple platforms, such as Linux, Windows 98/Me/NT/2000/XP, Irix, and Sun. For detailed information on platform and compiler versions supported see the Build Kit.
The SDK includes tools useful for accessing, testing, and viewing SEDRIS transmittals (also called STF transmittals). Some of these tools are designed to be used from the command line, but there is also an application that can display 3D geometry present in a transmittal using the OpenGL libraries. More information on these applications is available in the Tools and Utilities page.
This release is compatible with the following SEDRIS technology components:
- Data Representation Model (DRM), version 4.1
- Environmental Data Coding Specification (EDCS), version 4.2
- Spatial Reference Model (SRM), version 4.1
- Transmittal Access (TA) API, version 4.1
- SEDRIS Transmittal Format (STF), version 4.1
This release includes the following SEDRIS implementations:
- Reference DRM implementation, version 4.1.1
- Reference EDCS implementation, version 4.2.0
- Reference SRM implementation, version 4.1.1
- Reference TA API implementation, version 4.1.1
- Reference STF implementation, version 4.1.1
This reference implementation is compliant with the following SEDRIS IS specifications:
- (ISO/IEC 18023-1) SEDRIS -- Part 1: Functional specification
- (ISO/IEC 18023-3) SEDRIS -- Part 3: Transmittal format binary encoding
- (ISO/IEC 18024-4) SEDRIS language bindings -- Part 4: C
- (ISO/IEC 18025) Environmental Data Coding Specification (EDCS)
- (ISO/IEC 18041-4) EDCS language bindings -- Part 4: C
- (ISO/IEC 18026) Spatial Reference Model (SRM)
- (ISO/IEC 18042-4) SRM language bindings -- Part 4: C
The EDCS and SRM will be updated on a regular basis, probably at a faster rate than the other SEDRIS technology components. New versions of these components will easily integrate into your current SEDRIS environment using simple file replacements.
For help, comments, and bug reports please send email to [email protected]. If you are an associate, please use [email protected].
Return to: Top
This version of the SDK is being made available in multiple distribution formats. In addition to source code, pre-compiled binaries for all supported platforms can be downloaded from the SEDRIS web site (www.sedris.org). You may also download separate distributions of the EDCS SDK and SRM SDK technology components in both source and pre-compiled binaries form.
The following matrix table shows the contents of the different packages for the SEDRIS SDK distributions and the directories in which you will find them:
Package and Contents bin: Executable binary applications
docs: Documentation, including Release Notes, Migration Guide, and Reference Manual
include: Headers for SEDRIS Technology Components
lib: Compiled binary libraries
src: Source code for SEDRIS Technology Components and Applications
transmittals: Sample SEDRIS STF transmittals
Complete Source Suite:
- All SEDRIS Technology Components
- All SDK Applications
X X X Complete Binary Suite:
- All SEDRIS Technology Components
- All SDK applications
X X X X X Return to: Top
The following table may assist developers in finding the documentation that best matches their needs:
Release Notes Fixes and Limitations Build Kit Migration Guide Tools And Utilities SDK Reference Manual New user with
binary distributionRead Read Read Read New user with
source code distributionRead Read Read Read Read Experienced user with
binary distributionRead Read Read Read Experienced user with
source code distributionRead Read Read Read Read Return to: Top
The SEDRIS SDK is distributed as a GNU-zipped tar file for Unix systems and a zip file for Win32 systems. If you have obtained a source distribution, you will need to build the SDK after installation in order to run the applications and test your setup.
The binary releases include the OS/architecture type as part of the file/directory hierarchy. This allows binary releases associated with different OS/architectures to be installed on a common "sedris" SDK directory. The OS/architecture-specific libraries and executables are stored under separate sub-directories in the "lib" and "bin" directories.
To install, extract the contents of the compressed file:
- Unix
Use the "tar" and "gzip" commands to extract the contents of the SDK:
using the appropriate filename for "sdk_file.tgz".gunzip -c sdk_file.tgz | tar xf -If you have GNU tar installed, you can use the following command instead:
tar xzf sdk_file.tgz- Win32
Unzip the zip file using a decompression utility (such as WinZip or 7-Zip) to extract the contents of the SDK.
The next step is to build, test, and use the SDK. See the Build Kit page for information on building the SDK (if you downloaded a source distribution), testing the build, and linking your applications and/or libraries against the libraries in this SDK.
Return to: Top
The SDK Documentation is divided into the following areas:
- Release Notes (this document)
Describes the capabilities of this release, its contents, and supported platforms and compilers.
- Build Kit
Details the build options and procedures for compiling and linking the software, how to test the build, and how to link applications and libraries against the SDK.
- Fixes And Limitations
Describes the fixes and known limitations of this release.
- SDK Reference Manual
Provides links to detailed documents for the DRM, EDCS, SRM, API, and STF technology components.
- Tools and Utilities
Describes the tools and utilities included with this release, such as Depth and Model Viewer.
- Migration Guide
Provides information on procedures and utilities available to migrate applications from previous releases of the SDK.
Return to: Top
This release includes several applications and sample data that demonstrate the use of the SEDRIS SDK to create and access STF transmittals. For more information on these applications see the Tools and Utilities page.
Applications:
- Depth
An application that traverses an STF transmittal and displays the objects in text format. See a sample run of the Depth tool.
- Model Viewer
A 3D viewer that can display <Model> geometry and textures using OpenGL. See a sample run of the Model Viewer tool.
- ITR Test
An application that demonstrates the use of the Inter-Transmittal Referencing mechanism to link multiple STF transmittals.
- STF Test
A sample application that creates and populates an STF transmittal with <Data Table> data.
- Rules Checker (C SDK only)
A tool that checks the semantical correctness of an STF transmittal. See a sample run of the Rules Checker tool.
- Syntax Checker (C SDK only)
A tool that checks the syntactical correctness of an STF transmittal. See a sample run of the Syntax Checker tool.
Sample STF transmittals and related files:
- test.stf
Contains one <Model> with 3 polygons. Uses LSR for its environment. There are no textures, features, or grids. There is one green polygon in the <Environment Root> and an instance reference for the <Model>. (green color).
- sample_comm.stf
Contains a model of a communications console. It demonstrates texture mapping.
- sample_chair.stf
Contains a somewhat complex model of an office chair.
- WindData.stf
Contains sample atmospheric data (wind speed and temperature) stored in a <Property Grid> class instance.
- sedris.rsl
A sample SEDRIS resolution file for resolving transmittal Uniform Resource Names (URNs) to STF transmittals.
Return to: Top
The SDK can use several environment variables to control and configure its runtime execution.
Environment variables common to both the C and C++ SDKs:
- SEDRIS_RESOLVER_PATH
This variable specifies the path(s) where the API should look for SEDRIS resolution (*.rsl) files.
Environment variables unique to the C SDK:
Note: These variables rarely need to be set.
- SE_API_MEMORY_MODEL
This variable allows the user to specify, at a high level, the amount of memory to use. Its allowed values are SMALL (default), MEDIUM, and LARGE. Each choice will set the default values of the subordinate memory model environment variables SE_RAIF_MAX_OBJECT_CACHE_SIZE and SE_STF_BLOCK_CACHE_SIZE.
- SE_RAIF_MAX_OBJECT_CACHE_SIZE
The API maintains a cache of objects. This cache is made up of objects that the user has a handle for and objects that have been previously processed. This reduces the need to re-create previously seen objects. SE_RAIF_MAX_OBJECT_CACHE_SIZE specifies the maximum number of objects in the cache before the API will delete objects that don't have a user handle. The default is 4096.
- SE_STF_BLOCK_CACHE_SIZE
This variable specifies how many STF memory blocks to keep in memory. Every file contains 2048 blocks; the more blocks in memory the less they have to be instantiated. The default value is 500.
If SE_API_MEMORY_MODEL is set and the user overrides the subordinate variables, then the overriding values will be used.
The following are the default values for each memory model choice:
Memory Model Default Setting SMALL
(default)SE_RAIF_MAX_OBJECT_CACHE_SIZE = 4096
SE_STF_BLOCK_CACHE_SIZE = 500MEDIUM SE_RAIF_MAX_OBJECT_CACHE_SIZE = 32768
SE_STF_BLOCK_CACHE_SIZE = 2000LARGE SE_RAIF_MAX_OBJECT_CACHE_SIZE = 131072
SE_STF_BLOCK_CACHE_SIZE = 10000The following considerations can be used when deciding to set these variables in order to attempt performance improvements:
- Object interconnectivity
If a transmittal has a high amount of object sharing and hence is highly interconnected, the user could benefit by enlarging the memory model, which causes more objects to be maintained in memory. Since in highly interconnected transmittals the same objects will be encountered many times, maintaining them in memory means that they will not have to be re-instantiated each time they are encountered. The API can directly access them and the user will have immediate access, rather than having to read them from disk or convert them in memory.
- Traversal algorithm
The second area of impact depends on the user's traversal algorithm. The user could benefit from larger memory models if the user consumes/produces transmittals in a manner in which the same transmittal areas are visited repeatedly. In the case where the user has simple depth-first traversal and processes most objects only once, there is no benefit in enlarging the memory model.
- <Data Table> production
The third area affected is specific to data providers of <Data Tables>. Using a small memory model while a <Data Table> is being produced will optimize the <Data Table>'s size on disk, while a large memory model will optimize it for speed of consumption.
Return to: Top
The following table provides a short summary of changes in this release. For a full description of software fixes and known limitations in this SDK release see Fixes And Limitations.
SEDRIS Change Requests (SCRs) addressed None DRM None SRM None EDCS Added registered EDCS concepts. Transmittal Access C API Performance improvements when generating large transmittals. Transmittal Access C++ API Performance improvements when opening transmittals with thousands of ITR references. Applications
- Core applications have a more consistent style of reporting and usage.
- Syntax Checker now fully enforces the syntactic restrictions on aggregate/component relationships.
- Rules Checker application now performs many additional tests.
- ITR Test now produces a different transmittal as an example. The ITR relationships are now associations between <Geometry Model Instance> objects in transmittal A and <Geometry Model> objects in transmittals B and C (as opposed to the previously invalid <Model Library> to <Model> relationships).
A SEDRIS Change Request (SCR) is the means by which users make their requests for SEDRIS technology changes as either a functional enhancement or a software problem. Users can make such requests via the SCR Form Web Site. The SEDRIS Associates can review the status of the SCRs at the SEDRIS website while the non-associates can obtain their status by sending a request for specific SCRs to [email protected].
Return to: Top
Questions, comments, and bug reports should be sent to [email protected].
If you are an associate, please send email to [email protected].
Return to: Top
These links require Internet access:
Return to: Top
Copyright © 2007 SEDRIS