What a signal is
A signal is a permit-backed decision for a location scope. Each signal row returns:decision:positive,negative, orinsufficient_datascore: normalized 0.0 to 1.0confidence: confidence level for that decisionreasons: deterministic reason codes explaining the decisioncomputed_at: timestamp of the scoring run
Signal families
Geo-scoped signals
Geo-scoped signals use a location anchor and are exposed through:GET /v1/signals/geo/location/{geo_id}GET /v1/signals/geo/searchGET /v1/signals/catalog
city, zip, county, jurisdiction, or state.
For the current customer-facing signal catalog, see Signals Catalog.
Permit-scoped signals
Permit-scoped signals use a non-propertygeo_id and are exposed through:
GET /v1/signals/permit/leadsGET /v1/signals/permit/stats
geo_id- a non-property anchor
- customer-facing permit signal keys such as
site_prep_issued_nowcast,new_construction_issued_nowcast,framing_nowcast_early,framing_window_late,rough_in_nowcast_early, andrough_in_window_late
include_stale=true to disable the freshness window, or set max_freshness_days between 1 and 3650.
Lead rows include the trust fields used for ranking and review:
event_date_usedsignal_basisconfidencereason_codesfreshness_lag_days
observed_event and inferred_timing.
The signal catalog includes both geo-scoped and permit-signal entries, so discovery stays in one place.
Current production signals (WA)
Current public geo signals:roofing_activity_hotspothvac_activity_hotspot
site_prep_issued_nowcastnew_construction_issued_nowcastframing_nowcast_earlyframing_window_laterough_in_nowcast_earlyrough_in_window_late
How signals are computed (conceptual)
Geo-scoped signals compare recent permit activity to prior activity for the same location scope.At a high level, we evaluate:
- current activity level
- change vs previous periods
- minimum support needed to make a reliable call
Decision logic (high level)
Signals are deterministic and profile-driven.-
Eligibility check
If data support is too low for a reliable decision, output isinsufficient_data. -
Positive check
If activity and momentum meet the profile requirements, output ispositive. -
Otherwise
Output isnegative.
Confidence interpretation
Confidence reflects how much supporting evidence exists for that location decision.- lower support typically yields lower confidence
- stronger support yields higher confidence
Timing guidance
Observed nowcasts are best when you want the most literal read on the permit record. Early inferred windows are best when you want more lead time and can accept more uncertainty. Late inferred windows are best when you want tighter timing and fewer premature leads. Freshness still matters: if your source data lands monthly, the support behind a valid signal can still be several days old.Versioning and release control
Signal reads are controlled by active pointers.signal_release_pointers selects active versions by state + signal_key.
This allows:
- predictable production behavior
- pointer-based rollback
- safe promotion of new runs without breaking clients
Product boundaries
- Signals are ranking inputs, not guarantees.
- Signals do not replace underwriting, legal, or compliance review.
- Confidence can vary across geographies based on data availability.

