{"id":1299,"name":"PyCPD","description":"PyCPD: Pure NumPy Implementation of the Coherent Point Drift Algorithm - Published in JOSS (2022)","url":"https://github.com/siavashk/pycpd","last_synced_at":"2025-09-04T16:22:53.271Z","repository":{"id":13186432,"uuid":"71678665","full_name":"siavashk/pycpd","owner":"siavashk","description":"Pure Numpy Implementation of the Coherent Point Drift Algorithm","archived":false,"fork":false,"pushed_at":"2023-08-08T05:52:16.000Z","size":15069,"stargazers_count":568,"open_issues_count":6,"forks_count":124,"subscribers_count":14,"default_branch":"master","last_synced_at":"2025-08-31T21:16:09.412Z","etag":null,"topics":["expectation-maximization","point-cloud","python","registration"],"latest_commit_sha":null,"homepage":null,"language":"Python","has_issues":true,"has_wiki":null,"has_pages":null,"mirror_url":null,"source_name":null,"license":"mit","status":null,"scm":"git","pull_requests_enabled":true,"icon_url":"https://github.com/siavashk.png","metadata":{"files":{"readme":"README.rst","changelog":"CHANGES.txt","contributing":"CONTRIBUTING.md","funding":null,"license":"LICENSE","code_of_conduct":"CODE_OF_CONDUCT.md","threat_model":null,"audit":null,"citation":null,"codeowners":null,"security":null,"support":null,"governance":null,"roadmap":null,"authors":null,"dei":null,"publiccode":null,"codemeta":null,"zenodo":null}},"created_at":"2016-10-23T03:05:07.000Z","updated_at":"2025-08-04T11:37:47.000Z","dependencies_parsed_at":"2025-04-14T14:39:59.795Z","dependency_job_id":"3a63d650-ad69-4ba3-b0c7-db923e9ff0f0","html_url":"https://github.com/siavashk/pycpd","commit_stats":{"total_commits":165,"total_committers":18,"mean_commits":9.166666666666666,"dds":0.7333333333333334,"last_synced_commit":"e5ca02d2501fb4b633c1664de939c336ffa2349e"},"previous_names":[],"tags_count":2,"template":false,"template_full_name":null,"purl":"pkg:github/siavashk/pycpd","repository_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/siavashk%2Fpycpd","tags_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/siavashk%2Fpycpd/tags","releases_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/siavashk%2Fpycpd/releases","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/siavashk%2Fpycpd/manifests","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/siavashk","download_url":"https://codeload.github.com/siavashk/pycpd/tar.gz/refs/heads/master","sbom_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/siavashk%2Fpycpd/sbom","scorecard":{"id":822127,"data":{"date":"2025-08-11","repo":{"name":"github.com/siavashk/pycpd","commit":"e5ca02d2501fb4b633c1664de939c336ffa2349e"},"scorecard":{"version":"v5.2.1-40-gf6ed084d","commit":"f6ed084d17c9236477efd66e5b258b9d4cc7b389"},"score":3.1,"checks":[{"name":"Packaging","score":-1,"reason":"packaging workflow not detected","details":["Warn: no GitHub/GitLab publishing workflow detected."],"documentation":{"short":"Determines if the project is published as a package that others can easily download, install, easily update, and uninstall.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#packaging"}},{"name":"Maintained","score":0,"reason":"0 commit(s) and 0 issue activity found in the last 90 days -- score normalized to 0","details":null,"documentation":{"short":"Determines if the project is \"actively maintained\".","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#maintained"}},{"name":"Code-Review","score":3,"reason":"Found 3/10 approved changesets -- score normalized to 3","details":null,"documentation":{"short":"Determines if the project requires human code review before pull requests (aka merge requests) are merged.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#code-review"}},{"name":"Binary-Artifacts","score":10,"reason":"no binaries found in the repo","details":null,"documentation":{"short":"Determines if the project has generated executable (binary) artifacts in the source repository.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#binary-artifacts"}},{"name":"Dangerous-Workflow","score":10,"reason":"no dangerous workflow patterns detected","details":null,"documentation":{"short":"Determines if the project's GitHub Action workflows avoid dangerous patterns.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#dangerous-workflow"}},{"name":"Token-Permissions","score":0,"reason":"detected GitHub workflow tokens with excessive permissions","details":["Warn: no topLevel permission defined: .github/workflows/build-test.yml:1","Info: topLevel 'contents' permission set to 'read': .github/workflows/docs.yml:14","Warn: no topLevel permission defined: .github/workflows/draft-pdf.yml:1","Info: no jobLevel write permissions found"],"documentation":{"short":"Determines if the project's workflows follow the principle of least privilege.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#token-permissions"}},{"name":"CII-Best-Practices","score":0,"reason":"no effort to earn an OpenSSF best practices badge detected","details":null,"documentation":{"short":"Determines if the project has an OpenSSF (formerly CII) Best Practices Badge.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#cii-best-practices"}},{"name":"Security-Policy","score":0,"reason":"security policy file not detected","details":["Warn: no security policy file detected","Warn: no security file to analyze","Warn: no security file to analyze","Warn: no security file to analyze"],"documentation":{"short":"Determines if the project has published a security policy.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#security-policy"}},{"name":"License","score":10,"reason":"license file detected","details":["Info: project has a license file: LICENSE:0","Info: FSF or OSI recognized license: MIT License: LICENSE:0"],"documentation":{"short":"Determines if the project has defined a license.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#license"}},{"name":"Fuzzing","score":0,"reason":"project is not fuzzed","details":["Warn: no fuzzer integrations found"],"documentation":{"short":"Determines if the project uses fuzzing.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#fuzzing"}},{"name":"Signed-Releases","score":-1,"reason":"no releases found","details":null,"documentation":{"short":"Determines if the project cryptographically signs release artifacts.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#signed-releases"}},{"name":"Branch-Protection","score":0,"reason":"branch protection not enabled on development/release branches","details":["Warn: branch protection not enabled for branch 'master'"],"documentation":{"short":"Determines if the default and release branches are protected with GitHub's branch protection settings.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#branch-protection"}},{"name":"Vulnerabilities","score":3,"reason":"7 existing vulnerabilities detected","details":["Warn: Project is vulnerable to: PYSEC-2018-34 / GHSA-2fc2-6r4j-p65h","Warn: Project is vulnerable to: PYSEC-2021-856 / GHSA-5545-2q6w-2gh6","Warn: Project is vulnerable to: PYSEC-2019-108 / GHSA-9fq2-x9r6-wfmf","Warn: Project is vulnerable to: PYSEC-2018-33 / GHSA-cw6w-4rcx-xphc","Warn: Project is vulnerable to: PYSEC-2021-857 / GHSA-f7c7-j99h-c22f","Warn: Project is vulnerable to: GHSA-fpfv-jqm9-f5jm","Warn: Project is vulnerable to: PYSEC-2017-1 / GHSA-frgw-fgh6-9g52"],"documentation":{"short":"Determines if the project has open, known unfixed vulnerabilities.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#vulnerabilities"}},{"name":"SAST","score":0,"reason":"SAST tool is not run on all commits -- score normalized to 0","details":["Warn: 0 commits out of 27 are checked with a SAST tool"],"documentation":{"short":"Determines if the project uses static code analysis.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#sast"}},{"name":"Pinned-Dependencies","score":0,"reason":"dependency not pinned by hash detected -- score normalized to 0","details":["Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/build-test.yml:46: update your workflow using https://app.stepsecurity.io/secureworkflow/siavashk/pycpd/build-test.yml/master?enable=pin","Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/build-test.yml:48: update your workflow using https://app.stepsecurity.io/secureworkflow/siavashk/pycpd/build-test.yml/master?enable=pin","Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/docs.yml:21: update your workflow using https://app.stepsecurity.io/secureworkflow/siavashk/pycpd/docs.yml/master?enable=pin","Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/docs.yml:22: update your workflow using https://app.stepsecurity.io/secureworkflow/siavashk/pycpd/docs.yml/master?enable=pin","Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/docs.yml:31: update your workflow using https://app.stepsecurity.io/secureworkflow/siavashk/pycpd/docs.yml/master?enable=pin","Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/docs.yml:49: update your workflow using https://app.stepsecurity.io/secureworkflow/siavashk/pycpd/docs.yml/master?enable=pin","Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/draft-pdf.yml:9: update your workflow using https://app.stepsecurity.io/secureworkflow/siavashk/pycpd/draft-pdf.yml/master?enable=pin","Warn: third-party GitHubAction not pinned by hash: .github/workflows/draft-pdf.yml:11: update your workflow using https://app.stepsecurity.io/secureworkflow/siavashk/pycpd/draft-pdf.yml/master?enable=pin","Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/draft-pdf.yml:17: update your workflow using https://app.stepsecurity.io/secureworkflow/siavashk/pycpd/draft-pdf.yml/master?enable=pin","Warn: pipCommand not pinned by hash: .github/workflows/build-test.yml:53","Info:   0 out of   8 GitHub-owned GitHubAction dependencies pinned","Info:   0 out of   1 third-party GitHubAction dependencies pinned","Info:   0 out of   1 pipCommand dependencies pinned"],"documentation":{"short":"Determines if the project has declared and pinned the dependencies of its build process.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#pinned-dependencies"}}]},"last_synced_at":"2025-08-23T15:52:04.569Z","repository_id":13186432,"created_at":"2025-08-23T15:52:04.570Z","updated_at":"2025-08-23T15:52:04.570Z"},"host":{"name":"GitHub","url":"https://github.com","kind":"github","repositories_count":273523047,"owners_count":25120859,"icon_url":"https://github.com/github.png","version":null,"created_at":"2022-05-30T11:31:42.601Z","updated_at":"2022-07-04T15:15:14.044Z","status":"online","status_checked_at":"2025-09-03T02:00:09.631Z","response_time":76,"last_error":null,"robots_txt_status":"success","robots_txt_updated_at":"2025-07-24T06:49:26.215Z","robots_txt_url":"https://github.com/robots.txt","online":true,"can_crawl_api":true,"host_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub","repositories_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories","repository_names_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repository_names","owners_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners"}},"owner":{"login":"siavashk","name":"Siavash Khallaghi","uuid":"1020752","kind":"user","description":"The work is mysterious and important.","email":"","website":"http://siavashk.github.io","location":"Vancouver, Canada","twitter":null,"company":"Unraveled AI","icon_url":"https://avatars.githubusercontent.com/u/1020752?u=820366ee7cd0b4cb1c5c2ee828666208cefe8d71\u0026v=4","repositories_count":21,"last_synced_at":"2025-08-27T22:57:44.255Z","metadata":{"has_sponsors_listing":true},"html_url":"https://github.com/siavashk","funding_links":["https://github.com/sponsors/siavashk"],"total_stars":630,"followers":59,"following":0,"created_at":"2022-11-06T22:43:30.269Z","updated_at":"2025-08-27T22:57:44.256Z","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/siavashk","repositories_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/siavashk/repositories"},"packages":[{"id":2868424,"name":"pycpd","ecosystem":"pypi","description":"Pure Numpy Implementation of the Coherent Point Drift Algorithm","homepage":"https://github.com/siavashk/pycpd","licenses":"MIT","normalized_licenses":["MIT"],"repository_url":"https://github.com/siavashk/pycpd","keywords_array":["image processing","point cloud","registration","mesh","surface"],"namespace":null,"versions_count":12,"first_release_published_at":"2017-03-15T20:13:15.000Z","latest_release_published_at":"2020-04-15T23:25:56.000Z","latest_release_number":"2.0.0","last_synced_at":"2025-09-03T22:35:52.563Z","created_at":"2022-04-10T12:11:16.270Z","updated_at":"2025-09-04T09:42:11.343Z","registry_url":"https://pypi.org/project/pycpd/","install_command":"pip install pycpd --index-url https://pypi.org/simple","documentation_url":"https://pycpd.readthedocs.io/","metadata":{"funding":null,"documentation":null,"classifiers":["Development Status :: 3 - Alpha","License :: OSI Approved :: MIT License","Programming Language :: Python :: 2.7","Programming Language :: Python :: 3.4","Programming Language :: Python :: 3.5","Programming Language :: Python :: 3.6","Topic :: Scientific/Engineering"],"normalized_name":"pycpd","project_status":null},"repo_metadata":{"id":13186432,"uuid":"71678665","full_name":"siavashk/pycpd","owner":"siavashk","description":"Pure Numpy Implementation of the Coherent Point Drift Algorithm","archived":false,"fork":false,"pushed_at":"2023-08-08T05:52:16.000Z","size":15069,"stargazers_count":568,"open_issues_count":6,"forks_count":124,"subscribers_count":14,"default_branch":"master","last_synced_at":"2025-08-31T21:16:09.412Z","etag":null,"topics":["expectation-maximization","point-cloud","python","registration"],"latest_commit_sha":null,"homepage":null,"language":"Python","has_issues":true,"has_wiki":null,"has_pages":null,"mirror_url":null,"source_name":null,"license":"mit","status":null,"scm":"git","pull_requests_enabled":true,"icon_url":"https://github.com/siavashk.png","metadata":{"files":{"readme":"README.rst","changelog":"CHANGES.txt","contributing":"CONTRIBUTING.md","funding":null,"license":"LICENSE","code_of_conduct":"CODE_OF_CONDUCT.md","threat_model":null,"audit":null,"citation":null,"codeowners":null,"security":null,"support":null,"governance":null,"roadmap":null,"authors":null,"dei":null,"publiccode":null,"codemeta":null,"zenodo":null}},"created_at":"2016-10-23T03:05:07.000Z","updated_at":"2025-08-04T11:37:47.000Z","dependencies_parsed_at":"2025-04-14T14:39:59.795Z","dependency_job_id":"3a63d650-ad69-4ba3-b0c7-db923e9ff0f0","html_url":"https://github.com/siavashk/pycpd","commit_stats":{"total_commits":165,"total_committers":18,"mean_commits":9.166666666666666,"dds":0.7333333333333334,"last_synced_commit":"e5ca02d2501fb4b633c1664de939c336ffa2349e"},"previous_names":[],"tags_count":2,"template":false,"template_full_name":null,"purl":"pkg:github/siavashk/pycpd","repository_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/siavashk%2Fpycpd","tags_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/siavashk%2Fpycpd/tags","releases_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/siavashk%2Fpycpd/releases","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/siavashk%2Fpycpd/manifests","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/siavashk","download_url":"https://codeload.github.com/siavashk/pycpd/tar.gz/refs/heads/master","sbom_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/siavashk%2Fpycpd/sbom","scorecard":{"id":822127,"data":{"date":"2025-08-11","repo":{"name":"github.com/siavashk/pycpd","commit":"e5ca02d2501fb4b633c1664de939c336ffa2349e"},"scorecard":{"version":"v5.2.1-40-gf6ed084d","commit":"f6ed084d17c9236477efd66e5b258b9d4cc7b389"},"score":3.1,"checks":[{"name":"Packaging","score":-1,"reason":"packaging workflow not detected","details":["Warn: no GitHub/GitLab publishing workflow detected."],"documentation":{"short":"Determines if the project is published as a package that others can easily download, install, easily update, and uninstall.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#packaging"}},{"name":"Maintained","score":0,"reason":"0 commit(s) and 0 issue activity found in the last 90 days -- score normalized to 0","details":null,"documentation":{"short":"Determines if the project is \"actively maintained\".","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#maintained"}},{"name":"Code-Review","score":3,"reason":"Found 3/10 approved changesets -- score normalized to 3","details":null,"documentation":{"short":"Determines if the project requires human code review before pull requests (aka merge requests) are merged.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#code-review"}},{"name":"Binary-Artifacts","score":10,"reason":"no binaries found in the repo","details":null,"documentation":{"short":"Determines if the project has generated executable (binary) artifacts in the source repository.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#binary-artifacts"}},{"name":"Dangerous-Workflow","score":10,"reason":"no dangerous workflow patterns detected","details":null,"documentation":{"short":"Determines if the project's GitHub Action workflows avoid dangerous patterns.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#dangerous-workflow"}},{"name":"Token-Permissions","score":0,"reason":"detected GitHub workflow tokens with excessive permissions","details":["Warn: no topLevel permission defined: .github/workflows/build-test.yml:1","Info: topLevel 'contents' permission set to 'read': .github/workflows/docs.yml:14","Warn: no topLevel permission defined: .github/workflows/draft-pdf.yml:1","Info: no jobLevel write permissions found"],"documentation":{"short":"Determines if the project's workflows follow the principle of least privilege.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#token-permissions"}},{"name":"CII-Best-Practices","score":0,"reason":"no effort to earn an OpenSSF best practices badge detected","details":null,"documentation":{"short":"Determines if the project has an OpenSSF (formerly CII) Best Practices Badge.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#cii-best-practices"}},{"name":"Security-Policy","score":0,"reason":"security policy file not detected","details":["Warn: no security policy file detected","Warn: no security file to analyze","Warn: no security file to analyze","Warn: no security file to analyze"],"documentation":{"short":"Determines if the project has published a security policy.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#security-policy"}},{"name":"License","score":10,"reason":"license file detected","details":["Info: project has a license file: LICENSE:0","Info: FSF or OSI recognized license: MIT License: LICENSE:0"],"documentation":{"short":"Determines if the project has defined a license.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#license"}},{"name":"Fuzzing","score":0,"reason":"project is not fuzzed","details":["Warn: no fuzzer integrations found"],"documentation":{"short":"Determines if the project uses fuzzing.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#fuzzing"}},{"name":"Signed-Releases","score":-1,"reason":"no releases found","details":null,"documentation":{"short":"Determines if the project cryptographically signs release artifacts.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#signed-releases"}},{"name":"Branch-Protection","score":0,"reason":"branch protection not enabled on development/release branches","details":["Warn: branch protection not enabled for branch 'master'"],"documentation":{"short":"Determines if the default and release branches are protected with GitHub's branch protection settings.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#branch-protection"}},{"name":"Vulnerabilities","score":3,"reason":"7 existing vulnerabilities detected","details":["Warn: Project is vulnerable to: PYSEC-2018-34 / GHSA-2fc2-6r4j-p65h","Warn: Project is vulnerable to: PYSEC-2021-856 / GHSA-5545-2q6w-2gh6","Warn: Project is vulnerable to: PYSEC-2019-108 / GHSA-9fq2-x9r6-wfmf","Warn: Project is vulnerable to: PYSEC-2018-33 / GHSA-cw6w-4rcx-xphc","Warn: Project is vulnerable to: PYSEC-2021-857 / GHSA-f7c7-j99h-c22f","Warn: Project is vulnerable to: GHSA-fpfv-jqm9-f5jm","Warn: Project is vulnerable to: PYSEC-2017-1 / GHSA-frgw-fgh6-9g52"],"documentation":{"short":"Determines if the project has open, known unfixed vulnerabilities.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#vulnerabilities"}},{"name":"SAST","score":0,"reason":"SAST tool is not run on all commits -- score normalized to 0","details":["Warn: 0 commits out of 27 are checked with a SAST tool"],"documentation":{"short":"Determines if the project uses static code analysis.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#sast"}},{"name":"Pinned-Dependencies","score":0,"reason":"dependency not pinned by hash detected -- score normalized to 0","details":["Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/build-test.yml:46: update your workflow using https://app.stepsecurity.io/secureworkflow/siavashk/pycpd/build-test.yml/master?enable=pin","Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/build-test.yml:48: update your workflow using https://app.stepsecurity.io/secureworkflow/siavashk/pycpd/build-test.yml/master?enable=pin","Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/docs.yml:21: update your workflow using https://app.stepsecurity.io/secureworkflow/siavashk/pycpd/docs.yml/master?enable=pin","Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/docs.yml:22: update your workflow using https://app.stepsecurity.io/secureworkflow/siavashk/pycpd/docs.yml/master?enable=pin","Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/docs.yml:31: update your workflow using https://app.stepsecurity.io/secureworkflow/siavashk/pycpd/docs.yml/master?enable=pin","Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/docs.yml:49: update your workflow using https://app.stepsecurity.io/secureworkflow/siavashk/pycpd/docs.yml/master?enable=pin","Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/draft-pdf.yml:9: update your workflow using https://app.stepsecurity.io/secureworkflow/siavashk/pycpd/draft-pdf.yml/master?enable=pin","Warn: third-party GitHubAction not pinned by hash: .github/workflows/draft-pdf.yml:11: update your workflow using https://app.stepsecurity.io/secureworkflow/siavashk/pycpd/draft-pdf.yml/master?enable=pin","Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/draft-pdf.yml:17: update your workflow using https://app.stepsecurity.io/secureworkflow/siavashk/pycpd/draft-pdf.yml/master?enable=pin","Warn: pipCommand not pinned by hash: .github/workflows/build-test.yml:53","Info:   0 out of   8 GitHub-owned GitHubAction dependencies pinned","Info:   0 out of   1 third-party GitHubAction dependencies pinned","Info:   0 out of   1 pipCommand dependencies pinned"],"documentation":{"short":"Determines if the project has declared and pinned the dependencies of its build process.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#pinned-dependencies"}}]},"last_synced_at":"2025-08-23T15:52:04.569Z","repository_id":13186432,"created_at":"2025-08-23T15:52:04.570Z","updated_at":"2025-08-23T15:52:04.570Z"},"host":{"name":"GitHub","url":"https://github.com","kind":"github","repositories_count":273523047,"owners_count":25120859,"icon_url":"https://github.com/github.png","version":null,"created_at":"2022-05-30T11:31:42.601Z","updated_at":"2022-07-04T15:15:14.044Z","status":"online","status_checked_at":"2025-09-03T02:00:09.631Z","response_time":76,"last_error":null,"robots_txt_status":"success","robots_txt_updated_at":"2025-07-24T06:49:26.215Z","robots_txt_url":"https://github.com/robots.txt","online":true,"can_crawl_api":true,"host_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub","repositories_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories","repository_names_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repository_names","owners_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners"},"owner_record":{"login":"siavashk","name":"Siavash Khallaghi","uuid":"1020752","kind":"user","description":"The work is mysterious and important.","email":"","website":"http://siavashk.github.io","location":"Vancouver, Canada","twitter":null,"company":"Unraveled AI","icon_url":"https://avatars.githubusercontent.com/u/1020752?u=820366ee7cd0b4cb1c5c2ee828666208cefe8d71\u0026v=4","repositories_count":21,"last_synced_at":"2025-08-27T22:57:44.255Z","metadata":{"has_sponsors_listing":true},"html_url":"https://github.com/siavashk","funding_links":["https://github.com/sponsors/siavashk"],"total_stars":630,"followers":59,"following":0,"created_at":"2022-11-06T22:43:30.269Z","updated_at":"2025-08-27T22:57:44.256Z","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/siavashk","repositories_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/siavashk/repositories"},"tags":[{"name":"v2.0.1-JOSS-Paper","sha":"83ffd5ae14ec898f4415f34ed6fd183c34026804","kind":"commit","published_at":"2022-11-17T20:06:55.000Z","download_url":"https://codeload.github.com/siavashk/pycpd/tar.gz/v2.0.1-JOSS-Paper","html_url":"https://github.com/siavashk/pycpd/releases/tag/v2.0.1-JOSS-Paper","dependencies_parsed_at":null,"dependency_job_id":null,"purl":"pkg:github/siavashk/pycpd@v2.0.1-JOSS-Paper","tag_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/siavashk%2Fpycpd/tags/v2.0.1-JOSS-Paper","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/siavashk%2Fpycpd/tags/v2.0.1-JOSS-Paper/manifests"},{"name":"v2.0.0-JOSS-Paper","sha":"83ffd5ae14ec898f4415f34ed6fd183c34026804","kind":"commit","published_at":"2022-11-17T20:06:55.000Z","download_url":"https://codeload.github.com/siavashk/pycpd/tar.gz/v2.0.0-JOSS-Paper","html_url":"https://github.com/siavashk/pycpd/releases/tag/v2.0.0-JOSS-Paper","dependencies_parsed_at":null,"dependency_job_id":null,"purl":"pkg:github/siavashk/pycpd@v2.0.0-JOSS-Paper","tag_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/siavashk%2Fpycpd/tags/v2.0.0-JOSS-Paper","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/siavashk%2Fpycpd/tags/v2.0.0-JOSS-Paper/manifests"}]},"repo_metadata_updated_at":"2025-09-04T09:42:11.343Z","dependent_packages_count":4,"downloads":2819,"downloads_period":"last-month","dependent_repos_count":9,"rankings":{"downloads":5.610405415684187,"dependent_repos_count":4.846951874708785,"dependent_packages_count":3.1684991089784917,"stargazers_count":2.9107400927968357,"forks_count":4.378804017041996,"docker_downloads_count":4.135374808160067,"average":4.175129219561727},"purl":"pkg:pypi/pycpd","advisories":[],"docker_usage_url":"https://docker.ecosyste.ms/usage/pypi/pycpd","docker_dependents_count":1,"docker_downloads_count":8,"usage_url":"https://repos.ecosyste.ms/usage/pypi/pycpd","dependent_repositories_url":"https://repos.ecosyste.ms/api/v1/usage/pypi/pycpd/dependencies","status":null,"funding_links":["https://github.com/sponsors/siavashk"],"critical":null,"issue_metadata":{"last_synced_at":"2025-08-31T21:13:04.410Z","issues_count":56,"pull_requests_count":41,"avg_time_to_close_issue":5681818.346153846,"avg_time_to_close_pull_request":3365466.717948718,"issues_closed_count":52,"pull_requests_closed_count":39,"pull_request_authors_count":18,"issue_authors_count":44,"avg_comments_per_issue":3.625,"avg_comments_per_pull_request":1.2195121951219512,"merged_pull_requests_count":30,"bot_issues_count":0,"bot_pull_requests_count":0,"past_year_issues_count":3,"past_year_pull_requests_count":5,"past_year_avg_time_to_close_issue":168694.5,"past_year_avg_time_to_close_pull_request":4335.0,"past_year_issues_closed_count":2,"past_year_pull_requests_closed_count":3,"past_year_pull_request_authors_count":4,"past_year_issue_authors_count":1,"past_year_avg_comments_per_issue":3.0,"past_year_avg_comments_per_pull_request":0.2,"past_year_bot_issues_count":0,"past_year_bot_pull_requests_count":0,"past_year_merged_pull_requests_count":0,"issues_url":"https://issues.ecosyste.ms/api/v1/hosts/GitHub/repositories/siavashk%2Fpycpd/issues","maintainers":[{"login":"gattia","count":23,"url":"https://issues.ecosyste.ms/api/v1/hosts/GitHub/authors/gattia"},{"login":"siavashk","count":5,"url":"https://issues.ecosyste.ms/api/v1/hosts/GitHub/authors/siavashk"},{"login":"agporto","count":3,"url":"https://issues.ecosyste.ms/api/v1/hosts/GitHub/authors/agporto"}],"active_maintainers":[]},"versions_url":"https://packages.ecosyste.ms/api/v1/registries/pypi.org/packages/pycpd/versions","version_numbers_url":"https://packages.ecosyste.ms/api/v1/registries/pypi.org/packages/pycpd/version_numbers","dependent_packages_url":"https://packages.ecosyste.ms/api/v1/registries/pypi.org/packages/pycpd/dependent_packages","related_packages_url":"https://packages.ecosyste.ms/api/v1/registries/pypi.org/packages/pycpd/related_packages","maintainers":[{"uuid":"siavashk","login":"siavashk","name":null,"email":null,"url":null,"packages_count":1,"html_url":"https://pypi.org/user/siavashk/","role":null,"created_at":"2023-02-23T07:39:04.929Z","updated_at":"2023-02-23T07:39:04.929Z","packages_url":"https://packages.ecosyste.ms/api/v1/registries/pypi.org/maintainers/siavashk/packages"}],"registry":{"name":"pypi.org","url":"https://pypi.org","ecosystem":"pypi","default":true,"packages_count":724713,"maintainers_count":308190,"namespaces_count":0,"keywords_count":237984,"github":"pypi","metadata":{"funded_packages_count":50481},"icon_url":"https://github.com/pypi.png","created_at":"2022-04-04T15:19:23.364Z","updated_at":"2025-09-04T05:23:51.177Z","packages_url":"https://packages.ecosyste.ms/api/v1/registries/pypi.org/packages","maintainers_url":"https://packages.ecosyste.ms/api/v1/registries/pypi.org/maintainers","namespaces_url":"https://packages.ecosyste.ms/api/v1/registries/pypi.org/namespaces"}}],"commits":{"id":635419,"full_name":"siavashk/pycpd","default_branch":"master","committers":[{"name":"Anthony Gatt","email":"anthony@neuralseg.com","login":"gattia","count":64},{"name":"Siavash Khallaghi","email":"siavashk@ece.ubc.ca","login":"siavashk","count":40},{"name":"Siavash Khallaghi","email":"siavash@Siavashs-MacBook-Pro.local","login":null,"count":12},{"name":"Siavash Khallaghi","email":"siavash.khallaghi@clarius.me","login":null,"count":9},{"name":"mhr","email":"mhr","login":"mhr","count":9},{"name":"Siavash Khallaghi","email":"siavash@SiavashsMacBook.hitronhub.home","login":null,"count":8},{"name":"Arthur Porto","email":"agporto@gmail.com","login":"agporto","count":7},{"name":"Siavash Khallaghi","email":"siavash@dhcp-128-189-223-115.ubcsecure.wireless.ubc.ca","login":null,"count":3},{"name":"Siavash Khallaghi","email":"siavash@dhcp-128-189-220-204.ubcsecure.wireless.ubc.ca","login":null,"count":3},{"name":"Matthew DiFranco","email":"mdifranc@gmail.com","login":"mdifranc","count":2},{"name":"Hugo Ledoux","email":"h.ledoux@tudelft.nl","login":"hugoledoux","count":2},{"name":"Mariem Khlifi","email":"mariemkhlifi16@gmail.com","login":"khmariem","count":1},{"name":"Johan Forslund","email":"johanforslund95@gmail.com","login":"johanforslund","count":1},{"name":"Chaitanya","email":"kolluru.chaitanya@gmail.com","login":"ckolluru","count":1},{"name":"Brandon Dube","email":"brandondube@gmail.com","login":"brandondube","count":1},{"name":"WEI-CHUN KAO","email":"weichun@omnibpm.com","login":"wckao","count":1},{"name":"vincentme","email":"11166542+vincentme","login":"vincentme","count":1}],"total_commits":165,"total_committers":17,"total_bot_commits":0,"total_bot_committers":0,"mean_commits":9.705882352941176,"dds":0.6121212121212121,"past_year_committers":[],"past_year_total_commits":0,"past_year_total_committers":0,"past_year_total_bot_commits":0,"past_year_total_bot_committers":0,"past_year_mean_commits":0.0,"past_year_dds":0.0,"last_synced_at":"2025-08-07T08:02:11.034Z","last_synced_commit":"e5ca02d2501fb4b633c1664de939c336ffa2349e","created_at":"2023-03-09T08:35:24.634Z","updated_at":"2025-08-07T08:02:11.043Z","commits_url":"https://commits.ecosyste.ms/api/v1/hosts/GitHub/repositories/siavashk%2Fpycpd/commits","host":{"name":"GitHub","url":"https://github.com","kind":"github","last_synced_at":"2025-08-15T00:00:12.661Z","repositories_count":5478304,"commits_count":853215663,"contributors_count":31091519,"owners_count":906513,"icon_url":"https://github.com/github.png","host_url":"https://commits.ecosyste.ms/api/v1/hosts/GitHub","repositories_url":"https://commits.ecosyste.ms/api/v1/hosts/GitHub/repositories"}},"issues_stats":{"full_name":"siavashk/pycpd","html_url":"https://github.com/siavashk/pycpd","last_synced_at":"2025-08-31T21:13:04.410Z","status":"error","issues_count":56,"pull_requests_count":41,"avg_time_to_close_issue":5681818.346153846,"avg_time_to_close_pull_request":3365466.717948718,"issues_closed_count":52,"pull_requests_closed_count":39,"pull_request_authors_count":18,"issue_authors_count":44,"avg_comments_per_issue":3.625,"avg_comments_per_pull_request":1.2195121951219512,"merged_pull_requests_count":30,"bot_issues_count":0,"bot_pull_requests_count":0,"past_year_issues_count":3,"past_year_pull_requests_count":5,"past_year_avg_time_to_close_issue":168694.5,"past_year_avg_time_to_close_pull_request":4335.0,"past_year_issues_closed_count":2,"past_year_pull_requests_closed_count":3,"past_year_pull_request_authors_count":4,"past_year_issue_authors_count":1,"past_year_avg_comments_per_issue":3.0,"past_year_avg_comments_per_pull_request":0.2,"past_year_bot_issues_count":0,"past_year_bot_pull_requests_count":0,"past_year_merged_pull_requests_count":0,"created_at":"2023-05-14T21:00:00.923Z","updated_at":"2025-09-02T09:25:38.162Z","repository_url":"https://issues.ecosyste.ms/api/v1/hosts/GitHub/repositories/siavashk%2Fpycpd","issues_url":"https://issues.ecosyste.ms/api/v1/hosts/GitHub/repositories/siavashk%2Fpycpd/issues","issue_labels_count":{"bug":6,"stat:awaiting response":4,"help wanted":4,"question":4,"documentation":1,"enhancement":1},"pull_request_labels_count":{},"issue_author_associations_count":{"NONE":46,"OWNER":5,"COLLABORATOR":5},"pull_request_author_associations_count":{"COLLABORATOR":21,"CONTRIBUTOR":12,"NONE":11},"issue_authors":{"siavashk":5,"rejuce":4,"gattia":3,"BramshQamar":2,"stevenagl12":2,"sandyhsia":2,"agporto":2,"Harry710887048":1,"wbensvage":1,"ka-petrov":1,"Theophile88":1,"tlambert03":1,"necoxt":1,"mingweiY":1,"Reno989":1,"gaetanmrnd":1,"yenlianglintw":1,"junqiangchen":1,"bhjbvs":1,"mirickmi":1,"zexinyang":1,"GeomRJ":1,"mxf8bv":1,"munsanje":1,"cheng043":1,"Ritchizh":1,"MathieuLatulippe":1,"clausmichele":1,"a2mattreed":1,"schlegelp":1,"evolvedmicrobe":1,"normanius":1,"Kai-46":1,"aalavandhaann":1,"jflucph":1,"alvinwan":1,"ghost":1,"sandwich25":1,"fengyasi":1,"rebeen":1,"sheridan-fong":1,"aaman-ee":1,"rickie95":1},"pull_request_authors":{"gattia":20,"rejuce":3,"mdifranc":2,"wckao":2,"Nikitos1865":2,"hugoledoux":2,"omarhmoursy":2,"mhr":1,"vincentme":1,"sandyhsia":1,"ckolluru":1,"STForyoung":1,"ghost":1,"brandondube":1,"khmariem":1,"agporto":1,"johanforslund":1,"kylewang1999":1},"host":{"name":"GitHub","url":"https://github.com","kind":"github","last_synced_at":"2025-09-02T00:00:07.986Z","repositories_count":10032651,"issues_count":30500402,"pull_requests_count":90614348,"authors_count":10347922,"icon_url":"https://github.com/github.png","host_url":"https://issues.ecosyste.ms/api/v1/hosts/GitHub","repositories_url":"https://issues.ecosyste.ms/api/v1/hosts/GitHub/repositories","owners_url":"https://issues.ecosyste.ms/api/v1/hosts/GitHub/owners","authors_url":"https://issues.ecosyste.ms/api/v1/hosts/GitHub/authors"},"past_year_issue_labels_count":{},"past_year_pull_request_labels_count":{},"past_year_issue_author_associations_count":{"NONE":4},"past_year_pull_request_author_associations_count":{"NONE":8},"past_year_issue_authors":{"rejuce":4},"past_year_pull_request_authors":{"rejuce":3,"Nikitos1865":2,"omarhmoursy":2,"STForyoung":1},"maintainers":[{"login":"gattia","count":23,"url":"https://issues.ecosyste.ms/api/v1/hosts/GitHub/authors/gattia"},{"login":"siavashk","count":5,"url":"https://issues.ecosyste.ms/api/v1/hosts/GitHub/authors/siavashk"},{"login":"agporto","count":3,"url":"https://issues.ecosyste.ms/api/v1/hosts/GitHub/authors/agporto"}],"active_maintainers":[]},"events":{"total":{"WatchEvent":42,"PullRequestEvent":3,"ForkEvent":7},"last_year":{"WatchEvent":42,"PullRequestEvent":3,"ForkEvent":7}},"keywords":["expectation-maximization","point-cloud","python","registration"],"dependencies":[{"ecosystem":"actions","filepath":".github/workflows/build-test.yml","sha":null,"kind":"manifest","created_at":"2023-01-13T17:45:12.347Z","updated_at":"2023-01-13T17:45:12.347Z","repository_link":"https://github.com/siavashk/pycpd/blob/master/.github/workflows/build-test.yml","dependencies":[{"id":6890933750,"package_name":"actions/checkout","ecosystem":"actions","requirements":"v2","direct":true,"kind":"composite","optional":false},{"id":6890933751,"package_name":"actions/setup-python","ecosystem":"actions","requirements":"v2","direct":true,"kind":"composite","optional":false}]},{"ecosystem":"actions","filepath":".github/workflows/docs.yml","sha":null,"kind":"manifest","created_at":"2023-01-13T17:45:12.377Z","updated_at":"2023-01-13T17:45:12.377Z","repository_link":"https://github.com/siavashk/pycpd/blob/master/.github/workflows/docs.yml","dependencies":[{"id":6890933758,"package_name":"actions/checkout","ecosystem":"actions","requirements":"v3","direct":true,"kind":"composite","optional":false},{"id":6890933759,"package_name":"actions/setup-python","ecosystem":"actions","requirements":"v3","direct":true,"kind":"composite","optional":false},{"id":6890933760,"package_name":"actions/upload-artifact","ecosystem":"actions","requirements":"v3","direct":true,"kind":"composite","optional":false},{"id":6890933761,"package_name":"actions/deploy-pages","ecosystem":"actions","requirements":"v1","direct":true,"kind":"composite","optional":false}]},{"ecosystem":"actions","filepath":".github/workflows/draft-pdf.yml","sha":null,"kind":"manifest","created_at":"2023-01-13T17:45:12.416Z","updated_at":"2023-01-13T17:45:12.416Z","repository_link":"https://github.com/siavashk/pycpd/blob/master/.github/workflows/draft-pdf.yml","dependencies":[{"id":6890933762,"package_name":"actions/checkout","ecosystem":"actions","requirements":"v2","direct":true,"kind":"composite","optional":false},{"id":6890933763,"package_name":"openjournals/openjournals-draft-action","ecosystem":"actions","requirements":"master","direct":true,"kind":"composite","optional":false},{"id":6890933764,"package_name":"actions/upload-artifact","ecosystem":"actions","requirements":"v1","direct":true,"kind":"composite","optional":false}]},{"ecosystem":"pypi","filepath":"requirements.txt","sha":null,"kind":"manifest","created_at":"2023-01-13T17:45:12.447Z","updated_at":"2023-01-13T17:45:12.447Z","repository_link":"https://github.com/siavashk/pycpd/blob/master/requirements.txt","dependencies":[{"id":6890933765,"package_name":"numpy","ecosystem":"pypi","requirements":"*","direct":true,"kind":"runtime","optional":false}]},{"ecosystem":"pypi","filepath":"setup.py","sha":null,"kind":"manifest","created_at":"2023-01-13T17:45:12.475Z","updated_at":"2023-01-13T17:45:12.475Z","repository_link":"https://github.com/siavashk/pycpd/blob/master/setup.py","dependencies":[{"id":6890933770,"package_name":"numpy","ecosystem":"pypi","requirements":"*","direct":true,"kind":"runtime","optional":false},{"id":6890933771,"package_name":"future","ecosystem":"pypi","requirements":"*","direct":true,"kind":"runtime","optional":false}]}],"score":17.138106049032828,"created_at":"2025-09-04T09:17:46.314Z","updated_at":"2025-10-07T08:04:31.355Z","avatar_url":"https://github.com/siavashk.png","language":"Python","category":"Scientific Software","sub_category":"Peer-reviewed","monthly_downloads":2819,"funding_links":[],"readme_doi_urls":["https://doi.org/10.21105/joss.04681"],"works":{},"citation_counts":{},"total_citations":0,"keywords_from_contributors":[],"project_url":"https://science.ecosyste.ms/api/v1/projects/1299","html_url":"https://science.ecosyste.ms/projects/1299"}