Descriptor FAQ

The following are common questions and solutions around the usage of Ed-Fi descriptors.

Contents

Which Descriptors Are Most important for My Organization's Usage of Ed-Fi?

There are over 160 descriptors in the core Ed-Fi data model and many more in domains under development or proposed for introduction into the core model. Not all of them will be relevant to your organization's use of Ed-Fi.

Generally, the descriptors that matter most to your organization initially will be those involved in data exchanges between systems. That list will generally depend on the APIs your organization is using.

A good first list to pay attention to are the descriptors that are required in an Ed-Fi API certification, as these must be implemented by compliant systems. By API, those descriptors are:

Core Student API for Suite 3

(covered by Ed-Fi Student Information Systems API for Suite 3 Certification)

AcademicSubjectDescriptor
AddressTypeDescriptor
AttendanceEventCategoryDescriptor
BehaviorDescriptor
CalendarEventDescriptor
CalendarTypeDescriptor
CareerPathwayDescriptor
ClassroomPositionDescriptor
CohortScopeDescriptor
CohortTypeDescriptor
CountryDescriptor
CourseAttemptResultDescriptor
CourseIdentificationSystemDescriptor
CourseLevelCharacteristicDescriptor
DisciplineDescriptor
EducationOrganizationCategoryDescriptor
ElectronicMailTypeDescriptor
EntryTypeDescriptor
ExitWithdrawTypeDescriptor

GradeLevelDescriptor
GradePointAverageTypeDescriptor
GradingPeriodDescriptor
GraduationPlanTypeDescriptor
HomelessPrimaryNighttimeResidenceDescriptor
IncidentLocationDescriptor
LanguageDescriptor
LanguageInstructionProgramServiceDescriptor
LanguageUseDescriptor
LevelOfEducationDescriptor
LimitedEnglishProficiencyDescriptor
MonitoredDescriptor
NeglectedOrDelinquentProgramDescriptor
NeglectedOrDelinquentProgramServiceDescriptor
ParticipationDescriptor
ProficiencyDescriptor
ProgramAssignmentDescriptor
ProgramTypeDescriptor
RaceDescriptor
RelationDescriptor
ReporterDescriptionDescriptor
ResidencyStatusDescriptor
SchoolFoodServiceProgramServiceDescriptor
SexDescriptor
SpecialEducationSettingDescriptor
StaffClassificationDescriptor
StateAbbreviationDescriptor
StudentCharacteristicDescriptor
StudentIdentificationSystemDescriptor
StudentParticipationCodeDescriptor
TechnicalSkillsAssessmentDescriptor
TelephoneNumberTypeDescriptor
TermDescriptor
TitleIPartAParticipantDescriptor

Assessment Outcomes API

(covered by Ed-Fi Assessment Outcomes API for Suite 3 Certification)

AcademicSubjectDescriptor
AssessmentReportingMethodDescriptor
ResultDatatypeTypeDescriptor

It is unlikely you will need to consider or map all of these values, as your organization is likely not using all APIs covered in this standard and some values are inherently local.

The lists by domain (see Descriptor Guidance#DescriptorsbyDomain) can be cross-referenced with this list to further focus your efforts.

For example, if you were only using the Discipline Domain, there are 10 descriptors (see /wiki/spaces/DATASTDDEV/pages/26313408), and 5 of those appear in the SIS certification: Discipline, IncidentLocation, ReporterDescription, Behavior, and StudentParticipationCode. Of those 5, only IncidentLocation is not classified as "local".

Do We Have To Use Ed-Fi-Defined Values?

The answer to this question is generally "no" but there may be reasons why you should attempt to stay within these values.

For clarity, no one is forced to use the Ed-Fi values. The Ed-Fi technologies and specifications are open source and can be used however desired. Plus, the Ed-Fi Alliance and its community have discovered over time and endorsed the notion that there is no set of code values for any concept that is universally applicable. By definition, this means that we need to expect that code sets will sometimes be localized.

However, just because variation will exist and just because there is no "universally applicable" set of values for any concept, it does NOT follow that it is not helpful to adopt a common sets in some circumstances, and for the Alliance to encourage  sometimes strongly  community members to adopt common values. When we act in common ways, then we can rely on each other, share resources, and interoperate easier.

Said anther way: there may be pain or loss in mapping local values to Ed-Fi values, but that pain provides benefits in terms of interoperability.

In What Ways Does Ed-Fi Encourage or Enforce Compliance With Particular Value Sets?

First, as we noted above, any Ed-Fi descriptor set can be modified in field work. 

However, in its API standards and certifications, the Ed-Fi Alliance does add requirements for descriptor values. In order to be judged to be compliant with one of those specifications, a product may be required to show that it can use a particular set. That set is generally (but not necessarily) a set defined by the Ed-Fi Data Standard.

As an example, you can see that the Assessment Outcomes API v3 requires usage of most Ed-Fi defined values, but makes a few exceptions: Ed-Fi Assessment Outcomes API for Suite 3 Certification#FiAssessmentOutcomesAPIforSuite3Certification-Enumerations.

Why Do Ed-Fi Descriptor Values Have a URL in Them?

This URL is actually a "namespace." If you look at a descriptor in an Ed-Fi defined exchange, you will see it has this format:

uri://ed-fi.org/AcademicSubjectDescriptor#Mathematics

This is the pattern followed:

[namespace]#[descriptor value]

If the value is stored in a database, you will often see this namespace stored separately.

The descriptor value is the "code" that typically appears in source systems. But what is the namespace? The namespace is a string value that tells you who governs or defines the value. In this case, you can see that the value "Mathematics" is defined by "ed-fi.org". In other words, the Ed-Fi Alliance defines a value called "Mathematics." If this was an agency with a different definition of mathematics, there could very well be a different descriptor value that looked like this:

uri://mydistrict.edu/AcademicSubjectDescriptor#Mathematics

This is telling you that this is "mydistrict.edu" definition of "Mathematics" and not the definition of the Ed-Fi Alliance. 

By convention, these namespaces usually follow a URL-like-pattern, referencing an Internet domain owned by the organization that governs the descriptor value.

How Do I Create My Own Descriptors?

Descriptors are simple to create  you just create the code values you need. We recommend strongly that you provide a definition as well (we have not mentioned it thus far, but descriptors should have a clear definition).

However, the important part of creating a new descriptor value is that the value should be placed in your own namespace, and not placed in the "ed-fi.org" namespace. For example, if you were at a school district called: Grand Bend School District and needed an Academic Subject value called "Linear Algebra II", your descriptor might look like this:

uri://grandbendsd.edu/AcademicSubjectDescriptor#Linear Algebra II

It is recommended but not required that the namespace you choose include a domain name that is under your organization's control and resolves to a web property owned by your organization. This helps those who see this value discover who created that value.