Understanding Rule Structure
Each rule consists of one or more conditions that work together to validate model elements. Rules use a structured logic system:| Component | Description |
|---|---|
| Logic | How conditions combine: WHERE (filter), AND (additional filter), CHECK (final validation) |
| Property Name | The object property to check (e.g., category, width, baseline.length) |
| Predicate | The comparison operation (equal to, greater than, less than, exists, in list, etc.) |
| Value | The reference value for comparison |
| Message | Description shown in validation results (auto-generated but can be overwritten) |
| Report Severity | Defines the importance: ERROR, WARNING, or INFO |
Creating Your First Rule
Example: Checking Wall Thickness
Let’s create a rule that checks if walls are at least 200 units thick:-
WHERE condition: Filter for walls
- Property:
Category - Predicate:
equal to - Value:
Walls
- Property:
-
CHECK condition: Validate thickness
- Property:
Width - Predicate:
less than - Value:
200 - Severity:
ERROR - Message: “Wall thickness must be at least 200” (auto-generated, but can be customized)
- Property:
Adding Multiple Conditions
You can add multipleAND conditions between WHERE and CHECK to create more complex filters:
Example: Check steel beams that are too long
WHERECategory = BeamsANDMaterial = SteelCHECKLength > 5000
Supported Predicates
Model Checker supports the following predicates for comparing property values:| Predicate | Description | Example |
|---|---|---|
exists | Checks if a property exists | height exists |
equal to | Exact value match | width equal to 300 |
not equal to | Value doesn’t match | material not equal to Concrete |
identical to | Exact match (case-sensitive) | name identical to Wall-01 |
less than | Value below threshold | thickness less than 50 |
greater than | Value exceeds threshold | height greater than 3000 |
in range | Value within bounds | elevation in range 0,10000 |
in list | Value in allowed set | type in list W1,W2,W3 |
contains | Property contains substring | name contains Beam |
does not contain | Property doesn’t contain substring | name does not contain temp |
is true | Boolean property is true | is_structural is true |
is false | Boolean property is false | is_placeholder is false |
is like | Loose text matching (pattern matching) | name is like Wall matches “Walls”, “Wall-01”, etc. |
Rule Types
Property Existence
Check whether specific properties exist on model elements. Useful for ensuring required data is present. Example:CHECK acoustic rating exists
Pattern Matching
Validate that property values match specific patterns or formats. For example, ensure element names follow a naming convention. Example: Useis like for pattern matching or contains for substring matching.
Numeric Comparisons
Compare numeric property values against thresholds or ranges. Check that dimensions, areas, or other measurements meet requirements. Examples:greater than- Values above a thresholdless than- Values below a thresholdin range- Values between two numbers
Value Validation
Verify that properties contain expected values or fall within acceptable ranges. Examples:equal to- Exact matchin list- Match any value in a comma-separated listnot equal to- Exclude exact matchesidentical to- Exact match (case-sensitive)
Rule Messages
Rule messages are auto-generated to help validate the logic you are testing for. The auto-generated message describes what the rule is checking, making it easier to understand the validation logic. You can overwrite the auto-generated message with a custom message if you want to provide more specific guidance or context.Best Practices
Use Specific Property Paths
Use exact property paths for accurate validation. The Model Checker understands properties in Speckle objects regardless of schema:- Direct properties:
category,name,id - Nested properties:
baseline.length,parameters.WIDTH.value - Revit parameters: Use parameter names like
Mark,Width,Assembly Code
Set Appropriate Severity Levels
- ERROR: Critical issues that must be fixed (e.g., “Wall thickness must be at least 200”)
- WARNING: Moderate concerns that should be reviewed (e.g., “Height should be no more than 3000”)
- INFO: Informational notifications (e.g., “Material is Concrete”)
Write Clear Messages
When customizing messages, make them actionable and specific. Avoid vague terms like “Wall thickness check” and instead say “Wall thickness must be at least 200mm.”Examples of Good vs. Bad Messages
| Rule Condition | Bad Message ❌ | Better Message ✅ |
|---|---|---|
Width less than 200 and ERROR | ”Wall thickness check" | "Wall thickness must be at least 200” |
Height greater than 3000 and WARNING | ”Height check" | "Height should be no more than 3000” |
Material equal to "Concrete" and INFO | ”Material info" | "Material is Concrete” |
Common Rule Patterns
Filter by Category
Multiple Filters
Property Existence Check
Value Range Check
Door Naming Convention
Structural Column Height Range
Exporting Rulesets
Getting Your Ruleset URL
Once you’ve created a ruleset:- Navigate to your project’s rulesets page
- Find the ruleset you want to use
- Click Copy Link to get the URL for your ruleset
Exporting
Rulesets can also be exported as files for backup or sharing:- Navigate to your project’s rulesets page
- Find the ruleset you want to export
- Use the export option to download the ruleset
Exported files use the TSV (Tab-Separated Values) format. TSV files can be imported back into Model Checker or shared with other projects or teams.
Using Rulesets in Automations
Setting Up Model Checker Automation
- Copy the ruleset URL from Model Checker
- In Speckle Automate, create a new automation
- Select the Model Checker function
- Paste the ruleset URL into the configuration
- Configure which models or projects should be checked
How It Works
When you publish a model to Speckle:- The Model Checker automation is triggered
- It fetches your rules from the ruleset URL
- It validates the model against all rules in the ruleset
- Results are stored and can be viewed in the 3D viewer
Importing Rules
If you have existing rules in a file, you can import them into Model Checker:- Navigate to your project’s rulesets page
- Click Import
- Provide a name and description for the imported ruleset
- Upload your file
Imported files should use the TSV (Tab-Separated Values) format. The file should have the following columns:
File Format
The file format should have the following columns:- Rule Number - Groups conditions into a single rule
- Logic - WHERE, AND, or CHECK
- Property Name - The object property to check
- Predicate - The comparison operation
- Value - The reference value for comparison
- Report Severity - ERROR, WARNING, or INFO
- Message - Description shown in validation results
Example File
Managing Multiple Rulesets
You can create multiple rulesets for a single project. This is useful for organizing different types of validation checks:- Building Code Compliance - Rules for code requirements
- Naming Conventions - Rules for element naming standards
- Material Standards - Rules for material specifications
- Dimensional Checks - Rules for size and dimension validation
Updating Rules
When you update rules in Model Checker:- Make changes to your rules in the Model Checker interface
- The ruleset URL automatically reflects the latest version
- Your automations will use the updated rules without needing to reconfigure
Frequently Asked Questions
Can I use the auto-generated message as-is?
Can I use the auto-generated message as-is?
Yes, the auto-generated messages are designed to be clear and helpful. You can use them as-is or customize them to provide more specific guidance for your team.
What if I need to check multiple properties in one rule?
What if I need to check multiple properties in one rule?
You can add multiple
AND conditions between WHERE and CHECK to filter by multiple properties. However, the CHECK condition should validate a single property. If you need to check multiple properties, create separate rules.How do I know which property path to use?
How do I know which property path to use?
Use the exact property path as it appears in your model data. If you’re unsure, you can explore your model’s properties in the 3D viewer or use the property search in Model Checker to find the correct path.
Can I use the same ruleset URL in multiple automations?
Can I use the same ruleset URL in multiple automations?
Yes, you can use the same ruleset URL in multiple automations. All automations will use the latest version of your rules whenever they run.
What happens if I delete a ruleset?
What happens if I delete a ruleset?
If you delete a ruleset, any automations using that ruleset’s URL will no longer be able to fetch the rules. Make sure to update or remove those automations.
Do I need to update my automation when I change rules?
Do I need to update my automation when I change rules?
No, the ruleset URL automatically reflects the latest version of your rules. Your automations will use the updated rules without needing to reconfigure.
Can I share exported files with other teams?
Can I share exported files with other teams?
Why TSV and not CSV?
Why TSV and not CSV?
TSV (Tab-Separated Values) is used instead of CSV (Comma-Separated Values) to cope with commas that may be present in properties or messages. TSV is the same as CSV but uses tabs in place of commas to separate values, preventing issues when property values or messages contain commas.
Can I create the file in Excel?
Can I create the file in Excel?
Yes, you can create TSV files in Excel. When saving, choose “Tab delimited” or “Text (Tab delimited)” as the file format. Make sure to save with the .tsv extension.
How does Model Checker relate to IDS (Information Delivery Specification)?
How does Model Checker relate to IDS (Information Delivery Specification)?
IDS (Information Delivery Specification) is designed for IFC model checking, but IDS rules can be applied to all Speckle models regardless of their source format. However, there are important differences:
- IDS checks for rules that relate to assembly membership - IDS can validate relationships between elements and their assemblies
- Model Checker is isolated to the data within an element - Model Checker focuses on validating properties and data within individual elements, not relationships between elements
Next Steps
- See how to view and analyze results