The Overall Stats API provides project-wide statistics about Project Sidewalk's data collection efforts in 密蘇裡州聖路易, including total distance covered, label counts by type, user participation metrics, and data quality indicators.
Below is a live preview of the Overall Stats API data for 密蘇裡州聖路易:
Retrieve overall statistics for the entire Project Sidewalk dataset.
GET /v3/api/overallStats
/v3/api/overallStats?filetype=json Get overall stats for 密蘇裡州聖路易 in JSON (default)
/v3/api/overallStats?filetype=csv Get overall stats for 密蘇裡州聖路易 in CSV
Download overall statistics data directly in your preferred format:
This endpoint accepts the following optional query parameters.
| Parameter | Type | Description | 
|---|---|---|
| filterLowQuality | boolean | When set to true, excludes data from low-quality contributors to provide
                            more reliable statistics. Default:false(includes all data). | 
| filetype | string | Specify the output format. Options: json(default),csv. | 
            On success, the API returns an HTTP 200 OK status code and the requested data in the specified
            filetype format.
        
Returns a JSON object with comprehensive project statistics:
{
    "launchDate": "2021-06-15T00:00:00Z",
    "avgTimestampLast100Labels": "2023-09-25T14:32:47Z",
    "kmExplored": 1834.26,
    "kmExploreNoOverlap": 1523.75,
    "nUsers": 4287,
    "nExplorers": 3892,
    "nValidators": 895,
    "nRegistered": 3456,
    "nAnon": 831,
    "nTurker": 214,
    "nResearcher": 42,
    "totalLabels": 183427,
    "severityByLabelType": {
        "CurbRamp": {
            "n": 72964,
            "nWithSeverity": 61837,
            "severityMean": 1.2,
            "severitySD": 0.5
        },
        "NoCurbRamp": {
            "n": 35682,
            "nWithSeverity": 31245,
            "severityMean": 3.8,
            "severitySD": 0.9
        },
        "Obstacle": {
            "n": 14256,
            "nWithSeverity": 12589,
            "severityMean": 2.7,
            "severitySD": 1.1
        },
        "SurfaceProblem": {
            "n": 22784,
            "nWithSeverity": 19873,
            "severityMean": 2.4,
            "severitySD": 1.2
        },
        "NoSidewalk": {
            "n": 15682,
            "nWithSeverity": 14352,
            "severityMean": 4.2,
            "severitySD": 0.7
        },
        "Crosswalk": {
            "n": 9427,
            "nWithSeverity": 0,
            "severityMean": null,
            "severitySD": null
        },
        "Signal": {
            "n": 7851,
            "nWithSeverity": 6284,
            "severityMean": 3.1,
            "severitySD": 1.0
        },
        "Occlusion": {
            "n": 3475,
            "nWithSeverity": 0,
            "severityMean": null,
            "severitySD": null
        },
        "Other": {
            "n": 1306,
            "nWithSeverity": 582,
            "severityMean": 2.9,
            "severitySD": 1.4
        }
    },
    "nValidations": 125834,
    "accuracyByLabelType": {
        "CurbRamp": {
            "n": 54321,
            "nAgree": 48923,
            "nDisagree": 5398,
            "accuracy": 0.90
        },
        "NoCurbRamp": {
            "n": 21456,
            "nAgree": 18237,
            "nDisagree": 3219,
            "accuracy": 0.85
        },
        "Obstacle": {
            "n": 8932,
            "nAgree": 7324,
            "nDisagree": 1608,
            "accuracy": 0.82
        },
        "SurfaceProblem": {
            "n": 12879,
            "nAgree": 10561,
            "nDisagree": 2318,
            "accuracy": 0.82
        },
        "NoSidewalk": {
            "n": 9871,
            "nAgree": 8765,
            "nDisagree": 1106,
            "accuracy": 0.89
        },
        "Crosswalk": {
            "n": 6543,
            "nAgree": 5982,
            "nDisagree": 561,
            "accuracy": 0.91
        },
        "Signal": {
            "n": 5432,
            "nAgree": 4812,
            "nDisagree": 620,
            "accuracy": 0.89
        },
        "Occlusion": {
            "n": 2154,
            "nAgree": 1723,
            "nDisagree": 431,
            "accuracy": 0.80
        },
        "Other": {
            "n": 743,
            "nAgree": 521,
            "nDisagree": 222,
            "accuracy": 0.70
        }
    }
}The response includes the following fields:
| Field | Type | Description | 
|---|---|---|
| launchDate | string | ISO 8601 formatted date when Project Sidewalk was launched in this city. | 
| avgTimestampLast100Labels | string | ISO 8601 formatted average timestamp of the 100 most recent labels, indicating data recency. | 
| kmExplored | number | Total kilometers of streets explored by all users, including overlapping segments. | 
| kmExploreNoOverlap | number | Total kilometers of unique streets explored, excluding overlapping segments. | 
| nUsers | integer | Total number of users who have contributed to Project Sidewalk. | 
| nExplorers | integer | Number of users who have participated in exploration/labeling tasks. | 
| nValidators | integer | Number of users who have participated in validation tasks. | 
| nRegistered | integer | Number of registered users with accounts. | 
| nAnon | integer | Number of anonymous users. | 
| nTurker | integer | Number of users from crowdsourcing platforms. | 
| nResearcher | integer | Number of users with researcher role. | 
| totalLabels | integer | Total number of accessibility labels placed by all users. | 
| severityByLabelType | object | Statistics about severity ratings by label type. | 
| severityByLabelType.[type].n | integer | Total number of labels of this type. | 
| severityByLabelType.[type].nWithSeverity | integer | Number of labels of this type that have severity ratings. | 
| severityByLabelType.[type].severityMean | number | null | Mean severity rating for this label type, or null if no severity ratings exist. | 
| severityByLabelType.[type].severitySD | number | null | Standard deviation of severity ratings for this label type, or null if insufficient data. | 
| nValidations | integer | Total number of validation judgments made across all labels. | 
| accuracyByLabelType | object | Statistics about validation accuracy by label type. | 
| accuracyByLabelType.[type].n | integer | Number of labels of this type that have been validated. | 
| accuracyByLabelType.[type].nAgree | integer | Number of validations agreeing with the label placement. | 
| accuracyByLabelType.[type].nDisagree | integer | Number of validations disagreeing with the label placement. | 
| accuracyByLabelType.[type].accuracy | number | null | Calculated accuracy rate (nAgree / n) for this label type, or null if no validations. | 
If filetype=csv is specified, the response body will be CSV data with key-value pairs. Each row represents a different statistic or metric:
Launch Date,2021-06-15
Recent Labels Average Timestamp,2023-09-25T14:32:47Z
KM Explored,1834.26
KM Explored Without Overlap,1523.75
Total User Count,4287
Explore User Count,3892
Validate User Count,895
Registered User Count,3456
Anonymous User Count,831
Turker User Count,214
Researcher User Count,42
Total Label Count,183427
CurbRamp Count,72964
CurbRamp Count With Severity,61837
CurbRamp Severity Mean,1.2
CurbRamp Severity SD,0.5
NoCurbRamp Count,35682
NoCurbRamp Count With Severity,31245
NoCurbRamp Severity Mean,3.8
NoCurbRamp Severity SD,0.9
...
Total Validations,125834
CurbRamp Labels Validated,54321
CurbRamp Agreed Count,48923
CurbRamp Disagreed Count,5398
CurbRamp Accuracy,0.90
...In CSV format, each row represents a specific metric in a key-value format:
severityByLabelType and accuracyByLabelType are flattened into multiple rows with descriptive namesIf an error occurs, the API will return an appropriate HTTP status code and a JSON response body containing details about the error.
400 Bad Request: Invalid parameter values.404 Not Found: The requested resource does not exist.500 Internal Server Error: An unexpected error occurred on the server.503 Service Unavailable: The server is temporarily unable to handle the request.Error responses include a JSON body with the following structure:
{
    "status": 400, // HTTP Status Code
    "code": "INVALID_PARAMETER", // Machine-readable error code
    "message": "Invalid value for filetype parameter. Expected 'csv' or 'json'.", // Human-readable description
    "parameter": "filetype" // Optional: The specific parameter causing the error
}The Overall Stats API provides a comprehensive view of Project Sidewalk data. Here are some suggestions for effectively using this data:
For more detailed analysis, consider using the Overall Stats API in conjunction with:
Project Sidewalk is an open-source project created by the Makeability Lab and hosted on GitHub. We welcome your contributions! If you found a bug or have a feature request, please open an issue on GitHub.
You can also email us at sidewalk@cs.uw.edu
If you are interested in bringing Project Sidewalk to your city, please read our Wiki page.