From e4997e3d440bcfead36b487d7526e232f1903c1e Mon Sep 17 00:00:00 2001 From: GitHub Action <41898282+github-actions[bot]@users.noreply.github.com> Date: Thu, 21 Mar 2024 08:55:26 +0000 Subject: [PATCH] Update _config.yml [ci skip] --- .editorconfig | 13 - .gitattributes | 10 - .github/CONTRIBUTING.md | 23 - .github/FUNDING.yml | 2 - .github/ISSUE_TEMPLATE/bug_report.md | 68 - .github/ISSUE_TEMPLATE/bug_report.yml | 81 - .github/ISSUE_TEMPLATE/config.yml | 5 - .github/ISSUE_TEMPLATE/documentation.md | 16 - .github/ISSUE_TEMPLATE/documentation.yml | 25 - .github/Instructions_members.md | 56 - .github/PULL_REQUEST_TEMPLATE.md | 31 - .github/workflows/bad-pr.yml | 18 - .github/workflows/deploy.yml | 47 - .travis.yml | 11 - 404.html | 114 + Gemfile | 6 - _bibliography/ieee-with-url-mod.csl | 331 - _bibliography/uscl_publications.bib | 1172 --- _config.yml | 75 - _data/alumni_bsc.yml | 1 - _data/alumni_members.yml | 6 - _data/alumni_msc.yml | 29 - _data/alumni_visitors.yml | 1 - _data/news.yml | 132 - _data/pictures_Uppsala.yml | 2 - _data/project.yml | 125 - _data/publist.yml | 22 - _data/research_themes.yml | 86 - _data/students.yml | 55 - _data/team_members.yml | 177 - _includes/analytics.html | 10 - _includes/footer.html | 36 - _includes/head.html | 16 - _includes/header.html | 31 - _includes/news.html | 11 - _includes/youtubePlayer.html | 11 - _layouts/bib.html | 71 - _layouts/bib_backup.html | 118 - _layouts/default.html | 20 - _layouts/gridlay.html | 6 - _layouts/gridlay2.html | 6 - _layouts/homelay.html | 15 - _layouts/page.html | 14 - _layouts/piclay.html | 7 - _layouts/post.html | 15 - _layouts/publications.html | 10 - _layouts/research.html | 6 - _layouts/team.html | 7 - _layouts/textlay.html | 6 - _pages/404.md | 10 - _pages/aboutwebsite.md | 48 - _pages/allnews.md | 16 - _pages/allprojects.md | 62 - _pages/funding.md | 89 - _pages/home.md | 82 - _pages/openings.md | 62 - _pages/publications.md | 93 - _pages/research.md | 103 - _pages/research_results.md | 87 - _pages/team.md | 193 - _plugins/hideCustomBibtex.rb | 15 - _plugins/markdown.rb | 23 - _sass/_bootstrap.scss | 58 - _sass/_publications.scss | 133 - _sass/_themes.scss | 65 - _sass/_variables.scss | 38 - _sass/bootstrap/_alerts.scss | 73 - _sass/bootstrap/_badges.scss | 68 - _sass/bootstrap/_bootswatch.scss | 523 -- _sass/bootstrap/_breadcrumbs.scss | 28 - _sass/bootstrap/_button-groups.scss | 244 - _sass/bootstrap/_buttons.scss | 349 - _sass/bootstrap/_carousel.scss | 270 - _sass/bootstrap/_close.scss | 36 - _sass/bootstrap/_code.scss | 69 - _sass/bootstrap/_component-animations.scss | 37 - _sass/bootstrap/_dropdowns.scss | 216 - _sass/bootstrap/_forms.scss | 617 -- _sass/bootstrap/_glyphicons.scss | 307 - _sass/bootstrap/_grid.scss | 84 - _sass/bootstrap/_input-groups.scss | 171 - _sass/bootstrap/_jumbotron.scss | 54 - _sass/bootstrap/_labels.scss | 66 - _sass/bootstrap/_list-group.scss | 130 - _sass/bootstrap/_media.scss | 66 - _sass/bootstrap/_mixins.scss | 40 - _sass/bootstrap/_modals.scss | 150 - _sass/bootstrap/_navbar.scss | 662 -- _sass/bootstrap/_navs.scss | 242 - _sass/bootstrap/_normalize.scss | 424 - _sass/bootstrap/_pager.scss | 54 - _sass/bootstrap/_pagination.scss | 89 - _sass/bootstrap/_panels.scss | 271 - _sass/bootstrap/_popovers.scss | 131 - _sass/bootstrap/_print.scss | 101 - _sass/bootstrap/_progress-bars.scss | 87 - _sass/bootstrap/_responsive-embed.scss | 35 - _sass/bootstrap/_responsive-utilities.scss | 179 - _sass/bootstrap/_scaffolding.scss | 161 - _sass/bootstrap/_tables.scss | 234 - _sass/bootstrap/_theme.scss | 291 - _sass/bootstrap/_thumbnails.scss | 38 - _sass/bootstrap/_tooltip.scss | 101 - _sass/bootstrap/_type.scss | 298 - _sass/bootstrap/_utilities.scss | 55 - _sass/bootstrap/_variables copy.scss | 874 -- _sass/bootstrap/_variables.scss | 870 -- _sass/bootstrap/_wells.scss | 67 - _sass/bootstrap/mixins/_alerts.scss | 14 - .../bootstrap/mixins/_background-variant.scss | 12 - _sass/bootstrap/mixins/_border-radius.scss | 18 - _sass/bootstrap/mixins/_buttons.scss | 65 - _sass/bootstrap/mixins/_center-block.scss | 7 - _sass/bootstrap/mixins/_clearfix.scss | 22 - _sass/bootstrap/mixins/_forms.scss | 88 - _sass/bootstrap/mixins/_gradients.scss | 58 - _sass/bootstrap/mixins/_grid-framework.scss | 81 - _sass/bootstrap/mixins/_grid.scss | 122 - _sass/bootstrap/mixins/_hide-text.scss | 21 - _sass/bootstrap/mixins/_image.scss | 33 - _sass/bootstrap/mixins/_labels.scss | 12 - _sass/bootstrap/mixins/_list-group.scss | 32 - _sass/bootstrap/mixins/_nav-divider.scss | 10 - .../bootstrap/mixins/_nav-vertical-align.scss | 9 - _sass/bootstrap/mixins/_opacity.scss | 8 - _sass/bootstrap/mixins/_pagination.scss | 24 - _sass/bootstrap/mixins/_panels.scss | 24 - _sass/bootstrap/mixins/_progress-bar.scss | 10 - _sass/bootstrap/mixins/_reset-filter.scss | 8 - _sass/bootstrap/mixins/_reset-text.scss | 18 - _sass/bootstrap/mixins/_resize.scss | 6 - .../mixins/_responsive-visibility.scss | 21 - _sass/bootstrap/mixins/_size.scss | 10 - _sass/bootstrap/mixins/_tab-focus.scss | 9 - _sass/bootstrap/mixins/_table-row.scss | 28 - _sass/bootstrap/mixins/_text-emphasis.scss | 12 - _sass/bootstrap/mixins/_text-overflow.scss | 8 - _sass/bootstrap/mixins/_vendor-prefixes.scss | 222 - aboutwebsite.html | 153 + allnews.html | 327 + allprojects.html | 340 + css/main.css | 8097 +++++++++++++++++ css/main.css.map | 1 + css/main.scss | 140 - funding/index.html | 374 + index.html | 217 + openings.html | 157 + publications/index.html | 6584 ++++++++++++++ research/index.html | 2032 +++++ research/research_results/index.html | 1959 ++++ team/index.html | 565 ++ 151 files changed, 20920 insertions(+), 14233 deletions(-) delete mode 100644 .editorconfig delete mode 100644 .gitattributes delete mode 100644 .github/CONTRIBUTING.md delete mode 100644 .github/FUNDING.yml delete mode 100644 .github/ISSUE_TEMPLATE/bug_report.md delete mode 100644 .github/ISSUE_TEMPLATE/bug_report.yml delete mode 100644 .github/ISSUE_TEMPLATE/config.yml delete mode 100644 .github/ISSUE_TEMPLATE/documentation.md delete mode 100644 .github/ISSUE_TEMPLATE/documentation.yml delete mode 100644 .github/Instructions_members.md delete mode 100644 .github/PULL_REQUEST_TEMPLATE.md delete mode 100644 .github/workflows/bad-pr.yml delete mode 100644 .github/workflows/deploy.yml delete mode 100644 .travis.yml create mode 100644 404.html delete mode 100644 Gemfile delete mode 100644 _bibliography/ieee-with-url-mod.csl delete mode 100644 _bibliography/uscl_publications.bib delete mode 100644 _config.yml delete mode 100644 _data/alumni_bsc.yml delete mode 100644 _data/alumni_members.yml delete mode 100644 _data/alumni_msc.yml delete mode 100644 _data/alumni_visitors.yml delete mode 100644 _data/news.yml delete mode 100644 _data/pictures_Uppsala.yml delete mode 100644 _data/project.yml delete mode 100644 _data/publist.yml delete mode 100644 _data/research_themes.yml delete mode 100644 _data/students.yml delete mode 100644 _data/team_members.yml delete mode 100644 _includes/analytics.html delete mode 100644 _includes/footer.html delete mode 100644 _includes/head.html delete mode 100644 _includes/header.html delete mode 100644 _includes/news.html delete mode 100644 _includes/youtubePlayer.html delete mode 100644 _layouts/bib.html delete mode 100644 _layouts/bib_backup.html delete mode 100644 _layouts/default.html delete mode 100644 _layouts/gridlay.html delete mode 100644 _layouts/gridlay2.html delete mode 100644 _layouts/homelay.html delete mode 100644 _layouts/page.html delete mode 100644 _layouts/piclay.html delete mode 100644 _layouts/post.html delete mode 100644 _layouts/publications.html delete mode 100644 _layouts/research.html delete mode 100644 _layouts/team.html delete mode 100644 _layouts/textlay.html delete mode 100755 _pages/404.md delete mode 100644 _pages/aboutwebsite.md delete mode 100644 _pages/allnews.md delete mode 100644 _pages/allprojects.md delete mode 100644 _pages/funding.md delete mode 100644 _pages/home.md delete mode 100644 _pages/openings.md delete mode 100644 _pages/publications.md delete mode 100644 _pages/research.md delete mode 100644 _pages/research_results.md delete mode 100644 _pages/team.md delete mode 100644 _plugins/hideCustomBibtex.rb delete mode 100644 _plugins/markdown.rb delete mode 100644 _sass/_bootstrap.scss delete mode 100644 _sass/_publications.scss delete mode 100644 _sass/_themes.scss delete mode 100644 _sass/_variables.scss delete mode 100644 _sass/bootstrap/_alerts.scss delete mode 100644 _sass/bootstrap/_badges.scss delete mode 100644 _sass/bootstrap/_bootswatch.scss delete mode 100644 _sass/bootstrap/_breadcrumbs.scss delete mode 100644 _sass/bootstrap/_button-groups.scss delete mode 100644 _sass/bootstrap/_buttons.scss delete mode 100644 _sass/bootstrap/_carousel.scss delete mode 100644 _sass/bootstrap/_close.scss delete mode 100644 _sass/bootstrap/_code.scss delete mode 100644 _sass/bootstrap/_component-animations.scss delete mode 100644 _sass/bootstrap/_dropdowns.scss delete mode 100644 _sass/bootstrap/_forms.scss delete mode 100644 _sass/bootstrap/_glyphicons.scss delete mode 100644 _sass/bootstrap/_grid.scss delete mode 100644 _sass/bootstrap/_input-groups.scss delete mode 100644 _sass/bootstrap/_jumbotron.scss delete mode 100644 _sass/bootstrap/_labels.scss delete mode 100644 _sass/bootstrap/_list-group.scss delete mode 100644 _sass/bootstrap/_media.scss delete mode 100644 _sass/bootstrap/_mixins.scss delete mode 100644 _sass/bootstrap/_modals.scss delete mode 100644 _sass/bootstrap/_navbar.scss delete mode 100644 _sass/bootstrap/_navs.scss delete mode 100644 _sass/bootstrap/_normalize.scss delete mode 100644 _sass/bootstrap/_pager.scss delete mode 100644 _sass/bootstrap/_pagination.scss delete mode 100644 _sass/bootstrap/_panels.scss delete mode 100644 _sass/bootstrap/_popovers.scss delete mode 100644 _sass/bootstrap/_print.scss delete mode 100644 _sass/bootstrap/_progress-bars.scss delete mode 100644 _sass/bootstrap/_responsive-embed.scss delete mode 100644 _sass/bootstrap/_responsive-utilities.scss delete mode 100644 _sass/bootstrap/_scaffolding.scss delete mode 100644 _sass/bootstrap/_tables.scss delete mode 100644 _sass/bootstrap/_theme.scss delete mode 100644 _sass/bootstrap/_thumbnails.scss delete mode 100644 _sass/bootstrap/_tooltip.scss delete mode 100644 _sass/bootstrap/_type.scss delete mode 100644 _sass/bootstrap/_utilities.scss delete mode 100644 _sass/bootstrap/_variables copy.scss delete mode 100644 _sass/bootstrap/_variables.scss delete mode 100644 _sass/bootstrap/_wells.scss delete mode 100644 _sass/bootstrap/mixins/_alerts.scss delete mode 100644 _sass/bootstrap/mixins/_background-variant.scss delete mode 100644 _sass/bootstrap/mixins/_border-radius.scss delete mode 100644 _sass/bootstrap/mixins/_buttons.scss delete mode 100644 _sass/bootstrap/mixins/_center-block.scss delete mode 100644 _sass/bootstrap/mixins/_clearfix.scss delete mode 100644 _sass/bootstrap/mixins/_forms.scss delete mode 100644 _sass/bootstrap/mixins/_gradients.scss delete mode 100644 _sass/bootstrap/mixins/_grid-framework.scss delete mode 100644 _sass/bootstrap/mixins/_grid.scss delete mode 100644 _sass/bootstrap/mixins/_hide-text.scss delete mode 100644 _sass/bootstrap/mixins/_image.scss delete mode 100644 _sass/bootstrap/mixins/_labels.scss delete mode 100644 _sass/bootstrap/mixins/_list-group.scss delete mode 100644 _sass/bootstrap/mixins/_nav-divider.scss delete mode 100644 _sass/bootstrap/mixins/_nav-vertical-align.scss delete mode 100644 _sass/bootstrap/mixins/_opacity.scss delete mode 100644 _sass/bootstrap/mixins/_pagination.scss delete mode 100644 _sass/bootstrap/mixins/_panels.scss delete mode 100644 _sass/bootstrap/mixins/_progress-bar.scss delete mode 100644 _sass/bootstrap/mixins/_reset-filter.scss delete mode 100644 _sass/bootstrap/mixins/_reset-text.scss delete mode 100644 _sass/bootstrap/mixins/_resize.scss delete mode 100644 _sass/bootstrap/mixins/_responsive-visibility.scss delete mode 100644 _sass/bootstrap/mixins/_size.scss delete mode 100644 _sass/bootstrap/mixins/_tab-focus.scss delete mode 100644 _sass/bootstrap/mixins/_table-row.scss delete mode 100644 _sass/bootstrap/mixins/_text-emphasis.scss delete mode 100644 _sass/bootstrap/mixins/_text-overflow.scss delete mode 100644 _sass/bootstrap/mixins/_vendor-prefixes.scss create mode 100644 aboutwebsite.html create mode 100644 allnews.html create mode 100644 allprojects.html create mode 100644 css/main.css create mode 100644 css/main.css.map delete mode 100644 css/main.scss create mode 100644 funding/index.html create mode 100644 index.html create mode 100644 openings.html create mode 100644 publications/index.html create mode 100644 research/index.html create mode 100644 research/research_results/index.html create mode 100644 team/index.html diff --git a/.editorconfig b/.editorconfig deleted file mode 100644 index 3a287c45..00000000 --- a/.editorconfig +++ /dev/null @@ -1,13 +0,0 @@ -# editorconfig.org -root = true - -[*] -indent_style = space -indent_size = 2 -end_of_line = lf -charset = utf-8 -trim_trailing_whitespace = true -insert_final_newline = false - -[*.md] -trim_trailing_whitespace = false diff --git a/.gitattributes b/.gitattributes deleted file mode 100644 index 4d536e4a..00000000 --- a/.gitattributes +++ /dev/null @@ -1,10 +0,0 @@ -assets/fonts/* linguist-vendored -assets/js/main.min.js linguist-vendored -assets/js/lunr/* linguist-vendored -assets/js/plugins/* linguist-vendored -assets/js/vendor/* linguist-vendored -_sass/minimal-mistakes/vendor/* linguist-vendored -CHANGELOG.md text merge=union -docs/_docs/18-history.md text merge=union - -*.md text diff --git a/.github/CONTRIBUTING.md b/.github/CONTRIBUTING.md deleted file mode 100644 index 847b69e8..00000000 --- a/.github/CONTRIBUTING.md +++ /dev/null @@ -1,23 +0,0 @@ -# Contributing - -Found a typo in the documentation or interested in [fixing a bug](https://github.com/mmistakes/minimal-mistakes/issues)? Then by all means [submit an issue](https://github.com/mmistakes/minimal-mistakes/issues/new) or [pull request](https://help.github.com/articles/using-pull-requests/). If this is your first pull request, it may be helpful to read up on the [GitHub Flow](https://guides.github.com/introduction/flow/) first. - -For help with using the theme or general Jekyll support questions, please use the [Jekyll Talk forums](https://talk.jekyllrb.com/). - -Minimal Mistakes has been designed as a base for you to customize and fit your -site's unique needs. Please keep this in mind when requesting features and/or -submitting pull requests. If it's not something that most people will use, I -probably won't consider it. When in doubt ask. - -This goes for author sidebar links and "share button" additions -- I have no -intention of merging in every possibly option, the essentials are there to get -you started :smile:. - -## Pull Requests - -When submitting a pull request: - -1. Clone the repo. -2. Create a branch off of `master` and give it a meaningful name (e.g. - `my-awesome-new-feature`) and describe the feature or fix. -3. Open a pull request on GitHub. diff --git a/.github/FUNDING.yml b/.github/FUNDING.yml deleted file mode 100644 index 72c3cf2e..00000000 --- a/.github/FUNDING.yml +++ /dev/null @@ -1,2 +0,0 @@ -github: mmistakes -custom: ['https://www.paypal.me/mmistakes'] diff --git a/.github/ISSUE_TEMPLATE/bug_report.md b/.github/ISSUE_TEMPLATE/bug_report.md deleted file mode 100644 index cb3aac83..00000000 --- a/.github/ISSUE_TEMPLATE/bug_report.md +++ /dev/null @@ -1,68 +0,0 @@ ---- -name: "Bug Report" -about: "Is something not working as expected?" ---- - - - -## Environment - - - -- Minimal Mistakes version: -- Ruby gem or remote theme version: -- Jekyll version: -- Git repository URL: -- Hosted on GitHub Pages (if yes provide URL to site): -- Operating system: - -## Expected behavior - - - -## Steps to reproduce the behavior - - - -## Other - - diff --git a/.github/ISSUE_TEMPLATE/bug_report.yml b/.github/ISSUE_TEMPLATE/bug_report.yml deleted file mode 100644 index 3adfbcd1..00000000 --- a/.github/ISSUE_TEMPLATE/bug_report.yml +++ /dev/null @@ -1,81 +0,0 @@ -name: Bug Report -description: There is something wrong with the theme. 99% of the time you should select Support below. -body: - - type: markdown - attributes: - value: | - Before opening a new issue please: - - - Verify you have the latest versions of Jekyll and Minimal Mistakes - installed by running `bundle update`. - - Thoroughly read the theme's documentation at - https://mmistakes.github.io/minimal-mistakes/docs/quick-start-guide/ - - Search all issues at https://github.com/mmistakes/minimal-mistakes/issues - for solutions and to avoid duplication. - - Ask for help at https://talk.jekyllrb.com/ - - If none of the above solved your problem, you can continue below. - - - type: textarea - id: environment - attributes: - label: What happened? - description: | - Please include theme version, Jekyll version, public git repository, whether - you are hosting with GitHub Pages, and the operating system you tested with. - - Issues without a link to a public repository or ZIP file will likely go ignored. - Being able to see your actual files is necessary to troubleshoot, as most - issues stem from invalid/missing YAML Front Matter, a mis-configured _config.yml - file, or problematic site content. - value: |- - - Minimal Mistakes version: - - Ruby gem or remote theme version: - - Jekyll version: - - Git repository URL: - - Hosted on GitHub Pages (if yes provide URL to site): - - Operating system: - validations: - required: true - - - type: textarea - id: expected-behavior - attributes: - label: Expected behavior - description: | - Please describe the expected behavior and the actual result you got. - placeholder: > - What is it you expected to happen? This should be a description of how the - functionality you tried to use is supposed to work. - validations: - required: true - - - type: textarea - id: steps-to-reproduce - attributes: - label: Steps to reproduce the behavior - description: | - Describe the steps you took for this problem to come up. Such as: you installed - the theme, customized _config.yml, added your own posts, and started up a - Jekyll server locally. - - If an error occurred on GitHub Pages when pushing, please test a local version - following these setup instructions: - https://help.github.com/articles/setting-up-your-github-pages-site-locally-with-jekyll/ - - Then provide a complete log by running `bundle exec jekyll build --trace --verbose` - and include this output in the filed issue. - - Screenshots can also be included if they help illustrate a behavior. - validations: - required: true - - - type: textarea - id: other - attributes: - label: Other - description: | - Please provide a code repository, gist, code snippet, sample files, - screenshots, or anything else you think will aid in reproducing the issue. - validations: - required: false \ No newline at end of file diff --git a/.github/ISSUE_TEMPLATE/config.yml b/.github/ISSUE_TEMPLATE/config.yml deleted file mode 100644 index e02be34d..00000000 --- a/.github/ISSUE_TEMPLATE/config.yml +++ /dev/null @@ -1,5 +0,0 @@ -blank_issues_enabled: false -contact_links: - - name: Support - url: https://github.com/mmistakes/minimal-mistakes/discussions - about: Please post your support questions in the Discussions section. \ No newline at end of file diff --git a/.github/ISSUE_TEMPLATE/documentation.md b/.github/ISSUE_TEMPLATE/documentation.md deleted file mode 100644 index 25f111fd..00000000 --- a/.github/ISSUE_TEMPLATE/documentation.md +++ /dev/null @@ -1,16 +0,0 @@ ---- -name: "Documentation" -about: "Found a typo or something that needs clarification?" ---- - - - -## Motivation - - - - - -## Suggestion - - \ No newline at end of file diff --git a/.github/ISSUE_TEMPLATE/documentation.yml b/.github/ISSUE_TEMPLATE/documentation.yml deleted file mode 100644 index 65a03152..00000000 --- a/.github/ISSUE_TEMPLATE/documentation.yml +++ /dev/null @@ -1,25 +0,0 @@ -name: Documentation -description: Found a typo or something that needs clarification? -body: - - type: markdown - attributes: - value: | - Thanks for taking the time to open an issue and help make the docs better. - - - type: textarea - id: motivation - attributes: - label: Motivation - description: | - Why should we update our docs? - validations: - required: true - - - type: textarea - id: suggestion - attributes: - label: Suggestion - description: | - What should we do instead? - validations: - required: true \ No newline at end of file diff --git a/.github/Instructions_members.md b/.github/Instructions_members.md deleted file mode 100644 index 728b2cc1..00000000 --- a/.github/Instructions_members.md +++ /dev/null @@ -1,56 +0,0 @@ -## How to update highlighted publications -This is done by creating a new entry at "\_data/publist.yml" -Each entry has several fields that must be completed. Two of them are especial: -1. 'highlight:'. This field is a flag that indicates whether (1) or not (0) the entry should be processed and included; -2. 'image:'. This field id the filename (with extension) of the image that will appear to the left. The image should be saved under the forlder 'images/pubpic/' - -### Here is the example of an entry on "\_data/publist.yml" -- title: "Safety, Security and Privacy for Cyber-Physical Systems" - image: Springer_book_2021.png - description: This book presents an in-depth overview of recent work related to the safety, security, and privacy of cyber-physical systems (CPSs). It brings together contributions from leading researchers in networked control systems and closely related fields to discuss overarching aspects of safety, security, and privacy; characterization of attacks; and solutions to detecting and mitigating such attacks.
The book begins by providing an insightful taxonomy of problems, challenges and techniques related to safety, security, and privacy for CPSs. It then moves through a thorough discussion of various control-based solutions to these challenges, including cooperative fault-tolerant and resilient control and estimation, detection of attacks and security metrics, watermarking and encrypted control, privacy and a novel defense approach based on deception. The book concludes by discussing risk management and cyber-insurance challenges in CPSs, and by presenting the future outlook for this area of research as a whole.
Its wide-ranging collection of varied works in the emerging fields of security and privacy in networked control systems makes this book a benefit to both academic researchers and advanced practitioners interested in implementing diverse applications in the fields of IoT, cooperative autonomous vehicles and the smart cities of the future. - authors: Riccardo M. G. Ferrari and André M. H. Teixeira (Eds) - year: 2021 - link: - url: https://doi.org/10.1007/978-3-030-65048-3 - display: Lecture Notes in Control and Information Sciences (LNCIS, volume 486), Springer International Publishing, (2021) - highlight: 1 - news2: - long: 1 - - - - -## How to update the the list of team members -The list of team members can be updated by modifing the data files "\_data/team_members.yml" and "\_data/students.yml" - -Save the profile photo of the team member in the file 'images/teampic/'. If a team member does have a photo, one can use the file 'bio-photo.jpg' as a "blank photo". - - -## How to update the News items -News items correspond to entries at '\_data/news.yml' -Items can be created continuosly, the website generator automatically keeps the 9 latests items for display at the front page. - - - -## How to update the publication list -There are two steps involved: -1. update the .bib file inside the folder '\_bibliography' -2. upload the corresponding PDF file to the folder 'assets/papers/' - -For step 1, see the minimal example below: -@inproceedings{Teixeira_CDC9999, - address={}, - author = {A. M. H. Teixeira}, - booktitle = {Conference}, - title = {The Fantastic Example}, - year = {9999}, - tag={}, - abstract = {This paper proposes...}, - doi = {10.1109/CDC51059.2022.9992468}, - arxiv = {2210.04091}, - pdf = {file_name} -} - -The final four fields are used to construct buttons that link to the respective items. The website's engine automatically ads prefix to the the DOI and Arxiv, and the '.pdf' suffix to the filename. - -The field tag is used to select the publication to be included in a given research theme (for now awe can use "tag" and "taga" for tagging up to 2 areas). \ No newline at end of file diff --git a/.github/PULL_REQUEST_TEMPLATE.md b/.github/PULL_REQUEST_TEMPLATE.md deleted file mode 100644 index 2c5d045a..00000000 --- a/.github/PULL_REQUEST_TEMPLATE.md +++ /dev/null @@ -1,31 +0,0 @@ - - - - - - - - -## Summary - - - -## Context - - - - diff --git a/.github/workflows/bad-pr.yml b/.github/workflows/bad-pr.yml deleted file mode 100644 index ce9de201..00000000 --- a/.github/workflows/bad-pr.yml +++ /dev/null @@ -1,18 +0,0 @@ -name: Cleanup bad PR - -on: - pull_request_target: - types: [opened, reopened] - -jobs: - close-pr: - runs-on: ubuntu-latest - if: "contains(github.event.pull_request.body, 'CHECK_PR_DID_NOT_CONFIRM') || github.event.pull_request.body == ''" - steps: - - uses: actions-ecosystem/action-add-labels@v1 - with: - labels: 'Type: Invalid' - - uses: superbrothers/close-pull-request@v3 - with: - # Optional. Post an issue comment just before closing a pull request. - comment: "This PR is not valid for inclusion. Please check again if you're submitting improvements for *the theme*." diff --git a/.github/workflows/deploy.yml b/.github/workflows/deploy.yml deleted file mode 100644 index e88d5e58..00000000 --- a/.github/workflows/deploy.yml +++ /dev/null @@ -1,47 +0,0 @@ -name: deploy - -on: - push: - branches: - - master - - main - -jobs: - deploy: - runs-on: ubuntu-latest - steps: - - name: Checkout code - uses: actions/checkout@v2 - - name: Setup Ruby - uses: ruby/setup-ruby@v1 - with: - ruby-version: '3.0.2' - - name: Enable bundler cache - uses: actions/cache@v2 - with: - path: vendor/bundle - key: ${{ runner.os }}-gems-${{ hashFiles('**/Gemfile.lock') }} - restore-keys: | - ${{ runner.os }}-gems- - - name: Install deps - run: | - gem install bundler - bundle config path vendor/bundle - bundle install --jobs 4 --retry 3 - npm install -g mermaid.cli - - name: Setup deploy options - id: setup - run: | - git config --global user.name "GitHub Action" - git config --global user.email "41898282+github-actions[bot]@users.noreply.github.com" - if [[ ${GITHUB_REF} = refs/pull/*/merge ]]; then # pull request - echo "::set-output name=SRC_BRANCH::${GITHUB_HEAD_REF}" - echo "::set-output name=NO_PUSH::--no-push" - elif [[ ${GITHUB_REF} = refs/heads/* ]]; then # branch, e.g. master, source etc - echo "::set-output name=SRC_BRANCH::${GITHUB_REF#refs/heads/}" - fi - echo "::set-output name=DEPLOY_BRANCH::gh-pages" - - name: Deploy website - run: yes | bash bin/deploy --verbose ${{ steps.setup.outputs.NO_PUSH }} - --src ${{ steps.setup.outputs.SRC_BRANCH }} - --deploy ${{ steps.setup.outputs.DEPLOY_BRANCH }} diff --git a/.travis.yml b/.travis.yml deleted file mode 100644 index 1bb28592..00000000 --- a/.travis.yml +++ /dev/null @@ -1,11 +0,0 @@ -language: ruby -cache: bundler -gemfile: docs/Gemfile -script: - - bundle exec jekyll algolia --source docs --destination docs/_site --config docs/_config.yml -branches: - only: - # Change this to gh-pages if you're deploying using the gh-pages branch - - master -rvm: - - 2.4 \ No newline at end of file diff --git a/404.html b/404.html new file mode 100644 index 00000000..93e78d03 --- /dev/null +++ b/404.html @@ -0,0 +1,114 @@ + + + + + + + + Page Not Found + + + + + + + + + + + + + + + + + + +
+
+

Sorry, but the page you were trying to view does not exist.

+ + +
+
+ + + + + + + + + + diff --git a/Gemfile b/Gemfile deleted file mode 100644 index f929174f..00000000 --- a/Gemfile +++ /dev/null @@ -1,6 +0,0 @@ -source 'https://rubygems.org' - -gem "jekyll", ">= 3.6.3" - -gem 'jekyll-scholar', group: :jekyll_plugins -gem "webrick", "~> 1.7" diff --git a/_bibliography/ieee-with-url-mod.csl b/_bibliography/ieee-with-url-mod.csl deleted file mode 100644 index 60a1d52b..00000000 --- a/_bibliography/ieee-with-url-mod.csl +++ /dev/null @@ -1,331 +0,0 @@ - - \ No newline at end of file diff --git a/_bibliography/uscl_publications.bib b/_bibliography/uscl_publications.bib deleted file mode 100644 index 74a144e1..00000000 --- a/_bibliography/uscl_publications.bib +++ /dev/null @@ -1,1172 +0,0 @@ - - -%%%%%%%%%%%%%%%%%% - - - -%%%%%%%%%%%%%%%%% Under Review - -@inproceedings{Ju2023, - address={}, - author = {L. Ju and T. Zhang and S. Toor and A. Hellander}, - booktitle = {(Submitted, 2023)}, - title = {Accelerating Fair Federated Learning: Adaptive Federated Adam}, - abstract = {Federated learning is a distributed and privacy-preserving approach to train a statistical model collaboratively from decentralized data of different parties. However, when datasets of participants are not independent and identically distributed (non-IID), models trained by naive federated algorithms may be biased towards certain participants, and model performance across participants is non-uniform. This is known as the fairness problem in federated learning. In this paper, we formulate fairness-controlled federated learning as a dynamical multi-objective optimization problem to ensure fair performance across all participants. To solve the problem efficiently, we study the convergence and bias of Adam as the server optimizer in federated learning, and propose Adaptive Federated Adam (AdaFedAdam) to accelerate fair federated learning with alleviated bias. We validated the effectiveness, Pareto optimality and robustness of AdaFedAdam in numerical experiments and show that AdaFedAdam outperforms existing algorithms, providing better convergence and fairness properties of the federated scheme.}, - published={0}, - arxiv={2301.09357}, - tag = {10003} -} - - -@article{Tung_TCNS2024, - author = {A. T. Nguyen and A. M. H. Teixeira and A. Medvedev}, - journal = {IEEE Trans. Control of Network Systems (Submitted)}, - number = {}, - pages = {}, - title = {Security Allocation in Networked Control Systems under Stealthy Attacks}, - abstract = {This paper considers the problem of security allocation in a networked control system under stealthy attacks in which the system is comprised of interconnected subsystems represented by vertices. A malicious adversary selects a single vertex on which to conduct a stealthy data injection attack to maximally disrupt the local performance while remaining undetected. On the other hand, a defender selects several vertices on which to allocate defense resources against the adversary. First, the objectives of the adversary and the defender with uncertain targets are formulated in probabilistic ways, resulting in an expected worst-case impact of stealthy attacks. Next, we provide a graph-theoretic necessary and sufficient condition under which the cost for the defender and the expected worst-case impact of stealthy attacks are bounded. This condition enables the defender to restrict the admissible actions to a subset of available vertex sets. Then, we cast the problem of security allocation in a Stackelberg game-theoretic framework. Finally, the contribution of this paper is highlighted by utilizing the proposed admissible actions of the defender in the context of large-scale networks. A numerical example of a 50-vertex networked control system is presented to validate the obtained results.}, - volume = {}, - year = {}, - arxiv={2308.16639}, - published={0}, - tag = {10005} -} - -@inproceedings{Anand_L4DC2024, - author = {S. C. Anand and M. S. Chong and A. M. H. Teixeira}, - booktitle = {Submitted to L4DC 2024}, - title = {Data-Driven Identification of Attack-free Sensors in Networked Control Systems}, - year = {}, - published={0}, - tag={} -} - - - -@inproceedings{Seifullaev_CDC024, - author = {R. Seifullaev and A. M. H. Teixeira and A. Ahl\'{e}n}, - booktitle = {Submitted}, - title = {Event-triggered control of nonlinear systems under deception and Denial-of-Service attacks}, - year = {}, - published={9999}, - tag={10004} -} - - - -%%%%%%%%%%% Up: under review - -@inproceedings{Arnstrom_ECC2024, - author = {D. Arnstr\"{o}m and A. M. H. Teixeira}, - booktitle = {European Control Conference (Accepted)}, - title = {Stealthy Deactivation of Safety Filters}, - year = {2024}, - abstract={Safety filters ensure that only safe control actions are executed. We propose a simple and stealthy false-data injection attack for deactivating such safety filters; in particular, we focus on deactivating safety filters that are based on controlbarrier functions. The attack injects false sensor measurements to bias state estimates to the interior of a safety region, which makes the safety filter accept unsafe control actions. To detect such attacks, we also propose a detector that detects biases manufactured by the proposed attack policy, which complements conventional detectors when safety filters are used. The proposed attack policy and detector are illustrated on a double integrator example.}, - published={1} -} - -@inproceedings{Wigren_ECC2024, - author = {T. Wigren and A. M. H. Teixeira}, - booktitle = {European Control Conference (Accepted)}, - title = {Delay Attack and Detection in Feedback Linearized Control Systems}, - year = {2024}, - abstract={Delay injection attacks on nonlinear control systems have many consequences. Nonlinear instability mechanisms, for example finite escape time dynamics, can be triggered which is why rapid attack detection needs research. The paper therefore considers delay attacks on feedback linearized systems and shows how a recursive identification algorithm for nonlinear systems with delay may be used for detection of delay injection in the feedback path. The attack methodology is illustrated using a simulated feedback linearized automotive cruise controller where the attack is disguised, but anyway rapidly detected.}, - published={1}, - tag={10004} -} - -@inproceedings{Tosun_SP024, - author = {F. E. Tosun and A. M. H. Teixeira and A. Ahlén and S. Dey}, - booktitle = {12th IFAC Symposium on Fault Detection, Supervision and Safety for Technical Processes (Accepted)}, - title = {Kullback-Leibler Divergence-Based Detector Design Against Bias Injection Attacks in an Artificial Pancreas System}, - year = {2024}, - abstract={This paper considers constant bias injection attacks on the glucose sensor deployed in an artificial pancreas system that has an integrator. The main challenge with such apparently simple attacks is that, if the system is linear and has an integrator, they are only detectable for a limited duration. More formally, they are steady-state stealthy attacks. To address this issue, we propose a residual generation method to increase the detectability of these attacks based on the Kullback–Leibler divergence metric. Illustrative examples with numerical simulations are provided to demonstrate the effectiveness of the proposed method.}, - published={1}, - tag = {10002} -} - - -@article{Tosun_JPC2024, - author = {F. E. Tosun and A. M. H. Teixeira and M. Abdalmoaty and A. Ahl\'{e}n and S. Dey}, - journal = {Journal of Process Control}, - volume = {153}, - number = {103162}, - title = {Quickest Detection of Bias Injection Attacks on the Glucose Sensor in the Artificial Pancreas Under Meal Disturbances}, - year = {2024}, - abstract = {Modern glucose sensors deployed in closed-loop insulin delivery systems, so-called artificial pancreas use wireless communication channels. While this allows a flexible system design, it also introduces vulnerability to cyberattacks. Timely detection and mitigation of attacks are imperative for device safety. However, large unknown meal disturbances are a crucial challenge in determining whether the sensor has been compromised or the sensor glucose trajectories are normal. We address this issue from a control-theoretic security perspective. In particular, a time-varying Kalman filter is employed to handle the sporadic meal intakes. The filter prediction error is then statistically evaluated to detect anomalies if present. We compare two state-of-the-art online anomaly detection algorithms, namely the $\chi^2$ and CUSUM tests. We establish a robust optimal detection rule for unknown bias injections. Even if the optimality holds only for the restrictive case of constant bias injections, we show that the proposed model-based anomaly detection scheme is also effective for generic non-stealthy sensor deception attacks through numerical simulations}, - doi = {10.1016/j.jprocont.2024.103162}, - published = {1}, - tag = {10002} -} - -@phdthesis{Nguyen_Lic2023, - author = {Anh Tung Nguyen}, - title = {Security Allocation in Networked Control Systems}, - school = {Uppsala University}, - year = {2023}, - address = {Uppsala, Sweden}, - month = oct, - type = {Licentiate thesis}, - url={http://www.it.uu.se/research/publications/lic/2023-003/2023-003.pdf}, - abstract={Sustained use of critical infrastructure, such as electrical power and water distribution networks, requires efficient management and control. Facilitated by the advancements in computational devices and non-proprietary communication technology, such as the Internet, the efficient operation of critical infrastructure relies on network decomposition into interconnected subsystems, thus forming networked control systems. However, the use of public and pervasive communication channels leaves these systems vulnerable to cyber attacks. Consequently, the critical infrastructure is put at risk of suffering operation disruption and even physical damage that would inflict financial costs as well as pose a hazard to human health. Therefore, security is crucial to the sustained efficient operation of critical infrastructure. - - This thesis develops a framework for evaluating and improving the security of networked control systems in the face of cyber attacks. The considered security problem involves two strategic agents, namely a malicious adversary and a defender, pursuing their specific and conflicting goals. The defender aims to efficiently allocate defense resources with the purpose of detecting malicious activities. Meanwhile, the malicious adversary simultaneously conducts cyber attacks and remains stealthy to the defender. We tackle the security problem by proposing a game-theoretic framework and characterizing its main components: the payoff function, the action space, and the available information for each agent. Especially, the payoff function is characterized based on the output-to-output gain security metric that fully explores the worst-case attack impact. Then, we investigate the properties of the game and how to efficiently compute its equilibrium. Given the combinatorial nature of the defender's actions, one important challenge is to alleviate the computational burden. To overcome this challenge, the thesis contributes several system- and graph-theoretic conditions that enable the defender to shrink the action space, efficiently allocating the defense resources. The effectiveness of the proposed framework is validated through numerical examples.}, - tag = {10005} -} - - -@article{Ramos_TAC2024, - author = {G. Ramos and A. P. Aguiar and Soummya Kar and S. Pequito}, - journal = {IEEE Trans. Automatic Control (Accepted)}, - title = {Privacy preserving average consensus through network augmentation}, - year = {2023}, - published = {1}, - tag = {10006} -} - -@article{Ramos_CSL2024, - author = {G. Ramos and S. Pequito}, - journal = {Systems & Control Letters}, - volume = {180}, - pages = {105608}, - year = {2023}, - title = {Designing communication networks for discrete-time consensus for performance and privacy guarantees}, - pdf = {ramosandpequito_CSL2023}, - abstract = {Discrete-time consensus plays a key role in multi-agent systems and distributed protocols. Unfortunately, due to the self-loop dynamics of the agents (an agent’s current state depends only on its own immediately previous state, i.e., one time-step in the past), they often lack privacy guarantees. Therefore, in this paper, we propose a novel design that consists of a network augmentation, where each agent uses the previous iteration values and the newly received ones to increase the privacy guarantees. To formally evaluate the privacy of a network of agents, we define the concept of privacy index, which intuitively measures the minimum number of agents that should work in coalition to recover all the initial states. Moreover, we aim to explore if there is a trade-off between privacy and accuracy (rate of convergence) or if we can increase both. We unveil that, with the proposed method, we can design networks with higher privacy index and faster convergence rates. Remarkably, we further ensure that the network always reaches consensus even when the original network does not. Finally, we illustrate the proposed method with examples and present networks that lead to higher privacy levels and, in the majority of the cases, to faster consensus rates.}, - doi = {10.1016/j.sysconle.2023.105608}, - published = {1}, - tag = {10006} -} - -@article{Anand_TAC2024, - author = {S. C. Anand and A. M. H. Teixeira and A. Ahl\'{e}n}, - journal = {IEEE Trans. Automatic Control (Accepted)}, - number = {}, - pages = {}, - title = {Risk Assessment of Stealthy Attacks on Uncertain Control Systems}, - volume = {}, - year = {2023}, - pdf = {anandandteixeira_TAC2023}, - arxiv={2106.07071}, - abstract={In this article, we address the problem of risk assessment of stealthy attacks on uncertain control systems. Considering data injection attacks that aim at maximizing impact while remaining undetected, we use the recently proposed output-to-output gain to characterize the risk associated with the impact of attacks under a limited system knowledge attacker. The risk is formulated using a well-established risk metric, namely the maximum expected loss. Under this setups, the risk assessment problem corresponds to an untractable infinite non-convex optimization problem. To address this limitation, we adopt the framework of scenario-based optimization to approximate the infinite non-convex optimization problem by a sampled non-convex optimization problem. Then, based on the framework of dissipative system theory and S-procedure, the sampled non-convex risk assessment problem is formulated as an equivalent convex semi-definite program. Additionally, we derive the necessary and sufficient conditions for the risk to be bounded. Finally, we illustrate the results through numerical simulation of a hydro-turbine power system.}, - doi={10.1109/TAC.2023.3318194}, - published={1}, - tag = {10001} -} - - -@article{Anand_IEEEOJCSys2023, - author = {S. C. Anand and A. M. H. Teixeira}, - journal = {IEEE Open Journal of Control Systems}, - number = {}, - pages = {297--309}, - title = {Risk-based Security Measure Allocation Against Actuator Attacks}, - volume = {2}, - year = {2023}, - pdf = {anandandteixeira_OJC2023}, - arxiv={2304.02055}, - doi={10.1109/OJCSYS.2023.3305831}, - abstract={This article considers the problem of risk-optimal allocation of security measures when the actuators of an uncertain control system are under attack. We consider an adversary injecting false data into the actuator channels. The attack impact is characterized by the maximum performance loss caused by a stealthy adversary with bounded energy. Since the impact is a random variable, due to system uncertainty, we use Conditional Value-at-Risk (CVaR) to characterize the risk associated with the attack. We then consider the problem of allocating the security measures which minimize the risk. We assume that there are only a limited number of security measures available. Under this constraint, we observe that the allocation problem is a mixed-integer optimization problem. Thus we use relaxation techniques to approximate the security allocation problem into a Semi-Definite Program (SDP). We also compare our allocation method (i) across different risk measures: the worst-case measure, the average (nominal) measure, and (ii) across different search algorithms: the exhaustive and the greedy search algorithms. We depict the efficacy of our approach through numerical examples.}, - published={1}, - tag = {10001} -} - -@inproceedings{Ramos_CDC2023, - author = {G. Ramos and A. M. H. Teixeira and S. Pequito}, - booktitle = {Accepted to IEEE Conference on Decisions and Control (CDC)}, - title = {On the trade-offs between accuracy, privacy, and resilience in average consensus algorithms}, - year = {2023}, - published={1}, - tag = {10005}, - taga = {10006} -} - -@inproceedings{Tosun_CDC2023, - address={}, - author = {F. E. Tosun and A. M. H. Teixeira}, - booktitle = {Accepted to IEEE Conference on Decisions and Control (CDC)}, - title = {Robust Sequential Detection of Non-stealthy Sensor Deception Attacks in an Artificial Pancreas System}, - year = {2023}, - published={1}, - tag={10002} -} - -@inproceedings{Li_CDC2023, - address={}, - author = {Z. Li and A. T. Nguyen and A. M. H. Teixeira and Y. Mo and K. H. Johansson}, - booktitle = {Accepted to IEEE Conference on Decisions and Control (CDC)}, - title = {Secure State Estimation with Asynchronous Measurements against Malicious Measurement-data and Time-stamp Manipulation}, - year = {2023}, - arxiv={2303.17514}, - abstract = {This paper proposes a secure state estimation scheme with non-periodic asynchronous measurements for linear continuous-time systems under false data attacks on the measurement transmit channel. After sampling the output of the system, a sensor transmits the measurement information in a triple composed of sensor index, time-stamp, and measurement value to the fusion center via vulnerable communication channels. The malicious attacker can corrupt a subset of the sensors through (i) manipulating the time-stamp and measurement value; (ii) blocking transmitted measurement triples; or (iii) injecting fake measurement triples. To deal with such attacks, we propose the design of local estimators based on observability space decomposition, where each local estimator updates the local state and sends it to the fusion center after sampling a measurement. Whenever there is a local update, the fusion center combines all the local states and generates a secure state estimate by adopting the median operator. We prove that local estimators of benign sensors are unbiased with stable covariance. Moreover, the fused central estimation error has bounded expectation and covariance against at most p corrupted sensors as long as the system is 2p-sparse observable. The efficacy of the proposed scheme is demonstrated through an application on a benchmark example of the IEEE 14-bus system.}, - published={1}, - tag={10005} -} - -@inproceedings{Wigren_CDC2023, - address={}, - author = {T. Wigren and A. M. H. Teixeira}, - booktitle = {Accepted to IEEE Conference on Decisions and Control (CDC)}, - title = {Feedback Path Delay Attacks and Detection}, - year = {2023}, - published={1}, - tag={10004} -} - -@article{Naha_AUTOMATICA2023, - author = {A. Naha and A. M. H. Teixeira and A. Ahl\'{e}n and S. Dey}, - journal = {Automatica}, - number = {}, - pages = {111147}, - title = {Quickest Detection of Deception Attacks on Cyber-Physical Systems with a Parsimonious Watermarking Policy}, - volume = {155}, - year = {2023}, - pdf = {nahaandteixeira_ATM2023}, - doi={10.1016/j.automatica.2023.111147}, - arxiv={2201.09389}, - abstract={The addition of a physical watermarking signal to the control input increases the detection probability of data deception attacks at the expense of increased control cost. In this paper, we propose a parsimonious policy to reduce the average number of watermarking events when the attack is not present, which in turn reduces the control cost. We model the system as a stochastic optimal control problem and apply the dynamic programming to minimize the average detection delay (ADD) for fixed upper bounds on false alarm rate (FAR) and increased control cost. The optimal solution results in a two threshold policy on the posterior probability of attack, which is derived from the Shiryaev statistics for sequential change detection assuming the change point is a random variable with a geometric distribution. We derive approximate expressions of ADD and FAR applying the non-linear renewal theory. The relationship between the average number of watermarking added before the attack and the increase in control cost is also derived. We design the optimal watermarking that maximizes the Kullback-Leibler divergence for a fixed increase in the control cost. Simulation studies are performed to illustrate and validate the theoretical results.} -} - -@article{Chockalingam_JISA2023, - author = {S. Chockalingam and W. Pieters and A. M. H. Teixeira and P. van Gelder}, - journal = {Journal of Information Security and Applications}, - number = {}, - title = {Probability Elicitation for Bayesian Networks to Distinguish between Intentional Attacks and Accidental Technical Failures}, - year = {2023}, - doi={10.1016/j.jisa.2023.103497}, - pdf = {chockalingamandteixeira_JISA2023}, - volume = {75}, - pages = {103497}, - issn = {2214-2126}, - abstract = {Both intentional attacks and accidental technical failures can lead to abnormal behaviour in components of industrial control systems. In our previous work, we developed a framework for constructing Bayesian Network (BN) models to enable operators to distinguish between those two classes, including knowledge elicitation to construct the directed acyclic graph of BN models. In this paper, we add a systematic method for knowledge elicitation to construct the Conditional Probability Tables (CPTs) of BN models, thereby completing a holistic framework to distinguish between attacks and technical failures. In order to elicit reliable probabilities from experts, we need to reduce the workload of experts in probability elicitation by reducing the number of conditional probabilities to elicit and facilitating individual probability entry. We utilise DeMorgan models to reduce the number of conditional probabilities to elicit as they are suitable for modelling opposing influences i.e., combinations of influences that promote and inhibit the child event. To facilitate individual probability entry, we use probability scales with numerical and verbal anchors. We demonstrate the proposed approach using an example from the water management domain.} -} - -@article{Naha_EJC2023, - author = {A. Naha and A. M. H. Teixeira and A. Ahl\'{e}n and S. Dey}, - journal = {European Journal of Control}, - number = {}, - pages = {100804}, - title = {Quickest Physical Watermarking-Based Detection of Measurement Replacement Attacks in Networked Control Systems}, - volume = {71}, - year = {2023}, - pdf = {nahaandteixeira_EJC2023}, - doi = {10.1016/j.ejcon.2023.100804}, - abstract = {In this paper, we propose and analyze an attack detection scheme for securing the physical layer of a networked control system (NCS) with a wireless sensor network against attacks where the adversary replaces the true observations with stationary false data. An independent and identically distributed watermarking signal is added to the optimal linear quadratic Gaussian (LQG) control inputs, and a cumulative sum (CUSUM) test is carried out using the joint distribution of the innovation signal and the watermarking signal for quickest attack detection. We derive the expressions of the supremum of the average detection delay (SADD) for a multi-input and multi-output (MIMO) system under the optimal and sub-optimal CUSUM tests. The SADD is asymptotically inversely proportional to the expected KullbackLeibler divergence (KLD) under certain conditions. The expressions for the MIMO case are simplified for multi-input and single-output systems and explored further to distil design insights. We provide insights into the design of an optimal watermarking signal to maximize KLD for a given fixed increase in LQG control cost when there is no attack. Furthermore, we investigate how the attacker and the control system designer can accomplish their respective objectives by changing the relative power of the attack signal and the watermarking signal. Simulations and numerical studies are carried out to validate the theoretical results.} -} - -@inproceedings{AbdalmoatyIFAC2023, - address={}, - author = {M. Abdalmoaty and S. C. Anand and A. M. H. Teixeira}, - booktitle = {IFAC World Congress}, - title = {Privacy and Security in Network Controlled Systems via Dynamic Masking}, - year = {2023}, - arxiv = {2211.07328}, - abstract = {In this paper, we propose a new architecture to enhance the privacy and security of networked control systems against malicious adversaries. We consider an adversary which first learns the system dynamics (privacy) using system identification techniques, and then performs a data injection attack (security). In particular, we consider an adversary conducting zero-dynamics attacks (ZDA) which maximizes the performance cost of the system whilst staying undetected. However, using the proposed architecture, we show that it is possible to (i) introduce significant bias in the system estimates of the adversary: thus providing privacy of the system parameters, and (ii) efficiently detect attacks when the adversary performs a ZDA using the identified system: thus providing security. Through numerical simulations, we illustrate the efficacy of the proposed architecture.}, - video={https://youtu.be/uuz5ppriWLk}, - tag = {10006} -} - -@inproceedings{NguyenIFAC2023, - address={}, - author = {A. T. Nguyen and S. C. Anand and A. M. H. Teixeira and A. Medvedev}, - booktitle = {IFAC World Congress}, - title = {Optimal Detector Placement in Networked Control Systems under Cyber-attacks with Applications to Power Networks}, - tag = {10005}, - year = {2023}, - arxiv={2304.05710}, - abstract={This paper proposes a game-theoretic method to address the problem of optimal detector placement in a networked control system under cyber-attacks. The networked control system is composed of interconnected agents where each agent is regulated by its local controller over unprotected communication, which leaves the system vulnerable to malicious cyber-attacks. To guarantee a given local performance, the defender optimally selects a single agent on which to place a detector at its local controller with the purpose of detecting cyber-attacks. On the other hand, an adversary optimally chooses a single agent on which to conduct a cyber-attack on its input with the aim of maximally worsening the local performance while remaining stealthy to the defender. First, we present a necessary and sufficient condition to ensure that the maximal attack impact on the local performance is bounded, which restricts the possible actions of the defender to a subset of available agents. Then, by considering the maximal attack impact on the local performance as a game payoff, we cast the problem of finding optimal actions of the defender and the adversary as a zero-sum game. Finally, with the possible action sets of the defender and the adversary, an algorithm is devoted to determining the Nash equilibria of the zero-sum game that yield the optimal detector placement. The proposed method is illustrated on an IEEE benchmark for power systems.} -} - -@inproceedings{WigrenIFAC2023, - address={}, - author = {T. Wigren and A. M. H. Teixeira}, - booktitle = {IFAC World Congress}, - title = {On-line Identification of Delay Attacks in Networked Servo Control}, - year = {2023}, - abstract={The paper discusses attacks on networked control loops by increased delay, and shows how existing round trip jitter may disguise such attacks. The attackers objective need not be de-stabilization, the paper argues that making settling time requirements fail can be sufficient. To defend against such attacks, the paper proposes the use of joint recursive prediction error identification of the round trip delay and the networked closed loop dynamics. The proposed identification algorithm allows general defense, since it is designed for delayed nonlinear dynamics in state space form. Simulations show that the method is able to detect a delay attack on a printed circuit board component mounting servo loop, long before the attack reaches full effect.}, - tag={10004} -} - -@article{Zhang_TAC2023, - author = {Q. Zhang and K. Liu and A. M. H. Teixeira and Y. Li and S. Chai and Y. Xia}, - journal = {IEEE Trans. Automatic Control}, - number = {6}, - pages = {3672--3679}, - title = {An Online Kullback-Leibler Divergence-Based Stealthy Attack against Cyber-Physical Systems}, - volume = {68}, - year = {2023}, - abstract = {This article investigates the design of online stealthy attacks with the aim of moving the system's state to a desired target. Different from the design of offline attacks, which is only based on the system's model, to design the online attack, the attacker also estimates the system's state with the intercepted data at each instant and computes the optimal attack accordingly. To ensure stealthiness, the Kullback-Leibler divergence between the innovations with and without attacks at each instant should be smaller than a threshold. We show that the attacker should solve a convex optimization problem at each instant to compute the mean and covariance of the attack. The feasibility of the attack policy is also discussed. Furthermore, for the strictly stealthy case with zero threshold, the analytic expression of the unique optimal attack is given. Finally, a numerical example of the longitudinal flight control system is adopted to illustrate the effectiveness of the proposed attack.}, - arxiv = {}, - pdf = {zhangandteixeira_TAC2022}, - doi={10.1109/TAC.2022.3192201} -} - -@article{NahaTAC2022, - author = {A. Naha and A. M. H. Teixeira and A. Ahl\'{e}n and S. Dey}, - journal = {IEEE Trans. Automatic Control}, - number = {3}, - pages = {1941--1948}, - title = {Sequential detection of Replay attacks}, - abstract = {One of the most studied forms of attacks on the cyber-physical systems is the replay attack. The statistical similarities of the replayed signal and the true observations make the replay attack difficult to detect. In this paper, we address the problem of replay attack detection by adding watermarking to the control inputs and then perform resilient detection using cumulative sum (CUSUM) test on the joint statistics of the innovation signal and the watermarking signal, whereas existing work considers only the marginal distribution of the innovation signal. We derive the expression of the Kullback-Liebler divergence (KLD) between the two joint distributions before and after the replay attack, which is, asymptotically, inversely proportional to the detection delay. We perform a structural analysis of the derived KLD expression and suggest a technique to improve the KLD for the systems with relative degree greater than one. A scheme to find the optimal watermarking signal variance for a fixed increase in the control cost to maximize the KLD under the CUSUM test is presented. We provide various numerical simulation results to support our theory. The proposed method is also compared with a state-ofthe-art method based on the Neyman-Pearson detector, illustrating -the smaller detection delay of the proposed sequential detector.}, - volume = {68}, - year = {2023}, - pdf = {nahaandteixeira_TAC2022}, - arxiv={2012.10748}, - doi={10.1109/TAC.2022.3174004} -} - - -@inproceedings{NguyenCDC2022, - address={}, - author = {A. T. Nguyen and S. C. Anand and A. M. H. Teixeira}, - booktitle = {IEEE Conference on Decision and Control (CDC)}, - title = {A Zero-Sum Game Framework for Optimal Sensor Placement in Uncertain Networked Control Systems under Cyber-Attacks}, - year = {2022}, - abstract = {This paper proposes a game-theoretic approach to address the problem of optimal sensor placement against an adversary in uncertain networked control systems. The problem is formulated as a zero-sum game with two players, namely a malicious adversary and a detector. Given a protected performance vertex, we consider a detector, with uncertain system knowledge, that selects another vertex on which to place a sensor and monitors its output with the aim of detecting the presence of the adversary. On the other hand, the adversary, also with uncertain system knowledge, chooses a single vertex and conducts a cyber-attack on its input. The purpose of the adversary is to drive the attack vertex as to maximally disrupt the protected performance vertex while remaining undetected by the detector. As our first contribution, the game payoff of the above-defined zero-sum game is formulated in terms of the Value-at-Risk of the adversary's impact. However, this game payoff corresponds to an intractable optimization problem. To tackle the problem, we adopt the scenario approach to approximately compute the game payoff. Then, the optimal monitor selection is determined by analyzing the equilibrium of the zero-sum game. The proposed approach is illustrated via a numerical example of a 10-vertex networked control system.}, - doi = {10.1109/CDC51059.2022.9992468}, - arxiv = {2210.04091}, - pdf = {nguyenanandteixeira_CDC2022}, - tag = {10005} -} - - -@inproceedings{NahaCDC2022, - address={}, - author = {A. Naha and A. M. H. Teixeira and A. Ahl\'{e}n and S. Dey}, - booktitle = {IEEE Conference on Decisions and Control (CDC)}, - title = {Structural analyses of a parsimonious watermarking policy -for data deception attack detection in networked control systems}, - year = {2022}, - pdf = {nahaanandteixeira_CDC2022}, - abstract = {In this paper, we perform structural analyses of a parsimonious watermarking policy, which minimizes the average detection delay (ADD) to detect data deception attacks on networked control systems (NCS) for a fixed upper bound on the false alarm rate (FAR). The addition of physical watermarking to the control input of a NCS increases the probability of attack detections with an increase in the control cost. Therefore, we formulate the problem of data deception attack detection for NCS with the facility to add physical watermarking as a stochastic optimal control problem. Then we solve the problem by applying dynamic programming value iterations and find a parsimonious watermarking policy that decides to add watermarking and detects attacks based on the estimated posterior probability of attack. We analyze the optimal policy structure and find that it can be a one, two or three threshold policy depending on a few parameter values. Simulation studies show that the optimal policy for a practical range of parameter values is a two-threshold policy on the posterior probability of attack. Derivation of a threshold-based policy from the structural analysis of the value iteration method reduces the computational complexity during the runtime implementation and offers better structural insights. Furthermore, such an analysis provides a guideline for selecting the parameter values to meet the design requirements.}, - doi = {10.1109/CDC51059.2022.9993201}, -} - - -@inproceedings{AnandCCTA2022, - address={}, - author = {S. C. Anand and A. M. H. Teixeira and A. Ahl\'{e}n}, - booktitle = {IEEE Conference on Control Technology and Applications (CCTA)}, - title = {Risk assessment and optimal allocation of security measures under stealthy false data injection attacks}, - year = {2022}, - tag = {10001}, - pdf = {anandandteixeira_CCTA2022}, - abstract ={This paper firstly addresses the problem of risk assessment under false data injection attacks on uncertain control systems. We consider an adversary with complete system knowledge, injecting stealthy false data into an uncertain control system. We then use the Value-at-Risk to characterize the risk associated with the attack impact caused by the adversary. The worst-case attack impact is characterized by the recently proposed output-to-output gain. We observe that the risk assessment problem corresponds to an infinite non-convex robust optimization problem. To this end, we use dissipative system theory and the scenario approach to approximate the risk-assessment problem into a convex problem and also provide probabilistic certificates on approximation. Secondly, we con-sider the problem of security measure allocation. We consider an operator with a constraint on the security budget. Under this constraint, we propose an algorithm to optimally allocate the security measures using the calculated risk such that the resulting Value-at-risk is minimized. Finally, we illustrate the results through a numerical example. The numerical example also illustrates that the security allocation using the Value-at-risk, and the impact on the nominal system may have different outcomes: thereby depicting the benefit of using risk metrics.}, - doi = {10.1109/CCTA49430.2022.9966025}, - arxiv = {2207.04860}, -} - - -@inproceedings{NguyenNecsys2022, - address={}, - author = {A. T. Nguyen and A. M. H. Teixeira and A. Medvedev}, - booktitle = {IFAC Conference on Networked Systems (NecSys)}, - title = {A Single-Adversary-Single-Detector Zero-Sum Game in Networked Control Systems}, - year = {2022}, - pdf = {nguyenandteixeira_NecSys2022}, - abstract = {This paper proposes a game-theoretic approach to address the problem of optimal sensor placement for detecting cyber-attacks in networked control systems. The problem is formulated as a zero-sum game with two players, namely a malicious adversary and a detector. Given a protected target vertex, the detector places a sensor at a single vertex to monitor the system and detect the presence of the adversary. On the other hand, the adversary selects a single vertex through which to conduct a cyber-attack that maximally disrupts the target vertex while remaining undetected by the detector. As our first contribution, for a given pair of attack and monitor vertices and a known target vertex, the game payoff function is defined as the output-to-output gain of the respective system. Then, the paper characterizes the set of feasible actions by the detector that ensures bounded values of the game payoff. Finally, an algebraic sufficient condition is proposed to examine whether a given vertex belongs to the set of feasible monitor vertices. The optimal sensor placement is then determined by computing the mixed-strategy Nash equilibrium of the zero-sum game through linear programming. The approach is illustrated via a numerical example of a 10-vertex networked control system with a given target vertex.}, - doi = {10.1016/j.ifacol.2022.07.234}, - tag = {10005}, - arxiv = {2205.14001} -} - - - -@inproceedings{Tosun_ACC2022, - address = {Atlanta, Georgia, USA}, - author = {F. E. Tosun and A. M. H. Teixeira and A. Ahl\'{e}n and S. Dey}, - booktitle = {American Control Conference}, - title = {Detection of Bias Injection Attacks on the Glucose Sensor in the Artificial Pancreas Under Meal Disturbances}, - year = {2022}, - doi = {10.23919/ACC53348.2022.9867556}, - tag = {10002}, - pdf = {tosunandteixeira_ACC2022}, - abstract = {The artificial pancreas is an emerging concept of closed-loop insulin delivery that aims to tightly regulate the blood glucose levels in patients with type 1 diabetes. This paper considers bias injection attacks on the glucose sensor deployed in an artificial pancreas. Modern glucose sensors transmit measurements through wireless communication that are vulnerable to cyber-attacks, which must be timely detected and mitigated. To this end, we propose a model-based anomaly detection scheme using a Kalman filter and a χ 2 test. One key challenge is to distinguish cyber-attacks from large unknown disturbances arising from meal intake. This challenge is addressed by an online meal estimator, and a novel time-varying detection threshold. More precisely, we show that the ordinary least squares is the optimal unbiased estimator of the meal size under certain modelling assumptions. Moreover, we derive a novel time-varying threshold for the χ 2 detector to avoid false alarms during meal ingestion. The results are validated by means of numerical simulations.}, -} - -@inproceedings{Naha_ACC2022, - address = {Atlanta, Georgia, USA}, - author = {A. Naha and A. M. H. Teixeira and A. Ahl\'{e}n and S. Dey}, - booktitle = {American Control Conference}, - title = {Sequential Detection of Replay Attacks with a Parsimonious Watermarking Policy}, - year = {2022}, - doi = {10.23919/ACC53348.2022.9867703}, - pdf = {nahaandteixeira_ACC2022}, - abstract = {In this paper, we have proposed a technique for Bayesian sequential detection of replay attacks on networked control systems with a constraint on the average number of watermarking (ANW) events used during normal system operations. Such a constraint limits the increase in the control cost due to watermarking. To determine the optimal sequence regarding the addition or otherwise of watermarking signals, first, we formulate an infinite horizon stochastic optimal control problem with a termination state. Then applying the value iteration approach, we find an optional policy that minimizes the average detection delay (ADD) for fixed upper bounds on the false alarm rate (FAR) and ANW. The optimal policy turns out to be a two thresholds policy on the posterior probability of attack. We derive approximate expressions of ADD and FAR as functions of the two derived thresholds and a few other parameters. A simulation study on a single-input single-output system illustrates that the proposed method improves the control cost considerably at the expense of small increases in ADD. We also perform simulation studies to validate the derived theoretical results.}, -} - -@inproceedings{Anand_ACC2022, - address = {Atlanta, Georgia, USA}, - author = {S. C. Anand and A. M. H. Teixeira}, - booktitle = {American Control Conference}, - title = {Risk-averse controller design against data injection attacks on actuators for uncertain control systems}, - year = {2022}, - doi = {10.23919/ACC53348.2022.9867257}, - tag = {10001}, - pdf = {anandandteixeira_ACC2022}, - abstract = {In this paper, we consider the optimal controller design problem against data injection attacks on actuators for an uncertain control system. We consider attacks that aim at maximizing the attack impact while remaining stealthy in the finite horizon. To this end, we use the Conditional Value-at-Risk to characterize the risk associated with the impact of attacks. The worst-case attack impact is characterized using the recently proposed output-to-output ℓ 2 -gain (OOG). We formulate the design problem and observe that it is non-convex and hard to solve. Using the framework of scenario-based optimization and a convex proxy for the OOG, we propose a convex optimization problem that approximately solves the design problem with probabilistic certificates. Finally, we illustrate the results through a numerical example.}, - arxiv = {2203.00055}, -} - -@inproceedings{Ekmefjord_CCGrid2022, - address = {Taormina, Italy}, - author = {M. Ekmefjord and A. Ait-Mlouk and S. Alawadi and M. Åkesson and P. Singh and O. Spjuth and S. Toor and A. Hellander}, - booktitle = {Symposium on Cluster, Cloud and Internet Computing}, - title = {Scalable federated machine learning with FEDn}, - year = {2022}, - doi = {10.1109/CCGrid54584.2022.00065}, - tag = {10003}, - pdf = {ekmefjordandtoor_CCGrid2022}, - abstract = {Federated machine learning promises to overcome the input privacy challenge in machine learning. By iteratively updating a model on private clients and aggregating these local model updates into a global federated model, private data is incorporated in the federated model without needing to share and expose that data. Several open software projects for federated learning have appeared. Most of them focuses on supporting flexible experimentation with different model aggregation schemes and with different privacy-enhancing technologies. However, there is a lack of open frameworks that focuses on critical distributed computing aspects of the problem such as scalability and resilience. It is a big step to take for a data scientist to go from an experimental sandbox to testing their federated schemes at scale in real-world geographically distributed settings. To bridge this gap we have designed and developed a production-grade hierarchical federated learning framework, FEDn. The framework is specifically designed to make it easy to go from local development in pseudo-distributed mode to horizontally scalable distributed deployments. FEDn both aims to be production grade for industrial applications and a flexible research tool to explore real-world performance of novel federated algorithms and the framework has been used in number of industrial and academic R&D projects. In this paper we present the architecture and implementation of FEDn. We demonstrate the framework's scalability and efficiency in evaluations based on two case-studies representative for a cross-silo and a cross-device use-case respectively.}, - arxiv = {2103.00148}, -} - -@article{Chockalingam_2021, - author = {S. Chockalingam and W. Pieters and A. M. H. Teixeira and P. van Gelder}, - journal = {Cybersecurity}, - number = {29}, - pages = {}, - title = {Bayesian network model to distinguish between intentional attacks and accidental technical failures: a case study of floodgates}, - volume = {4}, - year = {2021} -} - -@inproceedings{Gallo_CDC2021, - address = {Austin, Texas, USA}, - author = {A. J. Gallo and S. C. Anand and A. M. H. Teixeira and R. M. G. Ferrari}, - booktitle = {IEEE Conf. Decision and Control}, - title = {Design of multiplicative watermarking against covert attacks}, - year = {2021}, - doi = {10.1109/CDC45484.2021.9683075} -} - - -@inproceedings{Anand_CDC2021, - address = {Austin, Texas, USA}, - author = {S. C. Anand and A. M. H. Teixeira}, - booktitle = {IEEE Conf. Decision and Control}, - title = {Stealthy Cyber-Attack Design Using Dynamic Programming}, - year = {2021}, - doi = {10.1109/CDC45484.2021.9683451}, - arxiv={2109.02954} -} - -@inproceedings{Naha_ECC2021, - address = {Rotterdam, The Netherlands}, - author = {A. Naha and A. M. H. Teixeira and A. Ahl\'{e}n and S. Dey}, - booktitle = {Eur. Control Conf.}, - title = {Deception Attack Detection Using Reduced Watermarking}, - year = {2021}, - doi = {10.23919/ECC54610.2021.9654843} -} - -@incollection{FerrariTeixeira_Springer2021, - author={Ferrari, Riccardo M. G. - and Teixeira, Andr{\'e} M. H.}, - editor={Ferrari, Riccardo M.G. - and Teixeira, Andr{\'e} M. H.}, - title={Introduction to the Book}, - bookTitle={Safety, Security and Privacy for Cyber-Physical Systems}, - year={2021}, - publisher={Springer International Publishing}, - address={Cham}, - pages={1--8}, - isbn={978-3-030-65048-3}, - doi={10.1007/978-3-030-65048-3_1} -} - - - -@incollection{Teixeira_Springer2021, - author={Teixeira, Andr{\'e} M. H.}, - editor={Ferrari, Riccardo M.G. - and Teixeira, Andr{\'e} M. H.}, - title={Security Metrics for Control Systems}, - bookTitle={Safety, Security and Privacy for Cyber-Physical Systems}, - year={2021}, - publisher={Springer International Publishing}, - address={Cham}, - pages={1--8}, - isbn={978-3-030-65048-3}, - doi={10.1007/978-3-030-65048-3_6}, - tag = {10001} -} - -@incollection{Ferrari_Springer2021, - author={Ferrari, Riccardo M. G. - and Teixeira, Andr{\'e} M. H.}, - editor={Ferrari, Riccardo M.G. - and Teixeira, Andr{\'e} M. H.}, - title={Detection of Cyber-Attacks: A Multiplicative Watermarking Scheme}, - bookTitle={Safety, Security and Privacy for Cyber-Physical Systems}, - year={2021}, - publisher={Springer International Publishing}, - address={Cham}, - pages={1--8}, - isbn={978-3-030-65048-3}, - doi={10.1007/978-3-030-65048-3_9} -} - - - -@inproceedings{Arghavani_WCNC2021, - title = {A {{Game}}-Theoretic {{Approach}} to {{Covert Communications}} in the {{Presence}} of {{Multiple Colluding Wardens}}}, - booktitle = {2021 {{IEEE Wireless Communications}} and {{Networking Conference}} ({{WCNC}})}, - author = {Arghavani, Abbas and Ahl{\'e}n, Anders and Teixeira, Andr{\'e} and Dey, Subhrakanti}, - year = {2021}, - month = mar, - pages = {1--7}, - issn = {1558-2612}, - doi = {10.1109/WCNC49053.2021.9417312}, - copyright = {All rights reserved}, - keywords = {communications,Computational modeling,Conferences,game-theory,Games,Linear programming,Nash equilibrium,Numerical simulation,Rayleigh channels,security} -} - -@inproceedings{javed_CBDC2021, - title = {An Evaluation of Container Security Vulnerability Detection Tools}, - booktitle = {Cloud and Big Data Computing}, - author = {O. Javed and S. Toor}, - year = {2021}, - doi = {10.1145/3481646.3481661}, - pdf = {javedandtoor_CBDC2021}, - astract = {Container is a lightweight virtualization technology which packages an application, its dependencies and an operating system (OS) to run as an isolated unit. However, the pressing concern with the use of containers is its susceptibility to security attacks. Consequently, a number of container scanning tools are available for detecting container security vulnerabilities. Therefore, in this experience report, we investigate the quality of existing container scanning tools by considering two metrics that reflect coverage and accuracy. We analyze popular public container images hosted on DockerHub using different container scanning tools (i.e., Clair, Anchore, and Microscanner). Our findings show that existing container scanning tools do not detect application package vulnerabilities. Furthermore, we find that existing tools do not have high accuracy.}, - arxiv = {}, -} - -@article{Rostampour_TAC2020, -author = {V. Rostampour and R. M.G. Ferrari and A. M. H. Teixeira and T. Keviczky}, -journal = {IEEE Trans. Automatic Control}, -number = {11}, -pages = {5299--5313}, -title = {Privatized Distributed Anomaly Detection for Large-Scale Nonlinear Uncertain Systems}, -volume = {66}, -year = {2021}, -doi={10.1109/TAC.2020.3040251} -} - - - -@article{Ferrari_TAC2020, -author = {R. Ferrari and A. M. H. Teixeira}, -journal = {IEEE Trans. Automatic Control}, -number = {6}, -pages = {2558--2573}, -title = {A Switching Multiplicative Watermarking Scheme for Detection of Stealthy Cyber-Attacks}, -volume = {66}, -year = {2020} -} - - -@article{Milosevic_TAC2020, -author = {J. Milosevic and A. M. H. Teixeira and H. Sandberg and K. H. Johansson}, -doi={10.1109/TAC.2020.2981392}, -journal = {IEEE Trans. Automatic Control}, -number = {9}, -pages = {3816--3831}, -title = {Actuator Security Indices Based on Perfect Undetectability: Computation, Robustness, and Sensor Placement}, -volume = {65}, -year = {2020} -} - - -@article{Knorn_CSL2019, -author = {S. Knorn and A. M. H. Teixeira}, -journal = {IEEE Control Systems Letters}, -number = {4}, -pages = {829--834}, -title = {Effects of Jamming Attacks on a Control System With Energy Harvesting}, -volume = {3}, -year = {2019} -} - - - -@inproceedings{Anand_2020, -address = {Berlin, Germany}, -author = {S. C. Anand and A M H Teixeira}, -booktitle = {IFAC World Congress}, -title = {Joint controller and detector design against -data injection attacks on actuators}, -year = {2020} -} - - -@inproceedings{Hylamia_2020, -address = {San Francisco, CA, USA}, -author = {S. Hylamia and W. Yan and A M. H. Teixeira and N. B. Asan and M. Perez and R. Augustine and T. Voigt}, -booktitle = {IEEE Workshop on the Internet of Safe Things (SafeThings)}, -title = {Privacy-preserving Continuous Tumour Relapse Monitoring Using In-body Radio Signals}, -year = {2020} -} - - -@inproceedings{Teixeira_CDC2019, -address = {Nice, France}, -author = {A. M. H. Teixeira}, -booktitle = {IEEE Conf. Decision and Control}, -title = {Optimal stealthy attacks on actuators for strictly proper systems}, -year = {2019} -} - -@inproceedings{Chong_ECC2019, -address = {Napoles, Italy}, -author = {M. S. Chong and H. Sandberg and A. M. H. Teixeira}, -booktitle = {Eur. Control Conf.}, -title = {A Tutorial Introduction to Security and Privacy for Cyber-Physical Systems}, -year = {2019} -} - - -@inproceedings{Teixeira_ECC2019, -address = {Napoles, Italy}, -author = {A. M. H. Teixeira}, -booktitle = {Eur. Control Conf.}, -title = {Data Injection Attacks against Feedforward Controllers}, -year = {2019} -} - - -@inproceedings{Umsonst_ACC2019, -address = {Philadelphia, PA, USA}, -author = {D. Umsonst and E. Nekouei and A. M. H. Teixeira and H. Sandberg}, -booktitle = {American Control Conf.}, -title = {On the Confidentiality of Linear Anomaly Detector States}, -year = {2019} -} - - -@inproceedings{Chockalingam2018, -abstract = {Because of modern societies' dependence on industrial control systems, adequate response to system failures is essential. In order to take appropriate measures, it is crucial for operators to be able to distinguish between intentional attacks and accidental technical failures. However, adequate decision support for this matter is lacking. In this paper, we use Bayesian Networks (BNs) to distinguish between intentional attacks and accidental technical failures, based on contributory factors and observations (or test results). To facilitate knowledge elicitation, we use extended shbone diagrams for discussions with experts, and then translate those into the BN formalism. We demonstrate the methodology using an example in a case study from the water management domain. M4 - Citavi}, -address = {Oxford, UK}, -author = {Chockalingam, Sabarathinam and Teixeira, Andr{\'{e}} M. H. and Pieters, Wolter and Khakzad, Nima and van Gelder, Pieter}, -booktitle = {Proc. 5th Int. Work. Graph. Model. Secur.}, -title = {Combining Bayesian Networks and Fishbone Diagrams to Distinguish between Intentional Attacks and Accidental Technical Failures}, -year = {2018} -} -@article{Pan2018, -abstract = {Understanding smart grid cyber attacks is key for developing appropriate protection and recovery measures. Advanced attacks pursue maximized impact at minimized costs and detectability. This paper conducts risk analysis of combined data integrity and availability attacks against the power system state estimation. We compare the combined attacks with pure integrity attacks - false data injection (FDI) attacks. A security index for vulnerability assessment to these two kinds of attacks is proposed and formulated as a mixed integer linear programming problem. We show that such combined attacks can succeed with fewer resources than FDI attacks. The combined attacks with limited knowledge of the system model also expose advantages in keeping stealth against the bad data detection. Finally, the risk of combined attacks to reliable system operation is evaluated using the results from vulnerability assessment and attack impact analysis. The findings in this paper are validated and supported by a detailed case study.}, -archivePrefix = {arXiv}, -arxivId = {1708.08349}, -author = {Pan, Kaikai and Teixeira, Andre M. H. and Cvetkovic, Milos and Palensky, Peter}, -doi = {10.1109/TSG.2018.2817387}, -eprint = {1708.08349}, -issn = {19493053}, -journal = {IEEE Trans. Smart Grid}, -keywords = {Combined integrity and availability attack,Indexes,Network topology,Power systems,Security,State estimation,Transmission line matrix methods,Transmission line measurements,false data injection,power system state estimation.,risk analysis}, -pages = {3044--3056}, -volume={10}, -number={3}, -title = {Cyber Risk Analysis of Combined Data Attacks Against Power System State Estimation}, -year = {2019}, -month=may -} -@inproceedings{Teixeira2018, -address = {Cyprus}, -author = {Teixeira, A. M. H. and Ferrari, R. M. G.}, -booktitle = {Eur. Control Conf.}, -title = {Detection of Sensor Data Injection Attacks with Multiplicative Watermarking}, -year = {2018} -} -@article{Rostampour2018, -abstract = {Distributed fault diagnosis has been proposed as an effective technique for monitoring large scale, nonlinear and uncertain systems. It is based on the decomposition of the large scale system into a number of interconnected subsystems, each one monitored by a dedicated Local Fault Detector (LFD). Neighboring LFDs, in order to successfully account for subsystems interconnection, are thus required to communicate with each other some of the measurements from their subsystems. Anyway, such communication may expose private information of a given subsystem, such as its local input. To avoid this problem, we propose here to use differential privacy to pre-process data before transmission.}, -author = {Rostampour, Vahab and Ferrari, Riccardo and Teixeira, Andr{\'{e}} M H and Keviczky, Tam{\'{a}}s}, -doi = {10.1016/J.IFACOL.2018.09.703}, -issn = {2405-8963}, -journal = {IFAC-PapersOnLine}, -month = jan, -number = {24}, -pages = {975--982}, -title = {Differentially-Private Distributed Fault Diagnosis for Large-Scale Nonlinear Uncertain Systems}, -volume = {51}, -year = {2018} -} -@article{Jezdimir2018, -author = {Milo{\v{s}}evi{\'{c}}, Jezdimir and Teixeira, Andr{\'{e}} M. H. and Tanaka, Takashi and Johansson, Karl H. and Sandberg, Henrik}, -doi = {10.1002/rnc.4375}, -journal = {Int. J. Robust Nonlinear Control}, -vol = {30}, -number = {11}, -pages = {4278--4302}, -title = {Security measure allocation for industrial control systems: Exploiting systematic search techniques and submodularity}, -year = {2018} -} - -@article{OsmaniTSC2018, - author = {L. Osmani and S. Toor and N. Komu and M. Kortelainen and T. Lindén and J. White and R. Khan and P. Eerola and S. Tarkoma}, - journal = {IEEE Transactions on Services Computing}, - number = {}, - pages = {}, - title = {Secure Cloud Connectivity for Scientific Applications}, - abstract = {Cloud computing improves utilization and flexibility in allocating computing resources while reducing the infrastructural costs. However, in many cases cloud technology is still proprietary and tainted by security issues rooted in the multi-user and hybrid cloud environment. A lack of secure connectivity in a hybrid cloud environment hinders the adaptation of clouds by scientific communities that require scaling-out of the local infrastructure using publicly available resources for large-scale experiments. In this article, we present a case study of the DII-HEP secure cloud infrastructure and propose an approach to securely scale-out a private cloud deployment to public clouds in order to support hybrid cloud scenarios. A challenge in such scenarios is that cloud vendors may offer varying and possibly incompatible ways to isolate and interconnect virtual machines located in different cloud networks. Our approach is tenant driven in the sense that the tenant provides its connectivity mechanism. We provide a qualitative and quantitative analysis of a number of alternatives to solve this problem. We have chosen one of the standardized alternatives, Host Identity Protocol, for further experimentation in a production system because it supports legacy applications in a topologically-independent and secure way.}, - volume = {}, - year = {2018}, - pdf = {osmaniandtoor_TSC2018}, - arxiv={}, - doi={10.1109/TSC.2015.2469292} -} - -@incollection{Chockalingam2017a, -abstract = {Bayesian Networks (BNs) are an increasingly popular mod- elling technique in cyber security especially due to their capability to overcome data limitations. This is also exemplified by the growth of BN models development in cyber security. However, a comprehensive comparison and analysis of these models is missing. In this paper, we conduct a systematic review of the scientific literature and identify 17 standard BN models in cyber security. We analyse these models based on 8 different criteria and identify important patterns in the use of these models. A key outcome is that standard BNs are noticeably used for problems especially associated with malicious insiders. This study points out the core range of problems that were tackled using standard BN models in cyber security, and illuminates key research gaps.}, -author = {Chockalingam, Sabarathinam and Pieters, Wolter and Teixeira, Andr{\'{e}} M. H. and van Gelder, Pieter}, -booktitle = {Secur. IT Syst. Nord. 2017. Lect. Notes Comput. Sci.}, -doi = {10.1007/978-3-319-70290-2_7}, -editor = {Lipmaa, Helger and and Mitrokotsa, Aikaterini and and Matulevi{\v{c}}ius, Raimundas}, -isbn = {9783319702896}, -issn = {16113349}, -keywords = {Bayesian attack graph,Bayesian network,Cyber security,Information security,Insider threat}, -pages = {105--122}, -publisher = {Springer, Cham}, -title = {Bayesian network models in cyber security: A systematic review}, -volume = {10674 LNCS}, -year = {2017} -} -@inproceedings{Pan2017, -abstract = {It is challenging to assess the vulnerability of a cyber-physical power system to data attacks from an integral perspective. In order to support vulnerability assessment except analytic analysis, suitable platform for security tests needs to be developed. In this paper we analyze the cyber security of energy management system (EMS) against data attacks. First we extend our analytic framework that characterizes data attacks as optimization problems with the objectives specified as security metrics and constraints corresponding to the communication network properties. Second, we build a platform in the form of co-simulation - coupling the power system simulator DIgSILENT PowerFactory with communication network simulator OMNeT++, and Matlab for EMS applications (state estimation, optimal power flow). Then the framework is used to conduct attack simulations on the co-simulation based platform for a power grid test case. The results indicate how vulnerable of EMS to data attacks and how co-simulation can help assess vulnerability.}, -address = {Dresden, Germany}, -archivePrefix = {arXiv}, -arxivId = {1708.08322}, -author = {Pan, Kaikai and Teixeira, Andr{\'{e}} M. H. and L{\'{o}}pez, Claudio and Palensky, Peter}, -booktitle = {IEEE Int. Conf. Smart Grid Commun.}, -doi = {10.1109/SmartGridComm.2017.8340668}, -eprint = {1708.08322}, -isbn = {9781538640555}, -pages = {253--258}, -title = {Co-simulation for Cyber Security Analysis: Data Attacks against Energy Management System}, -year = {2017} -} -@inproceedings{Pan2017a, -abstract = {{\textcopyright} 2017 IEEE. It has shown that with perfect knowledge of the system model and the capability to manipulate a certain number of measurements, the false data injection (FDI) attacks, as a class of data integrity attacks, can coordinate measurements corruption to keep stealth against the bad data detection schemes. However, a more realistic attack is essentially an attack with limited adversarial knowledge of the system model and limited attack resources due to various reasons. In this paper, we generalize the data attacks that they can be pure FDI attacks or combined with availability attacks (e.g., DoS attacks) and analyze the attacks with limited adversarial knowledge or limited attack resources. The attack impact is evaluated by the proposed metrics and the detection probability of attacks is calculated using the distribution property of data with or without attacks. The analysis is supported with results from a power system use case. The results show how important the knowledge is to the attacker and which measurements are more vulnerable to attacks with limited resources.}, -address = {Beijing, China}, -author = {Pan, Kaikai and Teixeira, Andre M. H. and Cvetkovic, Milos and Palensky, Peter}, -booktitle = {IECON 2017 - 43rd Annu. Conf. IEEE Ind. Electron. Soc.}, -doi = {10.1109/IECON.2017.8216741}, -isbn = {978-1-5386-1127-2}, -month = oct, -pages = {4313--4318}, -title = {Data attacks on power system state estimation: Limited adversarial knowledge vs. limited attack resources}, -year = {2017} -} -@article{Ferrari_IFAC_2017, -abstract = {This paper addresses the detection and isolation of replay attacks on sensor measurements. As opposed to previously proposed additive watermarking, we propose a multiplicative watermarking scheme, where each sensor's output is separately watermarked by being fed to a SISO watermark generator. Additionally, a set of equalizing filters is placed at the controller's side, which reconstructs the original output signals from the received watermarked data. We show that the proposed scheme has several advantages over existing approaches: it has no detrimental effects on the closed-loop performance in the absence of attacks; it can be designed in a modular fashion, independently of the design of the controller and anomaly detector; it facilitates the detection of replay attacks and the isolation of the time at which the replayed data was recorded. These properties are discussed in detail and the results are illustrated through a numerical example.}, -author = {Ferrari, Riccardo M.G. and Teixeira, Andr{\'{e}} M. H.}, -doi = {10.1016/j.ifacol.2017.08.1502}, -issn = {24058963}, -journal = {IFAC-PapersOnLine}, -month = jul, -number = {1}, -pages = {7363--7368}, -title = {Detection and Isolation of Replay Attacks through Sensor Watermarking}, -volume = {50}, -year = {2017} -} -@inproceedings{Ferrari2017, -abstract = {{\textcopyright} 2017 American Automatic Control Council (AACC). In networked control systems, leveraging the peculiarities of the cyber-physical domains and their interactions may lead to novel detection and defense mechanisms against malicious cyber-attacks. In this paper, we propose a multiplicative sensor watermarking scheme, where each sensor's output is separately watermarked by a Single Input Single Output (SISO) filter. Hence, such scheme does not require communication between multiple sensors, but can still lead to detection and isolation of malicious cyber-attacks. In particular, we analyze the benefits of the proposed watermarking scheme for two attack scenarios: The physical sensor re-routing attack and the cyber measurement re-routing one. For each attack scenario, detectability and isolability properties are analyzed with and without the proposed watermarking scheme and we show how the watermarking scheme can be leveraged to detect cyber sensor routing attacks. In order to detect compromised sensors, we design an observer-based detector with a robust adaptive threshold. Additionally, we identify the sensors involved in the re-routing attacks by means of a tailored Recursive Least Squares parameter estimation algorithm. The results are illustrated through a numerical example.}, -address = {Seattle, WA, USA}, -author = {Ferrari, Riccardo M.G. and Teixeira, Andre M. H.}, -booktitle = {Proc. Am. Control Conf.}, -doi = {10.23919/ACC.2017.7963800}, -isbn = {9781509059928}, -issn = {07431619}, -month = may, -pages = {5436--5442}, -title = {Detection and isolation of routing attacks through sensor watermarking}, -year = {2017} -} -@article{Teixeira_TCNS_2017, -abstract = {IEEE In this paper, we address the problem of distributed reconfiguration of networked control systems upon the removal of misbehaving sensors and actuators. In particular, we consider systems with redundant sensors and actuators cooperating to recover from faults. Reconfiguration is performed while minimizing a steady-state estimation error covariance and a quadratic control cost. A model-matching condition is imposed on the reconfiguration scheme. It is shown that the reconfiguration and its underlying computation can be distributed. Using an average dwell-time approach, the stability of the distributed reconfiguration scheme under finite-time termination is analyzed. The approach is illustrated in a numerical example.}, -author = {Teixeira, Andre M. H. and Araujo, Jose and Sandberg, Henrik and Johansson, K.H. Karl H.}, -doi = {10.1109/TCNS.2017.2732158}, -issn = {2325-5870}, -journal = {IEEE Trans. Control Netw. Syst.}, -keywords = {Actuators,Computational modeling,Estimation error,Networked control systems,Redundancy}, -pages = {1--12}, -title = {Distributed sensor and actuator reconfiguration for fault-tolerant networked control systems}, -year = {2017} -} -@article{Farokhi2017, -abstract = {{\textcopyright} 1963-2012 IEEE. We introduce a model of estimation in the presence of strategic, self-interested sensors. We employ a game-Theoretic setup to model the interaction between the sensors and the receiver. The cost function of the receiver is equal to the estimation error variance while the cost function of the sensor contains an extra term which is determined by its private information. We start by the single sensor case in which the receiver has access to a noisy but honest side information in addition to the message transmitted by a strategic sensor. We study both static and dynamic estimation problems. For both these problems, we characterize a family of equilibria in which the sensor and the receiver employ simple strategies. Interestingly, for the dynamic estimation problem, we find an equilibrium for which the strategic sensor uses a memory-less policy. We generalize the static estimation setup to multiple sensors with synchronous communication structure (i.e., all the sensors transmit their messages simultaneously). We prove the maybe surprising fact that, for the constructed equilibrium in affine strategies, the estimation quality degrades as the number of sensors increases. However, if the sensors are herding (i.e., copying each other policies), the quality of the receiver's estimation improves as the number of sensors increases. Finally, we consider the asynchronous communication structure (i.e., the sensors transmit their messages sequentially).}, -author = {Farokhi, Farhad and Teixeira, Andre M. H. and Langbort, Cedric}, -doi = {10.1109/TAC.2016.2571779}, -issn = {0018-9286}, -journal = {IEEE Trans. Automat. Contr.}, -keywords = {Estimation,Kalman filtering,game theory,strategic sensors}, -month = feb, -number = {2}, -pages = {724--739}, -title = {Estimation With Strategic Sensors}, -volume = {62}, -year = {2017} -} -@incollection{Chockalingam2017, -abstract = {Over the last years, we have seen several security incidents that compromised system safety, of which some caused physical harm to people. Meanwhile, various risk assessment methods have been developed that integrate safety and security, and these could help to address the corresponding threats by implementing suitable risk treatment plans. However, an overarching overview of these methods, systematizing the characteristics of such methods, is missing. In this paper, we conduct a systematic literature review, and identify 7 integrated safety and security risk assessment methods. We analyze these methods based on 5 different criteria, and identify key characteristics and applications. A key outcome is the distinction between sequential and non-sequential integration of safety and security, related to the order in which safety and security risks are assessed. This study provides a basis for developing more effective integrated safety and security risk assessment methods in the future.}, -archivePrefix = {arXiv}, -arxivId = {1707.02140}, -author = {Chockalingam, Sabarathinam and Hadziosmanovic, Dina and Pieters, Wolter and Teixeira, Andre M. H. and van Gelder, Pieter}, -booktitle = {Crit. Inf. Infrastructures Secur. CRITIS 2016. Lect. Notes Comput. Sci.}, -doi = {10.1007/978-3-319-71368-7_5}, -editor = {Havarneanu, G. and Setola, R. and Nassopoulos, H. and Wolthusen, S.}, -eprint = {1707.02140}, -isbn = {9783319713670}, -issn = {16113349}, -keywords = {Integrated safety and security risk assessment,Risk analysis,Risk evaluation,Risk identification,Safety risk assessment,Security risk assessment}, -month = oct, -pages = {50--62}, -publisher = {Springer, Cham}, -title = {Integrated Safety and Security Risk Assessment Methods: A Survey of Key Characteristics and Applications}, -year = {2017} -} -@article{Ma2017, -abstract = {Low-voltage distribution grids experience a rising penetration of inverter-based, distributed generation. In order to not only contribute to but also solve voltage problems, these inverters are increasingly asked to participate in intelligent grid controls. Communicating inverters implement distributed voltage droop controls. The impact of cyber-attacks to the stability of such distributed grid controls is poorly researched and therefore addressed in this article. We characterize the potential impact of several attack scenarios by employing the positivity and diagonal dominance properties. In particular, we discuss measurement falsification scenarios where the attacker corrupts voltage measurement data received by the voltage droop controllers. Analytical, control-theoretic methods for assessing the impact on system stability and voltage magnitude are presented and validated via simulation.}, -author = {Ma, Mingxiao and Teixeira, Andr{\'{e}} M. H. and van den Berg, Jan and Palensky, Peter}, -doi = {10.1016/j.ifacol.2017.08.1562}, -issn = {24058963}, -journal = {IFAC-PapersOnLine}, -keywords = {Cyber security,distribution network,risk assessment,stability,voltage control}, -month = jul, -number = {1}, -pages = {8379--8384}, -title = {Voltage Control in Distributed Generation under Measurement Falsification Attacks}, -volume = {50}, -year = {2017} -} -@inproceedings{Pan2016, -abstract = {{\textcopyright} 2016 IEEE. This paper introduces combined data integrity and availability attacks to expand the attack scenarios against power system state estimation. The goal of the adversary, who uses the combined attack, is to perturb the state estimates while remaining hidden from the observer. We propose security metrics that quantify vulnerability of power grids to combined data attacks under single and multi-path routing communication models. In order to evaluate the proposed security metrics, we formulate them as mixed integer linear programming (MILP) problems. The relation between the security metrics of combined data attacks and pure data integrity attacks is analyzed, based on which we show that, when data availability and data integrity attacks have the same cost, the two metrics coincide. When data availability attacks have a lower cost than data integrity attacks, we show that a combined data attack could be executed with less attack resources compared to pure data integrity attacks. Furthermore, it is shown that combined data attacks would bypass integrity-focused mitigation schemes. These conclusions are supported by the results obtained on a power system model with and without a communication model with single or multi-path routing.}, -address = {Sydney, Australia}, -author = {Pan, Kaikai and Teixeira, Andre M H and Cvetkovic, Milos and Palensky, Peter}, -booktitle = {IEEE Int. Conf. Smart Grid Commun.}, -doi = {10.1109/SmartGridComm.2016.7778773}, -isbn = {978-1-5090-4075-9}, -month = nov, -pages = {271--277}, -title = {Combined data integrity and availability attacks on state estimation in cyber-physical power grids}, -year = {2016} -} -@inproceedings{Paridari2016a, -abstract = {{\textcopyright} 2016 IEEE. Energy management systems (EMS) are used to control energy usage in buildings and campuses, by employing technologies such as supervisory control and data acquisition (SCADA) and building management systems (BMS), in order to provide reliable energy supply and maximise user comfort while minimising energy usage. Historically, EMS systems were installed when potential security threats were only physical. Nowadays, EMS systems are connected to the building network and as a result directly to the outside world. This extends the attack surface to potential sophisticated cyber-attacks, which adversely impact EMS operation, resulting in service interruption and downstream financial implications. Currently, the security systems that detect attacks operate independently to those which deploy resiliency policies and use very basic methods. We propose a novel EMS cyber-physical-security framework that executes a resilient policy whenever an attack is detected using security analytics. In this framework, both the resilient policy and the security analytics are driven by EMS data, where the physical correlations between the data-points are identified to detect outliers and then the control loop is closed using an estimated value in place of the outlier. The framework has been tested using a reduced order model of a real EMS site.}, -address = {Vienna, Austria}, -author = {Paridari, K. and Mady, A.E.-D. and {La Porta}, S. and Chabukswar, R. and Blanco, J. and Teixeira, A. M. H. and Sandberg, H. and Boubekeur, M.}, -booktitle = {ACM/IEEE 7th Int. Conf. Cyber-Physical Syst. ICCPS}, -doi = {10.1109/ICCPS.2016.7479072}, -isbn = {9781509017720}, -keywords = {Cyber-physical-security,energy management system,resilient control,security analytics,virtual sensor}, -title = {Cyber-Physical-Security Framework for Building Energy Management System}, -year = {2016} -} -@inproceedings{Fichtner2016, -abstract = {{\textcopyright} 2016 ACM. In the cybersecurity community it is common to think of security as a design feature for systems and infrastructures that may be difficult to balance with other requirements. What is less studied is how security requirements come about, for which reasons, and what their influence is on the actions the system facilitates. Security is for example often used as an argument for or against granting access rights that are of importance to stakeholders, such as in the discussion on counterterrorism and privacy. This paper argues that the ongoing politicization of security issues calls for a paradigm to study cybersecurity as a Politikum: a matter of political concern, embedded in existing and future infrastructures. We summarize literature which inspired this paper and explain the role of security arguments for infrastructure governance. Then we outline the new paradigm and its core concepts and contribution, including the notion of framing. Finally, we present discourse analysis and infrastructure ethnography as research methods and discuss cases in which discourses (may) shape infrastructures, in particular smart cities.}, -address = {Granby, CO, USA}, -author = {Fichtner, Laura and Pieters, Wolter and Teixeira, Andr{\'{e}}}, -booktitle = {Proc. 2016 New Secur. Paradig. Work. NSPW}, -doi = {10.1145/3011883.3011887}, -isbn = {9781450348133}, -keywords = {Discourse analysis,Framing,Infrastructure ethnography,Securitization,Security arguments,Security politics,Threat models}, -pages = {36--48}, -title = {Cybersecurity as a Politikum}, -volume = {26-29-Sept}, -year = {2016} -} -@inproceedings{Wang2016, -abstract = {Currently international supply chains are facing risks concerning faults in compliance, such as altering shipping documentations, fictitious inventory, and inter-company manipulations. In this paper a method to detect and diagnose fault scenarios regarding customs compliance in supply chains is proposed. This method forms part of a general approach called model-based auditing, which is based on a normative meta-model of the movement of money and goods or services. The modeling framework is proposed on compliance monitoring of supply chains with focus on information systems and compliance reporting tools. The innovation lies in the application and mapping of modeling techniques from dynamical systems engineering to business process analysis for audit and supervision purposes. Specifically, the application domain is where money, goods as well as information are transferred between international supply chain partners. A case study of a leading company in electronics manufacturing applying the model is analyzed.}, -address = {San Diego, CA, USA}, -author = {Wang, Yuxin and Teixeira, Andr{\'{e}} A.H. and Tian, Yifu and Hulstijn, Joris and Tan, Yao-Hua Y.-H. and Teixeira, Andr{\'{e}} A.H. and Hulstijn, Joris and Tan, Yao-Hua Y.-H.}, -booktitle = {22nd Am. Conf. Inf. Syst.}, -keywords = {Auditing,Compliance,Fault detection and diagnosis,International supply chains}, -month = aug, -title = {Fault Detection and Diagnosis for Compliance Monitoring in International Supply Chains}, -year = {2016} -} -@inproceedings{Sandberg2016, -abstract = {{\textcopyright} 2016 IEEE. In this paper, we investigate detectability and identifiability of attacks on linear dynamical systems that are subjected to external disturbances. We generalize a concept for a security index, which was previously introduced for static systems. The index exactly quantifies the resources necessary for targeted attacks to be undetectable and unidentifiable in the presence of disturbances. This information is useful for both risk assessment and for the design of anomaly detectors. Finally, we show how techniques from the fault detection literature can be used to decouple disturbances and to identify attacks, under certain sparsity constraints.}, -address = {Vienna, Austria}, -author = {Sandberg, Henrik and Teixeira, Andre M.H. A.M.H.}, -booktitle = {2016 Sci. Secur. Cyber-Physical Syst. Work.}, -doi = {10.1109/SOSCYPS.2016.7580001}, -isbn = {978-1-5090-4304-0}, -month = apr, -pages = {1--6}, -title = {From control system security indices to attack identifiability}, -year = {2016} -} - -@article{Teixeira_Automatica2015, -abstract = {Cyber-secure networked control is modeled, analyzed, and experimentally illustrated in this paper. An attack space defined by the adversary's model knowledge, disclosure, and disruption resources is introduced. Adversaries constrained by these resources are modeled for a networked control system architecture. It is shown that attack scenarios corresponding to denial-of-service, replay, zero-dynamics, and bias injection attacks on linear time-invariant systems can be analyzed using this framework. Furthermore, the attack policy for each scenario is described and the attack's impact is characterized using the concept of safe sets. An experimental setup based on a quadruple-tank process controlled over a wireless network is used to illustrate the attack scenarios, their consequences, and potential counter-measures.}, -archivePrefix = {arXiv}, -arxivId = {1212.0226}, -author = {Teixeira, Andr{\'{e}} and Shames, Iman and Sandberg, Henrik and Johansson, Karl Henrik}, -doi = {10.1016/j.automatica.2014.10.067}, -eprint = {1212.0226}, -isbn = {0005-1098}, -issn = {00051098}, -journal = {Automatica}, -keywords = {Attack space,Cyber-physical systems,Secure control systems,System security}, -number = {1}, -pages = {135--148}, -title = {A secure control framework for resource-limited adversaries}, -volume = {51}, -year = {2015} -} -@incollection{Teixeira_BC2015, -abstract = {In this chapter, we survey cyber security solutions for control and monitoring systems that are used to manage the Smart Grid. We start with a short review of the history and use of Industrial Control Systems (ICSs) and Supervisory Control and Data Acquisition (SCADA) systems, and how cyber security in control systems has recently become a major concern, in the wake of the Stuxnet and other recently discovered malware. We follow up with surveying information technology and control-centric security tools that can be used to improve the resilience of industrial control systems. Feedback control loops are core components in the Smart Grid, as they enable the maximal utilization of the physical infrastructure and its resources. As the number of control loops in the Smart Grid increases, the cyber security challenges faced by ICSs become increasingly important within the Smart Grid's context. To highlight such novel challenges, we give an overview of the envisioned control loops in future Smart Grids, and discuss the potential impact of cyber threats targeting critical Smart Grid functionalities. As a case study, false-data injection attacks on power transmission networks are considered. The level of resilience to such attacks is assessed through a control-centric risk assessment methodology, which is also used for allocating the deployment of more modern and secure equipment. The chapter ends with a discussion of future research challenges in the area.}, -author = {Teixeira, Andr{\'{e}} and Kupzog, Friederich and Sandberg, Henrik and Johansson, Karl H.}, -booktitle = {Smart Grid Secur. Innov. Solut. a Mod. Grid}, -doi = {10.1016/B978-0-12-802122-4.00006-7}, -editor = {{Florian Skopik and Paul Smith}}, -isbn = {9780128023549}, -keywords = {Industrial Control Systems,Resilient Control,Risk Assessment,Security}, -pages = {149--183}, -publisher = {Elsevier Science Publishing Co Inc}, -title = {Cyber-Secure and Resilient Architectures for Industrial Control Systems}, -year = {2015} -} - -@article{Teixeira_CSM_2015, -author = {Teixeira, A and Sou, K and Sandberg, H and Johansson, K}, -doi = {10.1109/MCS.2014.2364709}, -journal = {IEEE Control Syst. Mag.}, -keywords = {Communication networks;Computer crime;Computer sec}, -number = {1}, -pages = {24--45}, -title = {Secure Control Systems: A Quantitative Risk Management Approach}, -volume = {35}, -year = {2015} -} -@inproceedings{Teixeira_CDC2015, -abstract = {{\textcopyright} 2015 IEEE.In this paper, we characterize and analyze the set of strategic stealthy false-data injection attacks on discrete-time linear systems. In particular, the threat scenarios tackled in the paper consider adversaries that aim at deteriorating the system's performance by maximizing the corresponding quadratic cost function, while remaining stealthy with respect to anomaly detectors. As opposed to other work in the literature, the effect of the adversary's actions on the anomaly detector's output is not constrained to be zero at all times. Moreover, scenarios where the adversary has uncertain model knowledge are also addressed. The set of strategic attack policies is formulated as a non-convex constrained optimization problem, leading to a sensitivity metric denoted as the output-to-output ℓ2-gain. Using the framework of dissipative systems, the output-to-output gain is computed through an equivalent convex optimization problem. Additionally, we derive necessary and sufficient conditions for the output-to-output gain to be unbounded, with and without model uncertainties, which are tightly related to the invariant zeros of the system.}, -address = {Osaka, Japan}, -author = {Teixeira, Andre and Sandberg, Henrik and Johansson, Karl H.}, -booktitle = {Proc. IEEE Conf. Decis. Control}, -doi = {10.1109/CDC.2015.7402605}, -isbn = {9781479978861}, -issn = {07431546}, -pages = {2582--2587}, -title = {Strategic stealthy attacks: The output-to-output ℓ2-gain}, -volume = {54rd IEEE}, -year = {2015} -} - -@inproceedings{Teixeira_ETFA2015, -abstract = {{\textcopyright} 2015 IEEE. In this paper, we study the impact of adversarial actions on voltage control schemes in interconnected microgrids. Each microgrid is abstracted as a power inverter that can be controlled to regulate its voltage magnitude and phase-angle independently. Moreover, each power inverter is modeled as a single integrator, whose input is given by a voltage droop-control policy that is computed based on voltage magnitude and reactive power injection measurements. Under mild assumptions, we then establish important properties of the nominal linearized closed-loop system, such as stability, positivity, and diagonal dominance. These properties play an important role when characterizing the potential impact of different attack scenarios. In particular, we discuss two attack scenarios where the adversary corrupts measurement data and reference signals received by the voltage droop controllers. The potential impact of instances of each scenario is analyzed using control-theoretic tools, which may be used to develop methodologies for identifying high-risk attack scenarios, as is illustrated by numerical examples.}, -address = {Luxembourg}, -author = {Teixeira, Andre and Paridari, Kaveh and Sandberg, Henrik and Johansson, K.H. Karl H.}, -booktitle = {2015 IEEE 20th Conf. Emerg. Technol. Fact. Autom.}, -doi = {10.1109/ETFA.2015.7301476}, -isbn = {978-1-4673-7929-8}, -issn = {1946-0740}, -keywords = {Inverters,Microgrids,Power system dynamics,Power system stability,Stability analysis,Voltage control,Voltage measurement}, -month = sep, -pages = {1--8}, -title = {Voltage control for interconnected microgrids under adversarial actions}, -year = {2015} -} -@inproceedings{Araujo_CDC2014, -abstract = {{\textcopyright} 2014 IEEE.We propose and evaluate a down-sampled controller which reduces the network usage while providing a guaranteed desired linear quadratic control performance. This method is based on fast and slow sampling intervals, as the closed-system benefits by being brought quickly to steady-state conditions while behaving satisfactorily when being actuated at a slow rate once at those conditions. This mechanism is shown to provide large savings with respect to network usage when compared to traditional periodic time-triggered control and other aperiodic controllers proposed in the literature.}, -address = {Los Angeles, CA, USA}, -author = {Ara{\'{u}}jo, Jos{\'{e}} and Teixeira, Andre and Henriksson, Erik and Johansson, Karl H.}, -booktitle = {IEEE Conf. Decis. Control}, -doi = {10.1109/CDC.2014.7040465}, -isbn = {9781467360883}, -issn = {07431546}, -number = {February}, -pages = {6849--6856}, -title = {A down-sampled controller to reduce network usage with guaranteed closed-loop performance}, -year = {2014} -} - -@article{Teixeira_Cyb_2014, -author = {Teixeira, A and Shames, I and Sandberg, H and Johansson, K H}, -doi = {10.1109/TCYB.2014.2350335}, -journal = {IEEE Trans. Cybern.}, -number = {11}, -pages = {2024--2037}, -title = {Distributed Fault Detection and Isolation Resilient to Network Model Uncertainties}, -volume = {44}, -year = {2014} -} -@inproceedings{Farokhi_ACC2014, -address = {Portland, OR, USA}, -author = {Farokhi, F and Teixeira, A M H and Langbort, C}, -booktitle = {Am. Control Conf.}, -doi = {10.1109/ACC.2014.6859123}, -month = jun, -pages = {2267--2272}, -title = {Gaussian cheap talk game with quadratic cost functions: When herding between strategic senders is a virtue}, -year = {2014} -} -@inproceedings{Teixeira_ACC2014, -address = {Portland, OR, USA}, -author = {Teixeira, A and D{\'{a}}n, G and Sandberg, H and Berthier, R and Bobba, R B and Valdes, A}, -booktitle = {Am. Control Conf.}, -doi = {10.1109/ACC.2014.6859265}, -month = jun, -pages = {4372--4378}, -title = {Security of smart distribution grids: Data integrity attacks on integrated volt/{VAR} control and countermeasures}, -year = {2014} -} -@inproceedings{teixeirarecon13, -address = {Koblenz, Germany}, -author = {Teixeira, A and Ara{\'{u}}jo, J and Sandberg, H and Johansson, K H}, -booktitle = {4th {IFAC} Work. Distrib. Estim. Control Networked Syst.}, -month = sep, -title = {Distributed actuator reconfiguration in networked control systems}, -year = {2013} -} - -@incollection{Teixeira_Springer2013, -author = {Teixeira, A and Sou, K C and Sandberg, H and Johansson, K H}, -booktitle = {Control Cyber-Physical Syst.}, -editor = {Tarraf, Danielle C}, -number = {449}, -pages = {123--142}, -publisher = {Springer International Publishing}, -series = {Lecture Notes in Control and Information Sciences}, -title = {Quantifying Cyber-Security for Networked Control Systems}, -year = {2013} -} -@article{Shames_NM2012, -abstract = {Misbehaviors among the agents in a network might be intentional or unintentional, they might cause a system-wide failure or they might improve the performance or even enable us to achieve an objective. In this article we consider examples of these possible scenarios. First, we argue the necessity of monitoring the agents in a network to detect if they are misbehaving or not and outline a distributed method in which each agent monitors its neighbors for any sign of misbehavior. Later, we focus on solving the problem of distributed leader selection via forcing the agents to temporarily misbehave, and introduce an algorithm that enables the agents in a network to select their leader without any interference from the outside of the network. {\textcopyright} 2012 IEEE.}, -author = {Shames, I. and Teixeira, A.M.H. and Sandberg, H. and Johansson, K.H. H}, -doi = {10.1109/MNET.2012.6201214}, -issn = {08908044}, -journal = {{IEEE} Netw. Mag.}, -number = {3}, -pages = {35--40}, -title = {Agents Misbehaving in a Network: a Vice or a Virtue?}, -volume = {26}, -year = {2012} -} -@inproceedings{kn:Teixeira_HICONS2012, -abstract = {Cyber-secure networked control is modeled, analyzed, and experimentally illustrated in this paper. An attack space defined by the adversary's system knowledge, disclosure, and disruption resources is introduced. Adversaries constrained by these resources are modeled for a networked control system architecture. It is shown that attack scenarios corresponding to replay, zero dynamics, and bias injection attacks can be analyzed using this framework. An experimental setup based on a quadruple-tank process controlled over a wireless network is used to illustrate the attack scenarios, their consequences, and potential counter-measures.}, -address = {Beijing, China}, -author = {Teixeira, Andr{\'{e}} and P{\'{e}}rez, Daniel and Sandberg, Henrik and Johansson, Karl Henrik}, -booktitle = {Proc. 1st Int. Conf. High Confid. Networked Syst. - HiCoNS '12}, -doi = {10.1145/2185505.2185515}, -isbn = {9781450312639}, -issn = {00375675}, -pages = {55--64}, -title = {Attack models and scenarios for networked control systems}, -year = {2012} -} -@inproceedings{Andersson_2012, -address = {Washington, DC, USA}, -author = {Andersson, G and Esfahani, P M and Vrakopoulou, M and Margellos, K and Lygeros, J and Teixeira, A and Dan, G and Sandberg, H and Johansson, K H}, -booktitle = {IEEE PES Innov. Smart Grid Technol.}, -doi = {10.1109/ISGT.2012.6175543}, -pages = {1--2}, -title = {Cyber-security of SCADA systems}, -year = {2012} -} -@inproceedings{kn:Shames2012_ACC, -address = {Montreal, Canada}, -author = {Shames, I and Teixeira, A and Sandberg, H and Johansson, K H}, -booktitle = {Am. Control Conf.}, -month = jun, -title = {Distributed Fault Detection and Isolation with Imprecise Network Models}, -year = {2012} -} -@article{Shames_SPL2012, -author = {Shames, I and Teixeira, A M H and Sandberg, H and Johansson, K H}, -doi = {10.1109/LSP.2012.2217328}, -journal = {{IEEE} Signal Process. Lett.}, -month = nov, -number = {11}, -pages = {749--752}, -title = {Fault Detection and Mitigation in Kirchhoff Networks}, -volume = {19}, -year = {2012} -} - -@inproceedings{kn:Teixeira_ACC2012, -address = {Montreal, Canada}, -author = {Teixeira, A and Sandberg, H and D{\'{a}}n, G and Johansson, K H}, -booktitle = {Am. Control Conf.}, -title = {Optimal power flow: closing the loop over corrupted data}, -year = {2012} -} -@inproceedings{Teixeira_Allerton2012, -abstract = {In this paper the problem of revealing stealthy data-injection attacks on control systems is addressed. In particular we consider the scenario where the attacker performs zero-dynamics attacks on the system. First, we characterize and analyze the stealthiness properties of these attacks for linear time-invariant systems. Then we tackle the problem of detecting such attacks by modifying the system's structure. Our results provide necessary and sufficient conditions that the modifications should satisfy in order to detect the zero-dynamics attacks. The results and proposed detection methods are illustrated through numerical examples. {\textcopyright} 2012 IEEE.}, -address = {Monticello, IL, USA}, -author = {Teixeira, A. and Shames, I. and Sandberg, H. and Johansson, K.H. H}, -booktitle = {50th Annu. Allert. Conf. Commun. Control. Comput.}, -doi = {10.1109/Allerton.2012.6483441}, -isbn = {9781467345385}, -title = {Revealing Stealthy Attacks in Control Systems}, -year = {2012} -} -@inproceedings{kn:Teixeira2011, -address = {Milano, Italy}, -author = {Teixeira, A and D{\'{a}}n, G and Sandberg, H and Johansson, K H}, -booktitle = {18th {IFAC} World Congr.}, -title = {Cyber security study of a {SCADA} energy management system: stealthy deception attacks on the state estimator}, -year = {2011} -} -@article{Shamesetal-automatica-11, -abstract = {In this paper, the existence of unknown input observers for networks of interconnected second-order linear time invariant systems is studied. Two classes of distributed control systems of large practical relevance are considered. It is proved that for these systems, one can construct a bank of unknown input observers, and use them to detect and isolate faults in the network. The result presents a distributed implementation. In particular, by exploiting the system structure, this work provides further insight into the design of UIO for networked systems. Moreover, the importance of certain network measurements is shown. Infeasibility results with respect to available measurements and faults are also provided, as well as methods to remove faulty agents from the network. Applications to power networks and robotic formations are presented. It is shown how the developed methodology apply to a power network described by the swing equation with a faulty bus. For a multi-robot system, it is illustrated how a faulty robot can be detected and removed. {\textcopyright} 2011 Elsevier Ltd. All rights reserved.}, -author = {Shames, I. and Teixeira, A.M.H. and Sandberg, H. and Johansson, K.H.}, -doi = {10.1016/j.automatica.2011.09.011}, -issn = {00051098}, -journal = {Automatica}, -keywords = {Distributed algorithm,Distributed detection,Fault detection and isolation}, -number = {12}, -pages = {2757--2764}, -title = {Distributed Fault Detection for Interconnected Second-Order Systems}, -volume = {47}, -year = {2011} -} - -@inproceedings{kn:Teixeira10, -abstract = {In this paper, we analyze the cyber security of state estimators in Supervisory Control and Data Acquisition (SCADA) systems operating in power grids. Safe and reliable operation of these critical infrastructure systems is a major concern in our society. In current state estimation algorithms there are bad data detection (BDD) schemes to detect random outliers in the measurement data. Such schemes are based on high measurement redundancy. Although such methods may detect a set of very basic cyber attacks, they may fail in the presence of a more intelligent attacker. We explore the latter by considering scenarios where deception attacks are performed, sending false information to the control center. Similar attacks have been studied before for linear state estimators, assuming the attacker has perfect model knowledge. Here we instead assume the attacker only possesses a perturbed model. Such a model may correspond to a partial model of the true system, or even an out-dated model. We characterize the attacker by a set of objectives, and propose policies to synthesize stealthy deceptions attacks, both in the case of linear and nonlinear estimators. We show that the more accurate model the attacker has access to, the larger deception attack he can perform undetected. Specifically, we quantify trade-offs between model accuracy and possible attack impact for different BDD schemes. The developed tools can be used to further strengthen and protect the critical state-estimation component in SCADA systems. {\textcopyright}2010 IEEE.}, -address = {Atlanta, GA, USA}, -author = {Teixeira, A. and Amin, S. and Sandberg, H. and Johansson, K.H. H and Sastry, S.S. S}, -booktitle = {49th {IEEE} Conf. Decis. Control}, -doi = {10.1109/CDC.2010.5717318}, -isbn = {9781424477456}, -issn = {01912216}, -month = dec, -title = {Cyber Security Analysis of State Estimators in Electric Power Systems}, -year = {2010} -} -@inproceedings{Shamesetal_SCS_10, -address = {Stockholm, Sweden}, -author = {Shames, I and Teixeira, A M H and Sandberg, H and Johansson, K H}, -booktitle = {First Work. Secur. Control Syst. CPSWeek}, -month = apr, -title = {Distributed Fault Detection for Interconnected Second-Order Systems with Applications to Power Networks}, -year = {2010} -} - -@inproceedings{Teixeira_ACC2010, -address = {Baltimore, MD}, -author = {Teixeira, Andre and Sandberg, H and Johansson, K H}, -booktitle = {Am. Control Conf.}, -doi = {10.1109/ACC.2010.5530638}, -isbn = {978-1-4244-7427-1}, -month = jun, -pages = {3690--3696}, -title = {Networked control systems under cyber attacks with applications to power networks}, -year = {2010} -} -@inproceedings{kn:Sandberg10, -address = {Stockholm, Sweden}, -author = {Sandberg, H and Teixeira, A and Johansson, K H}, -booktitle = {First Work. Secur. Control Syst. CPSWeek}, -month = apr, -title = {On security indices for state estimators in power networks}, -year = {2010} -} - - - - - - -@phdthesis{Teixeira_PhD2014, - author = {Andr\'{e} M. H. Teixeira}, - title = {Toward Cyber-Secure and Resilient Networked Control Systems}, - school = {KTH Royal Institute of Technology}, - year = 2014, - address = {Stockholm, Sweden}, - month = nov, -} - - diff --git a/_config.yml b/_config.yml deleted file mode 100644 index f4501e4c..00000000 --- a/_config.yml +++ /dev/null @@ -1,75 +0,0 @@ -# Welcome to Jekyll! -# -# This config file is meant for settings that affect your whole blog, values -# which you are expected to set up once and rarely need to edit after that. -# For technical reasons, this file is *NOT* reloaded automatically when you use -# 'jekyll serve'. If you change this file, please restart the server process. - -# Site settings -title: Phong Lam's Home Page -email: lamthuaphong@gmail.com -description: > # this means to ignore newlines until "baseurl:" - Website of Phong Lam. -baseurl: "/" -url: "" - -include: - - .htaccess - - _pages - -sass: - sass_dir: _sass - -plugins: - - jekyll/scholar - -# Conversion -markdown: kramdown -highlighter: rouge -lsi: false -excerpt_separator: "\n\n" -incremental: false - - - -# Markdown Processing -kramdown: - input: GFM - hard_wrap: false - auto_ids: true - footnote_nr: 1 - entity_output: as_char - toc_levels: 1..6 - smart_quotes: lsquo,rsquo,ldquo,rdquo - enable_coderay: false - parse_block_html: true # default for kramdown is false. This will enable using Markdown links - - -# ----------------------------------------------------------------------------- -# Jekyll Scholar -# ----------------------------------------------------------------------------- - -scholar: - - style: _bibliography/ieee-with-url-mod.csl - locale: en - - source: /_bibliography/ - bibliography: uscl_publications.bib - bibliography_template: bib - # Note: if you have latex math in your bibtex, the latex filter - # preprocessing may conflict with MathJAX if the latter is enabled. - # See https://github.com/alshedivat/al-folio/issues/357. - bibtex_filters: [latex, smallcaps, superscript] - - replace_strings: true - join_strings: true - - details_dir: bibliography - details_layout: bibtex.html - details_link: Details - - query: "@*" - -filtered_bibtex_keywords: [abbr, abstract, arxiv, bibtex_show, html, pdf, selected, supp, blog, code, poster, slides, website] # Filter out certain bibtex entry keywords used internally from the bib output - diff --git a/_data/alumni_bsc.yml b/_data/alumni_bsc.yml deleted file mode 100644 index 8b137891..00000000 --- a/_data/alumni_bsc.yml +++ /dev/null @@ -1 +0,0 @@ - diff --git a/_data/alumni_members.yml b/_data/alumni_members.yml deleted file mode 100644 index 69b00df2..00000000 --- a/_data/alumni_members.yml +++ /dev/null @@ -1,6 +0,0 @@ -- name: Mohamed Abdalmoaty - photo: Abdalmoaty.jpg - position: Postdoc - duration: 2021 - 2023 - ORCID: 0000-0001-5474-7060 - info_current: Postdoc at ETH Zurich from 2023 diff --git a/_data/alumni_msc.yml b/_data/alumni_msc.yml deleted file mode 100644 index 0ec4bbc2..00000000 --- a/_data/alumni_msc.yml +++ /dev/null @@ -1,29 +0,0 @@ -# - name: Benjamin Bucknall, Spring 2022 - "Topic". - -# - name: Karl Walletin, Spring 2022 - "Topic". - -# - name: Teja Kedar Vaddehulgesh, Spring 2022 - "Topic". - -# - name: Oscar Larsson, Spring 2022 - "Topic". - -- name: Duc Huy Le, - info: Master student, Spring 2023 - ["Exploration-Exploitation Trade-off Approaches in Multi-Armed Bandit"](https://urn.kb.se/resolve?urn=urn:nbn:se:uu:diva-512002) - -- name: Teja Kedar Vaddehulgesh, - info: Master student, Spring 2023 - ["Evaluation of Cyber-Attacks in Networked Control Systems"](https://www.diva-portal.org/smash/get/diva2:1768944/FULLTEXT01.pdf) - -- name: Ankit Khandeparkar, - info: Master student, Spring 2023 - ["Embedded Control of a Rotary Inverted Pendulum"](https://www.diva-portal.org/smash/get/diva2:1763450/FULLTEXT01.pdf) - -- name: Rana Faheem Iftikhar, - info: Master student, Spring 2023 - ["Fault Tolerant Stabilizability in Multihop Control Networks"](https://urn.kb.se/resolve?urn=urn:nbn:se:uu:diva-513048) - -- name: Benjamin Bucknall, - info: Master student, Spring 2022 - ["Promoting Exploration in Reinforcement Learning through Surprise-Based Intrinsic Motivation"](http://urn.kb.se/resolve?urn=urn:nbn:se:uu:diva-479034) - number_educ: 0 - education1: - -- name: Oscar Larsson, - info: Master student, Spring 2022 - ["Generation and Detection of Adversarial Attacks in the Power Grid"](http://urn.kb.se/resolve?urn=urn:nbn:se:uu:diva-479474) - - diff --git a/_data/alumni_visitors.yml b/_data/alumni_visitors.yml deleted file mode 100644 index 06cf6bd9..00000000 --- a/_data/alumni_visitors.yml +++ /dev/null @@ -1 +0,0 @@ -[//]: # - name: Nikolaos Iliopoulos, Spring 2016 diff --git a/_data/news.yml b/_data/news.yml deleted file mode 100644 index c66fcc55..00000000 --- a/_data/news.yml +++ /dev/null @@ -1,132 +0,0 @@ -- date: 08 March 2024 - headline: "One recent paper has been accepted to the [IFAC SafeProcess 2024, Ferarra, Italy ](https://www.safeprocess2024.eu). The paper addresses the design of a full-state observer to maximize the transient detectability of static sensor errors, possibly caused through bias injection attacks. See the details at [Publications](publications)." - -- date: 29 February 2024 - headline: "Our two recent papers have been accepted to the [European Control Conference 2024, Stockholm ](https://ecc24.euca-ecc.org). They investigate problems in security of safety filters and detection of delay attacks. See their details at [Publications](publications)." - -- date: 02 February 2024 - headline: "We have **1 PhD position in Automatic Control focusing on probabilistic methods for secure control**, **deadline on March 08, 2024**. See the [job ad](https://www.jobb.uu.se/details/?positionId=697970&languageId=1) for how to apply!" - -- date: 30 Janurary 2024 - headline: "Welcome Jingwei Dong as a new PostDoc to our [group](team)! " - -- date: 08 Janurary 2024 - headline: "Our article [''Quickest detection of bias injection attacks on the glucose sensor in the artificial pancreas under meal disturbances''](https://www.sciencedirect.com/science/article/pii/S0959152424000027) was published on Journal of Process Control. The article studies the problem of detecting bias injection attacks on the glucose sensor in the artificial pancreas under sporadic meal uncertainties." - -- date: 06 December 2023 - headline: "We have **1 PhD position in Automatic Control focusing on Distributed Voltage Control**, together with KTH Royal Institute of Technology, **deadline on January 30, 2024**. See the [job ad](https://uu.varbi.com/en/what:job/jobID:680621/) for how to apply!" - -- date: 01 December 2023 - headline: "We have **1 Postdoc position** in Machine Learning focusing on Secure Federated Learning, together with [Scaleout Systems AB](https://www.scaleoutsystems.com), **deadline on January 15, 2024**. See [the job ad](https://uu.varbi.com/en/what:job/jobID:679885/) for how to apply!" - -- date: 29 November 2023 - headline: "André has been appointed as a [Wallenberg Academy Fellow 2023](https://kaw.wallenberg.org/en/andre-teixeira). Wallenberg Academy Fellows, the career program for young researchers launched by the [Knut and Alice Wallenberg Foundation](https://kaw.wallenberg.org/en) in cooperation with the Swedish Royal Academies in 2012, provides long-term funding for young, promising Swedish and foreign researchers from all academic fields. In 2023, 31 new researchers were appointed to the program." - -- date: 06 November 2023 - headline: "The Swedish Research Council has funded our project ''Probabilistic Methods for Secure Learning and Control'' (2024-2027), as part of the special [call for projects in cybersecurity](https://www.vr.se/english/applying-for-funding/decisions/2023-06-22-natural-and-engineering-sciences.html). André and Per will be leading the project." - -- date: 18 October 2023 - headline: "Our group received a grant by the Swedish Energy Agency for our newest four-year project [ADVOLCANO - Adverse Voltage Controllers' Interactions in Active Distribution Networks](https://www.energimyndigheten.se/forskning-och-innovation/projektdatabas/sokresultat/?registrationnumber=2023-201169). The project is led by RISE, together with KTH and our group and Uppsala University. The topic of the project is on active voltage controllers for resilient and safe electricity supply." - -- date: 17 October 2023 - headline: "A new movie from SSF (Swedish Foundation for Strategic Research) describes [our team's research in developing more secure control systems in a popular scientific way](research)." - -- date: 13 October 2023 - headline: "Tung has successfully defended his Licentiate thesis [''Security Allocation in Networked Control Systems''](http://www.it.uu.se/research/publications/lic/2023-003/2023-003.pdf) on October 13, 2023. Congratulations, Tung!" - -- date: 10 October 2023 - headline: "Tung got Erasmus+ Staff Mobility Grant to visit University of Cyprus for a month." - -- date: 29 September 2023 - headline: "Our group received a [Vinnova grant for a two-year project](https://www.vinnova.se/en/p/validating-a-system-development-kit-for-edge-federated-learning/) led by Scaleout Systems AB. The topic of the project is secure federated machine learning." - -- date: 25 September 2023 - headline: "Our article [''Risk Assessment of Stealthy Attacks on Uncertain Control Systems''](https://arxiv.org/abs/2106.07071) was accepted to the IEEE Transaction on Automatic Control, 2023. This article studies the problem of determining the risk of attacks in the presence of an adversary with uncertain system knowledge." - -- date: 25 September 2023 - headline: "Welcome Alain Govaert as a new PostDoc to our [group](team)! " - -- date: 29 August 2023 - headline: "[The Royal Society of Sciences at Uppsala](https://www.vetenskapssocietetenuppsala.se) has awarded the [Lilly and Sven Thuréus prize, technology-economics class, to André Teixeira](https://www.uu.se/nyheter/arkiv/2023-08-29-thureus-pris-till-tre-framstaende-forskare) for his work in _'designing intelligent autonomous decision-making systems that are secure and resilient to external attacks (cyber threats)'_." - -- date: 16 August 2023 - headline: "Welcome Lovisa Eriksson as a new PhD student, Ruslan Seifullaev and Daniel Arnström as new PostDocs to our [group](team)! " - -- date: 14 August 2023 - headline: "Our article [''Risk-based Security Measure Allocation Against Actuator Attacks''](https://doi.org/10.1109/OJCSYS.2023.3305831) was accepted to the IEEE Open Journal of Control Systems, 2023. This article considers the problem of risk-optimal allocation of security measures when the actuators of an uncertain control system are under attack." - -- date: 12 July 2023 - headline: "Our four recent papers have been accepted to the [IEEE Conf. Decision and Control 2023, Singapore ](https://cdc2023.ieeecss.org). They investigate problems in security and privacy of distributed consensus, secure state estimation, robust change detection, and detection of delay attacks. See their details at [Publications](publications)." - -- date: 02 July 2023 - headline: "The Division of Systems and Control has an open faculty position for an Assistant Professor in Automatic Control, **deadline on September 15**. See [the position ad](https://www.jobb.uu.se/details/?positionId=638951) for how to apply!" - -- date: 16 June 2023 - headline: "We have **1 PhD position** in Automatic Control focusing on Secure Control, **deadline on August 21**. See [the PhD ad](https://www.jobb.uu.se/details/?positionId=637356) for how to apply!" - -- date: 18 April 2023 - headline: "Our article [''Quickest Detection of Deception Attacks on Cyber-Physical Systems with a Parsimonious Watermarking Policy''](https://arxiv.org/abs/2201.09389) has just been accepted to the IFAC Journal Automatica. The paper investigates the problem of quickest change detection via physical watermarking with a twist: to balance the usage of watermarking noise with the detection delay." - -- date: 13 March 2022 - headline: "Sribalaji C. Anand has received the Liljewalch travel scholarship to support his research visit to Technion - Israel Institute of Technology, Haifa, June 2023." - -- date: 13 March 2022 - headline: "Fatih Emre Tosun received the Liljewalch travel scholarship to support his attendance to the [7th Edition of the Workshop on Nonlinear System Identification Benchmarks](https://www.nonlinearbenchmark.org/) at Eindhoven, The Netherlands, on 19-21 April 2023." - -- date: 03 March 2023 - headline: "Our three recent papers have been accepted to the [IFAC World Congress 2023, Yokohama, Japan](https://www.ifac2023.org). They investigate problems in security and privacy via dynamic masking, optimal detector placement, and detection of delay attacks. See their details at [Publications](publications)." - -- date: 15 February 2023 - headline: "(Closed) We have **1 Postdoc position** focusing on [Secure Learning and Control](http://uu.varbi.com/en/what:job/jobID:591192/), **deadline on March 15**." - -- date: 08 February 2023 - headline: "(Closed) We have **1 Postdoc position** in Automatic Control focusing on [Resilience in Large-Scale Critical Infrastructures](http://uu.varbi.com/en/what:job/jobID:592325/), **deadline on March 15**." - -- date: 31 January 2023 - headline: "(Closed) We have **1 PhD position** in Automatic Control focusing on Secure Learning and Control, **deadline on February 28**. See [the PhD ad](http://uu.varbi.com/en/what:job/jobID:589746/) for how to apply!" - -- date: 30 January 2023 - headline: "Welcome Usama Zafar to our [group](team) as a new PhD student! He will be working on the project \"Secure Federated Machine Learning.\"" - -- date: 20 December 2022 - headline: "Tung has received the Stenholm, Wilgott travel scholarship to support his attendance to an intensive course within the EECI International Graduate School on Control 2023." - -- date: 20 December 2022 - headline: "Sribalaji has received the Stenholm, Wilgott travel scholarship to support his research visit to Eindhoven University of Technology between March and July, 2023." - -- date: 10 December 2022 - headline: "Our two recent papers were presented [IEEE Conf. on Decisions and Control 2022](https://cdc2022.ieeecss.org). Participants can see the pre-recordings until March 2023!" - -- date: 31 October 2022 - headline: "Welcome Zhenlu Sun to our group as a new PhD student! He will be working on the project \"Data-driven vulnerability analysis for critical infrastructures\"." - - -- date: 14 October 2022 - headline: "We have several proposals for MSc thesis projects at our group, candidates are interviewed continuously **until early December**. See [the list and details](https://tinyurl.com/MSc2023-SysCon) for how to apply!" - - -- date: 23 August 2022 - headline: "We have **1 PhD position** focusing on Secure Federated Machine Learning, **deadline on September 27**. See [the ad](https://uu.varbi.com/what:job/jobID:535881/) for how to apply!" - - -- date: 22 August 2022 - headline: "We have two new papers accepted to IEEE Transactions in Automatic Control, take a look at our [Publications](publications) page for their DOI." - - -- date: 22 August 2022 - headline: "We have two new papers accepted to the [IEEE Conference on Decisions and Control 2022](https://cdc2022.ieeecss.org)! Take a look at our [Publications](publications) page. See you in Cancun, Mexico!" - - -- date: 19 May 2022 - headline: "We have **2 Postdocs positions** in Secure Learning and Control, one of which focused on Large-Scale Systems, **deadline on July 29**. See [the ad](https://uu.varbi.com/what:job/jobID:509082) for how to apply!" - - -- date: 19 May 2022 - headline: "We have **1 PhD position** on Secure Learning and Control Systems, **deadline on June 20**. See [the ad](https://uu.varbi.com/what:job/jobID:507667/) for how to apply!" - - -- date: 16 May 2022 - headline: "We have **1 PhD position** on Secure Federated Machine Learning, **deadline on May 27**. See [the ad](https://uu.se/en/about-uu/join-us/details/?positionId=507539) for how to apply!" - -- date: 08 May 2022 - headline: "**Our new paper**, on Risk assessment and optimal allocation of security measures, has been accepted to the [Conference on Control Technology and Applications 2022](https://ccta2022.ieeecss.org)." diff --git a/_data/pictures_Uppsala.yml b/_data/pictures_Uppsala.yml deleted file mode 100644 index 2c693807..00000000 --- a/_data/pictures_Uppsala.yml +++ /dev/null @@ -1,2 +0,0 @@ -- title: pic1_description - image: DSC_0366.JPG \ No newline at end of file diff --git a/_data/project.yml b/_data/project.yml deleted file mode 100644 index 4da988ce..00000000 --- a/_data/project.yml +++ /dev/null @@ -1,125 +0,0 @@ -- title: "Prob4Sec - Probabilistic Methods for Secure Learning and Control" - key: "VR2023-AT" - agency: "Swedish Research Council (Vetenskapsrådet)" - category: "VR Project Grant in Information and Cyber Security" - period: "2023-2027" - ongoing: 1 - lead: "*André Teixeira* (PI) and *Per Mattsson*" - member: "1 PhD student" - selected: 1 - summary: "Prob4Sec aims to develop theory and probabilistic methods for securing cyber-physical systems (CPSs) possessing learning and control capabilities: digital devices that learn from data they collect, and automatically decide how to best interact with the physical world over time. Intelligent CPSs are pervasive in our society. Users rely and trust that these devices will operate in a safe and secure manner. The consequences of incorrect behaviors in CPSs can be dire, threatening the users well being. Securing these systems is of utmost importance. Probabilistic methods are a natural way to deal with the uncertainty of physical systems and unintentional failures. Mathematical and statistical tools enable us to take a small number of samples and still be able to draw general conclusions. However, attacks are not only probabilistic but can have strategic behaviors, tailored to causing harm while avoiding detection. Hence, it is critical to develop systematic approaches that integrate the probabilistic and the strategic aspects of attacks in security analysis. Prob4Sec combines knowledge from security, statistical methods, and AI and control engineering to develop new methods for designing secure CPSs with learning and control functionalities. These methods will be instrumental in preventing future threats to all who benefit from this technology. Prob4Sec will provide further tools based on which trust in new technologies can be built and communicated, from developers to end users." - -- title: "Learning for decision and control in a population of dynamical systems" - key: "VR2023-PM" - agency: "Swedish Research Council (Vetenskapsrådet)" - category: "VR Starting grant within natural and engineering sciences" - period: "2024-2027" - ongoing: 1 - lead: "*Per Mattsson* (PI)" - member: "1 PhD student" - selected: 1 - summary: "In real-world applications there are often many individual systems with similar dynamics - a population of systems. For example batteries in different cars, different batches in the process industry or different patients in medicine. By taking a population view we can study how the dynamical systems in the population can learn from each other, both when it comes to estimating models and designing controllers, and how to detect systems with anomalous behavior that may need maintenance or replacement. The aim of this project is to develop methods and analysis to tackle these problems in a coherent way. To realize this we have identified three subprojects. In the first we will develop and analyze estimation methods for populations of systems that can also handle anomalous systems. In the second we will study how these models can be used for population-wide monitoring and anomaly detection. In the third we will develop methods for robust data-driven control, where individual systems learn from each other. We already have established collaborations with experts in industry that can provide us with relevant applications and data for evaluation of the developed methods. By considering populations, instead of single systems as traditionally done in control theory, and taking on these three problems in a coherent way we believe that this project will open up new research directions in, and make significant contributions to, data-driven modeling, fault detection and control." - -- title: "ADVOLCANO - Adverse Voltage Controllers’ Interactions in Active Distribution Networks" - key: "STEM2023-AT" - agency: "Swedish Energy Agency" - category: "Program 'The Electrical System of the Future'" - period: "2023-2026" - ongoing: 1 - lead: "Stefan Stanković (PI, RISE), Xiaofeng Xong (KTH), Henrik Sandberg (KTH), *André Teixeira*" - member: "1 PhD student" - selected: 1 - summary: "To meet the climate and safety challenges of today and the future, new technology is used that changes the dynamics of the electric power system, but which often also leads to unpredictable system behavior. To support voltage regulation in local distribution systems, but also to assist with voltage regulation in the overhead power transmission system, inverter-based generation is often used. However, these can lead to harmful interactions between voltage regulators that can compromise system security. This project analyzes these interactions. The project focus is on modeling and characterizing the interactions between voltage contorllers, as well as developing methods for analyzing them. Based on the analysis, in the project we will propose solutions on how to implement new voltage regulation strategies in active distribution networks while avoiding risks of harmful interactions. The project thus contributes to improved resilience and future secure electricity supply." - - -- title: "Validating a System Development Kit for edge federated learning" - key: "VINNOVA2023-AT" - agency: "Sweden's Innovation Agency (Vinnova)" - category: "'Advanced and innovative digitalisation'" - period: "2023-2025" - ongoing: 1 - lead: "Andreas Hellander (PI, Scaleout), *Salman Toor* (Scaleout), *André Teixeira*" - member: "Usama Zafar, 1 Postdoc" - selected: 1 - summary: "The project´s primary aim is to increase our understanding of scalability and cyber security in federated machine learning specifically for cloud edge applications. We will also further develop and validate a system development kit for federated machine learning, FEDn, for large-scale applications in fleet intelligence." - -- title: "Secure Federated Machine Learning at Scale" - key: "UU2022-ST" - agency: "Dept. of Information Technology, Uppsala University" - category: "'Joint Strategic Research Activities - Graduate School in Cybersecurity'" - period: "2022-2026" - ongoing: 1 - lead: "*Salman Toor* (PI), *André Teixeira*" - member: "Usama Zafar" - selected: 1 - summary: "The overall aims of the project are to mitigate the risk of attacks by providing security and enhanced privacy for a scalable federated training environment. In particular, the project addresses concerns related to security and privacy in federated machine learning against model poisoning and information leakage attacks. The envisioned approach is centered around developing new theories and methodologies to achieve two main aims: secure aggregation of local models under poisoning attacks, and private distributed aggregation of local models." - - -- title: "Data-driven Vulnerability Analysis for Critical Infrastructures" - key: "eSSENCE2021-ST" - agency: "eSSENCE-SciLifeLab" - category: "'Graduate School in Data-Intensive Science'" - period: "2022-2026" - ongoing: 1 - lead: "*Salman Toor* (PI), *André Teixeira*" - member: "Zhenlu Sun" - selected: 1 - summary: "In the last two decades, solutions to address software vulnerabilities have evolved significantly. With predictive schemes, vulnerability analysis has shifted from being reactive to being proactive in terms of early identification of possible risks. A comprehensive vulnerability analysis requires data from application execution patterns, network logs, infrastructure logs, and traces from the source code. Efficient collection, availability and analysis of the log files is a non-trivial task as this data grows rapidly with the execution pattern of the applications. The other sources include infrastructure settings and, most importantly, the information available in public vulnerability databases. All these massive data sources form the basis to call vulnerability analysis a big data challenge. A comprehensive data-driven vulnerability analysis framework will be required to ensure reliable, efficient and uninterrupted mission critical services based on software applications. This project takes a data-intensive approach to analyse and diagnose the presence of cybersecurity vulnerabilities in software applications supporting services within critical computing infrastructures. Our approach consists of combining above-mentioned different data sources with attack modeling frameworks and use explainable machine learning techniques to analyze and diagnose security vulnerabilities in software and network configurations." - - - -- title: "ReSiSt - Resilience, Safety, and Security in Tree-structured Civil Networks" - key: "VR2021-AT" - agency: "Swedish Research Council (Vetenskapsrådet)" - category: "VR Project Grant in Societal Security" - period: "2021-2024" - ongoing: 1 - lead: "*André Teixeira* (PI), Alexander Medvedev, *Per Mattsson*, Stefan Engblom" - member: "Mohamed Abdalmoaty, Alain Govaert" - selected: 0 - summary: "Civil infrastructure networks (CIN) critically support modern society by distributing resources and protecting communities from hazards. Distributed control and monitoring of CIN to meet network demand under the network efficiency and cost constraints also poses physical security and cyber-security challenges. The resilience of civil infrastructure to disruptive events is the overarching topic of the present project. The project goal is to devise a coherent system theoretical platform for resilience analysis of CIN as well as resilience informed control of those. More specifically, a CIN is modeled as a cyber-physical system (CPS) whose physical layer is a transportation network equipped with actuator and sensor nodes interlaced with a computer network that implements control and monitoring of the physical layer. The scope is limited to the consideration of CPS with a tree-structured physical layer and covers a broad class of pipeline systems, i.e. networked systems transporting single or multi phase fluids. Failures, breakdowns, natural hazards, and cyberattacks are considered potential disruptive events. The project will be conducted along three main threads Mathematical modeling of CIM as CPS Model based assessment of resilience via operational indices Resilience informed control of CIM. The feasibility and efficacy of the developed mathematical models and algorithms will be evaluated with respect to urban water and wastewater networks." - -- title: "Secure and Resilient Control Systems" - key: "SSF2020-AT" - agency: "Swedish Foundation for Strategic Research (SSF)" - category: "SSF Future Research Leaders 7" - period: "2020-2025" - lead: "*André Teixeira* (PI)" - member: "Sribalaji Anand, Anh Tung Nguyen, Daniel Arnstöm, Ruslan Seifullaev" - ongoing: 1 - selected: 1 - summary: "Reports of cyber-attacks on digitally controlled systems supporting modern societies, such as Stuxnet, have shown their devastating consequences to safety and human lives, and shed light on the attackers modus operandi first learn the system, then tamper the visible information so the attack is undetected, and meanwhile have significant impact on the physical system. It is of the utmost importance to be able to detect and mitigate such malicious cyber-attacks. Unfortunately, existing methods in control engineering consider impact on the physical system and detectability separately, and thus fail to accurately tackle cyber attacks that strategically mix high impact with low detectability. On the other hand, approaches from secure control assume adversaries with perfect knowledge, resulting in overly pessimistic, unrealistic conclusions. The project will produce approaches to analyze and mitigate cyber-attacks on control systems, through the following actions 1) to construct novel sensitivity metrics that jointly consider the impact and detectability of attacks under uncertainty; 2) to design optimal anomaly detectors, controllers, and security measure deployment that minimize the novel sensitivity metrics, and thus increase security; 3) to experimentally validate the developed scientific approaches in testbeds and numerical benchmarks. The developed science and tools will induce a paradigm change in robust control and fault detection, and allow for more effective handling of anomalies." - -- title: "ADSec - Analysis and Design of Secure and Resilient Control Systems" - key: "VR2019-AT" - agency: "Swedish Research Council (Vetenskapsrådet)" - category: "VR Starting Grant" - period: "2019-2023" - lead: "*André Teixeira* (PI)" - member: "Sribalaji Anand, Fatih Emre Tosun" - ongoing: 1 - selected: 0 - summary: "Reports on cyber-attacks, such as Stuxnet, have shown their devastating consequences on digitally controlled systems supporting modern societies. It is therefore of the utmost importance for control systems to be able to early detect and mitigate malicious cyber-attacks, which aim at having a significant impact on the system while remaining undetected. Unfortunately, existing techniques in control theory consider impact and detectability separately, and thus fail to accurately tackle malicious cyber-attacks. The aim of this project is to develop novel security metrics that jointly consider the impact and detectability of attacks, and that support the analysis and design of anomaly detectors and controllers for improved security and resilience." - -- title: "LifeSec - Don't Hack my Body" - key: "SSF2018-TV" - agency: "Swedish Foundation for Strategic Research (SSF)" - category: "SSF Cyber Security Framework Program" - period: "2018-2023" - lead: "Thiemo Voigt (UU, PI), Robin Augustin (UU), Anders Ahlén (UU), Subhrakanti Dey (UU)" - member: "André Teixeira, Fatih Emre Tosun" - ongoing: 1 - selected: 1 - summary: "Implanted devices must be effectively secured to avoid life-threatening scenarios where attackers control implanted devices such as pacemakers or insuline pumps, or install malware inside a human body. This project devises a security architecture for networked implanted medical devices that also enables a secure connection of the in-body network to the Internet. Our architecture ensures confidentiality, integrity and availability of the implanted devices considering also patients’ privacy." - -- title: "Secure Our Safety: Building Cyber Security for Flood Management" - key: "NWO2015-AT" - agency: "Dutch Research Council" - grant-nr: "628.001.010" - category: "Cyber Security research program" - period: "2015-2019" - lead: "Pieter van Gelder (TU Delft), Wolter Pieters (TU Delft)" - ongoing: 0 - selected: 0 - summary: "Cyber attacks on critical infrastructures can have devastating consequences for environment, health and even human lives. To improve the protection and resilience, various approaches for security risk assessment, attack detection and safety monitoring have been developed. However, the links between cyber security and safety management are poorly understood, and relevant information is not shared, creating space for malicious activities to pass undetected. The project has two objectives. Firstly, the project will enrich network security monitoring with safety context information. Secondly, the project will improve safety incident response by procedures that include information from security monitoring in assessing the expected effectiveness of responses. The integration of the two innovations will enable adequate responses to flood defense security threats." - diff --git a/_data/publist.yml b/_data/publist.yml deleted file mode 100644 index 99dd623e..00000000 --- a/_data/publist.yml +++ /dev/null @@ -1,22 +0,0 @@ -- title: "Security Allocation in Networked Control Systems" - image: Tung_Lic_2023.jpg - description: This thesis develops a framework for evaluating and improving the security of networked control systems in the face of cyber attacks. The considered security problem involves two strategic agents, namely a malicious adversary and a defender, pursuing their specific and conflicting goals. The defender aims to efficiently allocate defense resources with the purpose of detecting malicious activities. Meanwhile, the malicious adversary simultaneously conducts cyber attacks and remains stealthy to the defender. We tackle the security problem by proposing a game-theoretic framework and characterizing its main components the payoff function, the action space, and the available information for each agent. Especially, the payoff function is characterized based on the output-to-output gain security metric that fully explores the worst-case attack impact. Then, we investigate the properties of the game and how to efficiently compute its equilibrium. Given the combinatorial nature of the defender actions, one important challenge is to alleviate the computational burden. To overcome this challenge, the thesis contributes several system- and graph-theoretic conditions that enable the defender to shrink the action space, efficiently allocating the defense resources. The effectiveness of the proposed framework is validated through numerical examples. - authors: Anh Tung Nguyen - year: 2023 - link: - url: https://www.it.uu.se/research/publications/lic/2023-003/2023-003.pdf - display: Licentiate Thesis, Uppsala University, (2023) - highlight: 1 - news2: - -- title: "Safety, Security and Privacy for Cyber-Physical Systems" - image: Springer_book_2021.png - description: This book presents an in-depth overview of recent work related to the safety, security, and privacy of cyber-physical systems (CPSs). It brings together contributions from leading researchers in networked control systems and closely related fields to discuss overarching aspects of safety, security, and privacy; characterization of attacks; and solutions to detecting and mitigating such attacks.
The book begins by providing an insightful taxonomy of problems, challenges and techniques related to safety, security, and privacy for CPSs. It then moves through a thorough discussion of various control-based solutions to these challenges, including cooperative fault-tolerant and resilient control and estimation, detection of attacks and security metrics, watermarking and encrypted control, privacy and a novel defense approach based on deception. The book concludes by discussing risk management and cyber-insurance challenges in CPSs, and by presenting the future outlook for this area of research as a whole.
Its wide-ranging collection of varied works in the emerging fields of security and privacy in networked control systems makes this book a benefit to both academic researchers and advanced practitioners interested in implementing diverse applications in the fields of IoT, cooperative autonomous vehicles and the smart cities of the future. - authors: Riccardo M. G. Ferrari and André M. H. Teixeira (Eds) - year: 2021 - link: - url: https://doi.org/10.1007/978-3-030-65048-3 - display: Lecture Notes in Control and Information Sciences (LNCIS, volume 486), Springer International Publishing, (2021) - highlight: 1 - news2: - long: 1 diff --git a/_data/research_themes.yml b/_data/research_themes.yml deleted file mode 100644 index 8476c7dc..00000000 --- a/_data/research_themes.yml +++ /dev/null @@ -1,86 +0,0 @@ -- title: "Security metrics for control systems" - key: "secmetrics" - hasimage: 1 - width: 50% - image: cvar.png - description: The aim within this theme is to to create novel methodologies addressing cybersecurity problems under uncertainty in learning and control systems. A core element of this research is the development of novel *probabilistic risk metrics* and optimization-based design methods that *jointly consider the impact and the detectability constraints of attacks*, as well as model uncertainty and prior beliefs on the adversary model. - authors: Sribalaji C. Anand, Anh Tung Nguyen, André M. H. Teixeira - year: 2019 - tag: 10001 - highlight: 1 - news1: - news2: - long: 0 - -- title: "Secure Federated Machine Learning" - key: "secfedml" - hasimage: 1 - width: 70% - image: FedML2.png - description: "Federated machine learning (FedML) has proven to be a suitable approach for privacy-preserving machine learning across a large number of heterogeneous devices. Our group addresses concerns related to security and privacy in federated machine learning against model poisoning and information leakage attacks. The approach is centered around developing new theories and methodologies to achieve two main aims: secure aggregation of local models under poisoning attacks; private distributed aggregation of local models." - authors: Usama Zafar, Salman Toor, André M. H. Teixeira - year: 2023 - tag: 10003 - highlight: 1 - news1: - news2: - long: 0 - - -- title: "Secure artificial pancreas" - key: "secpancreas" - hasimage: 1 - width: 60% - image: GCM.jpg - description: "Artificial pancreas are envisioned medical systems whose function is to automatically regulate the blood glucose levels in patients with diabetes, with little to none human initervention. At the core of these systems we have an intellligent device autonomously deciding how much synthetic insulin and glucagon to infuse into the body through infusion pumps, based on data received from sensors located thoughout the body measuring, for instance, blood glucose levels in real-time. Data exchange among the controlling device, the pumps, and the sensors is critical. The whole system must operate safely, even in the presence of adversaries tampering with the communication or devices. \n\nIn this line of research, we develop schemes to monitor the sensor reading to detect anomalies, and distinguish them from natural unknown disturbances, such as meal intakes, physical exercise, among others." - authors: Fatih Emre Tosun, André M. H. Teixeira - year: 2019 - tag: 10002 - highlight: 1 - news1: - news2: - long: 0 - -- title: "Delay attacks on networked control systems" - key: "delayattacks" - hasimage: 1 - width: 60% - image: Time_Delay.png - description: "Feedback loop delay is known to impose limitations on the achievable performance of control systems. In particular, delays can increase oscillations, reduce regulation accuracy, and may cause destabilization of the control system. Large enough delays may also cause the loss of communication packets between the sensors, the controller, and the actuators, resulting in denial-of-service at the controller. Delays and packet losses are important aspects to be considered in the context of control over wireless communication networks. -Unfortunately, delays can also be induced by malicious cyber-attacks that aim to disrupt the system. In the security context, it is important to understand how delays may be induced by adversaries and how the attacks may be disguised as natural properties of the communication channel. -Our group investigates novel control-theoretic approaches for understanding, detecting, and mitigating attack-induced delays and packet losses, combining techniques from system identification, anomaly detection, and robust control." - authors: Torbjörn Wigren, Ruslan Seifullaev, André M. H. Teixeira - year: 2022 - tag: 10004 - highlight: 1 - news1: - news2: - long: 0 - -- title: "Security and resilience of networked dynamical systems" - key: "MAS" - hasimage: 1 - width: 80% - image: secure_networkv2.png - description: "Sustained use of critical infrastructure, such as electrical power and water distribution networks, requires efficient management and control. Facilitated by the advancements in computational devices and non-proprietary communication technology, such as the Internet, the efficient operation of critical infrastructure relies on network decomposition into interconnected subsystems, thus forming networked control systems. However, the use of public and pervasive communication channels leaves these systems vulnerable to cyber attacks. This theme aims to create novel methodologies to enhance the security and resilience of networked dynamical systems under cyber attacks." - authors: Anh Tung Nguyen, Alain Govaert, André M. H. Teixeira, Sérgio Pequito - year: 2021 - tag: 10005 - highlight: 1 - news1: - news2: - long: 0 - -- title: "Privacy of networked dynamical systems" - key: "Privacy" - hasimage: 1 - width: 50% - image: privacy_networked_systems.webp - description: "Guaranteeing privacy in dynamical networks is particularly important in the pressing concern of privacy in distributed optimization scenarios common in machine learning and artificial intelligence. The intrinsic design of these networks traditionally depends on implicit trust among agents, raising significant privacy issues. We propose a novel approach that integrates control theory and optimization techniques to address these privacy concerns. Our approach aims to refine network architectures and communication protocols, ensuring that the privacy of individual agents is preserved while maintaining the efficacy of collective decision-making processes. This advancement in network design is poised to substantially improve the handling of privacy in dynamical networks, facilitating their reliable and private application in various settings." - authors: André M. H. Teixeira, Sérgio Pequito - year: 2023 - tag: 10006 - highlight: 1 - news1: - news2: - long: 0 diff --git a/_data/students.yml b/_data/students.yml deleted file mode 100644 index 1e42cb73..00000000 --- a/_data/students.yml +++ /dev/null @@ -1,55 +0,0 @@ -#- name: -# photo: rock.jpg -# info: -# email: -# number_educ: -# education1: -# education2: -# education3: -# education4: - -- name: Andreas Hertzberg, - photo: rock.jpg - info: Master student, Spring 2024 - "Secure Multi-Agent Control Systems" - number_educ: 0 - education1: - -- name: Linus Svensson, - photo: rock.jpg - info: Master student, Spring 2023 - "Modelling of cyber-physical security for an automotive battery control system" - number_educ: 0 - education1: - -# - name: Duc Huy Le, -# photo: rock.jpg -# info: Master student, Spring 2023 - "Surprise-based exploration in multi-arm bandits" -# number_educ: 0 -# education1: - -# - name: Ankit Khandeparkar, -# photo: rock.jpg -# info: Master student, Spring 2023 - "Embedded implementation of learning and control algorithms on a rotary inverted pendulum" -# number_educ: 0 -# education1: - -# - name: Rana Faheem Iftikhar, -# photo: rock.jpg -# info: Master student, Spring 2023 - "Stabilization of Multi-Hop Control Networks Subject to Malicious Attacks" -# number_educ: 0 -# education1: - -- name: Karl Walletin, - photo: rock.jpg - info: Master student, Spring 2022 - "Implementation and evaluation of digital signal watermarking for control systems" - # email: - number_educ: 0 - education1: - -# - name: Teja Kedar Vaddehulgesh, -# photo: rock.jpg -# info: Master student, Spring 2022 - "Evaluation of security in wireless control systems" -# # email: -# number_educ: 0 -# education1: - - diff --git a/_data/team_members.yml b/_data/team_members.yml deleted file mode 100644 index ca7e30b1..00000000 --- a/_data/team_members.yml +++ /dev/null @@ -1,177 +0,0 @@ -- name: André Teixeira - photo: Teixeira1.jpg - info: Associate Professor, Lab Director - short_bio: André Teixeira is an Associate Professor at the Division of Systems and Control, Department of Information Technology, Uppsala University, Sweden. He received the M.Sc. degree in electrical and computer engineering from the Faculdade de Engenharia da Universidade do Porto, Porto, Portugal, in 2009, and the Ph. D. degree in automatic control from the KTH Royal Institute of Technology, Stockholm, Sweden, in 2014. From 2014 to 2015, he was a Postdoctoral Researcher at the Department of Automatic Control, KTH Royal Institute of Technology, Stockholm, Sweden. From October 2015 to August 2017, Teixeira was an Assistant Professor in Cybersecurity of Critical Infrastructures at the Faculty of Technology, Policy and Management, Delft University of Technology, The Netherlands. From September 2017 to April 2021, he was an Assistant Professor at the Department of Electrical Engineering at Uppsala University. Teixeira was a recipient for the Best Student-Paper Award from the IEEE Multi-Conference on Systems and Control in 2014, and an Honorable Mention for the Paul M. Frank Award at the IFAC SAFEPROCESS 2018. He was awarded a Starting Grant by the Swedish Research Council in 2018, and he is among the 20 young researchers in Sweden who received the Future Research Leaders 7 grant by the Swedish Foundation for Strategic Research in 2020. He was awarded the Lilly and Sven Thuréus prize in 2023 by The Royal Society of Sciences at Uppsala. In 2023, André was appointed as a Wallenberg Academy Fellow by the Knut and Alice Wallenberg Foundation. - email: andre.teixeira@it.uu.se - website: https://www.andre-teixeira.eu - number_educ: 0 - education1: - education2: - education3: - education: - -- name: Sergio Pequito - photo: Sergio.png - info: Associate Professor - short_bio: Sérgio Pequito is an associate professor in automatic control in the Department of Information Technology, at Uppsala University. Pequito's research consists of understanding the global qualitative behavior of large-scale systems from their structural or parametric descriptions and provides a rigorous framework for the design, analysis, optimization, and control of large-scale systems. His interests span neuroscience and biomedicine, where dynamical systems and control theoretic tools can be leveraged to develop new analysis tools for brain dynamics toward effective personalized medicine and improve bidirectional interfaces. Pequito was awarded the best student paper finalist in the 48th IEEE Conference on Decision and Control (2009) and the 2016 O. Hugo Schuck Award in the Theory Category by the American Automatic Control Council. - topics: - email: sergio.pequito@it.uu.se - website: https://www.spequito.com/ - number_educ: 0 - education1: - education2: - education3: - education4: - -- name: Salman Toor - photo: Toor.png - info: Associate Professor - short_bio: Salman Toor is an Associate Professor at the Division of Scientific Computing, Department of Information Technology, Uppsala University, Sweden. He earned his Masters and PhD in Scientific Computing from Uppsala University. In 2014, Toor finished his postdoctoral research from CMS program, Helsinki Institute of Physics, Finland. His area of expertise includes management, scalability and performance of distributed infrastructures for scientific applications. Toor is an active member of Distributed Computing Applications (DCA) group at Uppsala University. From 2015-2017, Toor was employed as a researcher in the Department of Information Technology, Uppsala University and as a senior cloud architect at Swedish National Infrastructure for Computing (SNIC). His research focuses on Distributed Computing Infrastructures. - topics: - email: salman.toor@it.uu.se - website: https://katalog.uu.se/profile/?id=N7-398 - number_educ: 0 - education1: - education2: - education3: - education4: - -- name: Torbjörn Wigren - photo: Torbjorn.jpg - info: Guest Researcher - short_bio: Torbjörn Wigren is a Guest Researcher at the Division of Systems and Control, Department of Information Technology, Uppsala University, Sweden. He received the M.Sc. degree in engineering physics (electrical engineering) in 1985, and the Dr. of Technology degree in automatic control in 1990, both from Uppsala University, Uppsala Sweden. His main employer from 2001 is Ericsson AB, where he is a Principal Developer, responsible for R&D on radio near feedback control and signal processing algorithms for 5G and 6G cellular systems. Before joining Ericsson, he held positions with Bofors Aerotronics (1985-1991), Ericsson Radio Systems (1991-1995) and Celsius Tech Systems (1995-2001) where he was involved in development of fire control systems, audio signal processing, and passive air-target tracking. During 2000 - 2018 he was Adjunct Professor of Automatic Control at Uppsala University. His research is focused on nonlinear dynamic systems, including recursive identification, optimal control and estimation, as well as on the use of feedback principles in machine learning. - topics: - email: Torbjorn.Wigren@it.uu.se - website: http://www.it.uu.se/katalog/tw - number_educ: 0 - education1: - education2: - education3: - education4: - -- name: Per Mattsson - photo: PerMatsson1.jpg - info: Associate Professor - short_bio: Per Mattsson is an Associate Professor in automatic control in the Department of Information Technology at Uppsala University. He received his Ph.D. degree in automatic control and system identification from Uppsala University in 2016. Mattsson’s research focuses on the development and analysis of data-driven methods for modeling, control, and predictive maintenance. - topics: - email: per.mattsson@it.uu.se - website: https://katalog.uu.se/profile/?id=N10-1806 - number_educ: 0 - education1: - education2: - education3: - education4: - -- name: Ruslan Seifullaev - photo: ruslan.jpg - info: Postdoc, started August 2023 - short_bio: Ruslan Seifullaev is a Postdoctoral Researcher at the Division of Systems and Control, Department of Information Technology, Uppsala University, Sweden. He received the Diploma (M.Sc.) degree in theoretical cybernetics and the Candidate of Science (Ph.D.) degree in discrete mathematics and mathematical cybernetics from St. Petersburg University in 2012 and 2016, respectively. From 2014 to 2018, he was employed as a Research Engineer at the Institute of Problems in Mechanical Engineering of Russian Academy of Sciences. In 2023, he received the Ph.D. degree in signal processing from the Division of Signals and Systems, Uppsala University. His research interests include nonlinear control theory, time-delay systems, and networked control systems. - topics: - email: ruslan.seifullaev@angstrom.uu.se - website: https://www.katalog.uu.se/empinfo/?id=N18-1190 - number_educ: 0 - education1: - education2: - education3: - education4: - -- name: Daniel Arnström - photo: daniel.jpeg - info: Postdoc, started August 2023 - short_bio: Daniel Arnström is a Postdoc at the Division of Systems and Control, Department of Information Technology, Uppsala University, Sweden. He received the Ph.D in automatic control from Linköping University, Sweden, in 2023. Previously, he had received M.Sc and Licentiate degrees from Linköping University in 2018 and 2021, respectively. At the 22nd World Congress of the International Federation of Automatic Control (IFAC) he was awarded the Young Author Prize (YAP) for his work on embedded optimization solvers. His research interests include reliable embedded optimization and reliable real-time Model Predictive Control (MPC); for reliability, his research interests include computational, safety, and security aspects. - topic: - email: daniel.arnstrom@it.uu.se - website: https://darnstrom.github.io/ - number_educ: 0 - education1: - education2: - education3: - education4: - -- name: Alain Govaert - photo: Alain.jpg - info: Postdoc, started September 2023 - short_bio: Alain Govaert is a Postdoctoral researcher at the Division of Systems and Control, Department of Information Technology, Uppsala University, Sweden. He received the M.Sc. degree in Industrial Engineering and the Ph.D. degree in automatic control from the Faculty of Sciences at University of Groningen in the Netherlands in 2015 and 2020, respectively. His research interests include complex systems theory, game theory, random graphs, and control systems. - topic: - email: alain.govaert@it.uu.se - website: https://www.katalog.uu.se/profile/?id=N23-2090 - number_educ: 0 - education1: - education2: - education3: - education4: - -- name: Jingwei Dong - photo: jingwei.jpg - info: Postdoc, started January 2024 - short_bio: Jingwei Dong is a Postdoctoral Researcher at the Division of Systems and Control, Department of Information Technology, Uppsala University, Sweden. He received the M. Eng degree in Control Science and Engineering from Harbin Institute of Technology, China, in 2018, and the Ph.D. degree in Systems and Control from Delft Center for Systems and Control, TU Delft, The Netherlands, in 2023. His research interests include optimization-based fault diagnosis, security of cyber-physical systems, control theory, and optimization methods. - topic: - email: jingwei.dong@it.uu.se - website: https://www.katalog.uu.se/profile/?id=N24-18 - number_educ: 0 - education1: - education2: - education3: - education4: - -- name: Sribalaji C. Anand - photo: Anand1.jpg - info: Ph.D. student, started August 2019 - short_bio: Sribalaji C. Anand is a Ph.D. student specializing in Automatic Control, at the Division of Signals and Systems, Department of Electrical Engineering, Uppsala University, Sweden. He works under the supervision of Dr. André Teixeira and Prof. Anders Ahlén. His research interests include optimization, Security of cyber-physical systems, Adaptive control. He received his M.Sc. degree in systems and control from the Delft Centre for Systems and Control (DCSC), TU Delft, the Netherlands in 2017. From 2016 to 2017, he was a research assistant at the Robotics Research Centre, International Institute of Information Technology (IIIT), Hyderabad, India. He received his Bachelor's degree in Mechatronics from SASTRA University, India. He was the recipient of the Dean's lister merit scholarship award for the years 2012 to 2016. - topics: - email: sribalaji.anand@angstrom.uu.se - website: https://sites.google.com/view/sribalajianand/home - number_educ: 0 - education1: - -- name: Fatih Emre Tosun - photo: emre.jpg - info: Ph.D. student, started October 2019 - short_bio: Fatih Emre Tosun received the B.S. and M.S. degrees in mechatronics engineering from Sabancı University, Istanbul, Turkey, in 2015 and 2019, respectively. He is currently working toward the Ph.D. degree in electrical engineering with Uppsala University, Uppsala, Sweden.,He conducted research in system design and control for physical human–robot interaction and series elastic actuation. His current research interests include secure and resilient control systems. - topics: - email: fatihemre.tosun@angstrom.uu.se - website: https://katalog.uu.se/profile/?id=N19-1870 - number_educ: 0 - education1: - -- name: Anh Tung Nguyen - photo: Tung1.jpg - info: Ph.D. student, started May 2021 - short_bio: Anh Tung Nguyen is a Ph.D. student at the Division of Systems and Control, Department of Information Technology, Uppsala University, Sweden. He was born in 1995, Hanoi city, the capital of Vietnam. He received the Degree of Engineer in Automatic Control (5-year Talent program) from the Department of Automatic Control, School of Electrical Engineering, Hanoi University of Science and Technology, Hanoi, Vietnam in 2018. In 2017, he was selected as Top 10 Young Engineer and Scientist Award granted by the Honda Foundation. He was a visiting student at the WPI International Institute for Carbon-Neutral Energy Research, Kyushu University, Fukuoka, Japan from September to December 2018. From 2019 to 2021, he was a research assistant at the Guidance, Navigation, and Control Laboratory, Sejong University, Seoul, Korea. He received the Degree of Master of Engineering in Aerospace Engineering from the Department of Aerospace Engineering, Sejong University, Seoul, Korea in 2021. His research interests include control theory, multi-agent systems, and cyber-physical security. - topics: - email: anh.tung.nguyen@it.uu.se - website: https://sites.google.com/view/anhtungnguyen - number_educ: 0 - education1: - -- name: Zhenlu Sun - photo: Zhenlu.jpg - info: Ph.D. student, started October 2022 - short_bio: Zhenlu Sun is a Ph.D. student at the Division of Scientific Computing, Department of Information Technology, Uppsala University, Sweden. He received the Bachelor's Degree in Measurement and Control Technology and Instrument from Shanghai Maritime University, Shanghai, China. He received the Master's Degree in Control Science and Engineering from Beijing Institute of Technology, Beijing, China. Zhenlu worked at Intel China for three years, focusing on design and development of cloud computing and edge computing under the 5G telecom context. Before joining Intel, he was a software engineer at Cadence Design Systems from 2017 to 2019, focusing on development of EDA software toolkit. He is conducting research in cybersecurity and machine learning for critical infrastructures under the supervision of Prof. Salman Toor and Prof. André Teixeira. His research interests include security and privacy, distributed computing, machine learning and 5G telecom technologies. - topics: - email: zhenlu.sun@it.uu.se - website: https://www.katalog.uu.se/empinfo/?id=N22-2419 - number_educ: 0 - education1: - -- name: Usama Zafar - photo: Usama.jpg - info: Ph.D. student, started February 2023 - short_bio: Usama Zafar is a Ph.D. student at the Division of Scientific Computing, Department of Information Technology, Uppsala University, Sweden. He received his Bachelor’s Degree in Computer Software Engineering from National University of Sciences and Technology (NUST), Islamabad, Pakistan. He completed his Master’s Degree in Advanced Computing Science from Tsinghua University, Beijing, China. Usama has worked at Netsol Technologies for two years, focusing on research and development of FinTech products. He is currently conducting research in secure federated machine learning under the supervision of Prof. Salman Toor and Prof. André Teixeira. His research interests include distributed computing, security and privacy, distributed and federated machine learning. - topics: - email: usama.zafar@it.uu.se - website: https://www.katalog.uu.se/empinfo/?id=N22-2641 - number_educ: 0 - education1: - -- name: Lovisa Eriksson - photo: lovisa.JPG - info: Ph.D. student, started August 2023 - short_bio: Lovisa Eriksson is a Ph.D. student at the Division of Systems and Control, Department of Information Technology, Uppsala University, Sweden. She works under the supervision of Prof. André Teixiera and Prof. Dave Zachariah. Her research interests include machine learning, security and privacy, and decision theory. She earned her B.S.s degree in Mathematics 2021, and her M.S.s degree in Data Science 2023, both from Uppsala University. - topics: - email: lovisa.eriksson@it.uu.se - website: https://lovisaluna.github.io/ - number_educ: 0 - education1: - - diff --git a/_includes/analytics.html b/_includes/analytics.html deleted file mode 100644 index f2c49551..00000000 --- a/_includes/analytics.html +++ /dev/null @@ -1,10 +0,0 @@ - \ No newline at end of file diff --git a/_includes/footer.html b/_includes/footer.html deleted file mode 100644 index 6e428a59..00000000 --- a/_includes/footer.html +++ /dev/null @@ -1,36 +0,0 @@ - - - - diff --git a/_includes/head.html b/_includes/head.html deleted file mode 100644 index 5ea3e7b5..00000000 --- a/_includes/head.html +++ /dev/null @@ -1,16 +0,0 @@ - - - - - {% if page.title %}{{ page.title | escape }}{% else %}{{ site.title | escape }}{% endif %} - - - - - - -{% if jekyll.environment == 'production' %} -{% include analytics.html %} -{% endif %} - - diff --git a/_includes/header.html b/_includes/header.html deleted file mode 100644 index e8bb43a8..00000000 --- a/_includes/header.html +++ /dev/null @@ -1,31 +0,0 @@ - diff --git a/_includes/news.html b/_includes/news.html deleted file mode 100644 index 1ea05c01..00000000 --- a/_includes/news.html +++ /dev/null @@ -1,11 +0,0 @@ - -
-

News

- -{% for article in site.data.news limit:5 %} -

{{ article.date }}
{{ article.headline | markdownify}}

-{% endfor %} - -

... see all News

- -
diff --git a/_includes/youtubePlayer.html b/_includes/youtubePlayer.html deleted file mode 100644 index 2f3b2c7b..00000000 --- a/_includes/youtubePlayer.html +++ /dev/null @@ -1,11 +0,0 @@ - - -
- -
\ No newline at end of file diff --git a/_layouts/bib.html b/_layouts/bib.html deleted file mode 100644 index 424cfb98..00000000 --- a/_layouts/bib.html +++ /dev/null @@ -1,71 +0,0 @@ ---- ---- - - -{% assign bib_show = true %} - -
- - -
- {{ reference | newline_to_br }} - -
- {% if entry.pdf %}{% endif %} - - {% if entry.url %} {% endif %} - - {% if entry.abstract %} - ABS - {% endif %} - - {% if entry.doi %} {% endif %} - - {% if entry.arxiv %} {% endif %} - - - {% if entry.video %} - VID - {% endif %} - - - {% if bib_show %} - BIB - {% endif %} - - - - - {% if entry.abstract %} -
-
- {{entry.abstract}} -
-
- {% endif %} - - {% if bib_show %} -
-
- {% highlight bibtex %}{{ entry.bibtex | hideCustomBibtex }}{% endhighlight %} -
-
- {% endif %} - - - - - - -
- -
\ No newline at end of file diff --git a/_layouts/bib_backup.html b/_layouts/bib_backup.html deleted file mode 100644 index b8a1bfe5..00000000 --- a/_layouts/bib_backup.html +++ /dev/null @@ -1,118 +0,0 @@ ---- ---- - - - - -{% assign bib_show = true %} - -
- - -
- {{ reference | newline_to_br }} - - - - - -
- {% if entry.pdf %}{% endif %} - - - {% if entry.abstract %} - ABS - {% endif %} - - {% if entry.doi %} {% endif %} - - {% if entry.arxiv %} {% endif %} - - {% if bib_show %} - BIB - {% endif %} - - - - - {% if entry.abstract %} -
-
- {{entry.abstract}} -
-
- {% endif %} - - {% if bib_show %} -
-
- {% highlight bibtex %}{{ entry.bibtex | hideCustomBibtex }}{% endhighlight %} -
-
- {% endif %} - -
- -
\ No newline at end of file diff --git a/_layouts/default.html b/_layouts/default.html deleted file mode 100644 index df89cb68..00000000 --- a/_layouts/default.html +++ /dev/null @@ -1,20 +0,0 @@ - - - - {% include head.html %} - - - - {% include header.html %} - -
-
- {{ content }} -
-
- - {% include footer.html %} - - - - diff --git a/_layouts/gridlay.html b/_layouts/gridlay.html deleted file mode 100644 index 45607940..00000000 --- a/_layouts/gridlay.html +++ /dev/null @@ -1,6 +0,0 @@ ---- -layout: default ---- -
- {{ content }} -
diff --git a/_layouts/gridlay2.html b/_layouts/gridlay2.html deleted file mode 100644 index 30365753..00000000 --- a/_layouts/gridlay2.html +++ /dev/null @@ -1,6 +0,0 @@ ---- -layout: default ---- -
- {{ content }} -
diff --git a/_layouts/homelay.html b/_layouts/homelay.html deleted file mode 100644 index 7430f45d..00000000 --- a/_layouts/homelay.html +++ /dev/null @@ -1,15 +0,0 @@ ---- -layout: default ---- - -
-
- ... -
-

Welcome our website!

- - {{ content }} -
-
- {% include news.html %} -
diff --git a/_layouts/page.html b/_layouts/page.html deleted file mode 100644 index ce233ad7..00000000 --- a/_layouts/page.html +++ /dev/null @@ -1,14 +0,0 @@ ---- -layout: default ---- -
- -
-

{{ page.title }}

-
- -
- {{ content }} -
- -
diff --git a/_layouts/piclay.html b/_layouts/piclay.html deleted file mode 100644 index 3a7ddcaa..00000000 --- a/_layouts/piclay.html +++ /dev/null @@ -1,7 +0,0 @@ ---- -layout: default ---- - -
- {{ content }} -
diff --git a/_layouts/post.html b/_layouts/post.html deleted file mode 100644 index 3a0fb52e..00000000 --- a/_layouts/post.html +++ /dev/null @@ -1,15 +0,0 @@ ---- -layout: default ---- -
- -
-

{{ page.title }}

- -
- -
- {{ content }} -
- -
diff --git a/_layouts/publications.html b/_layouts/publications.html deleted file mode 100644 index 3ec7d87c..00000000 --- a/_layouts/publications.html +++ /dev/null @@ -1,10 +0,0 @@ ---- -title: "Secure Learning and Control Lab - Publications" -layout: default -excerpt: "Secure Learning and Control Lab -- Publications" -sitemap: false -permalink: /publications/ ---- -
- {{ content }} -
\ No newline at end of file diff --git a/_layouts/research.html b/_layouts/research.html deleted file mode 100644 index 1fb65e77..00000000 --- a/_layouts/research.html +++ /dev/null @@ -1,6 +0,0 @@ ---- -layout: default ---- -
- {{ content }} -
diff --git a/_layouts/team.html b/_layouts/team.html deleted file mode 100644 index c17f2cea..00000000 --- a/_layouts/team.html +++ /dev/null @@ -1,7 +0,0 @@ ---- -layout: default ---- -
- {{ content }} -
- diff --git a/_layouts/textlay.html b/_layouts/textlay.html deleted file mode 100644 index a2bbf5e3..00000000 --- a/_layouts/textlay.html +++ /dev/null @@ -1,6 +0,0 @@ ---- -layout: default ---- -
- {{ content }} -
diff --git a/_pages/404.md b/_pages/404.md deleted file mode 100755 index 4dfa4844..00000000 --- a/_pages/404.md +++ /dev/null @@ -1,10 +0,0 @@ ---- -title: "Page Not Found" -layout: default -excerpt: "Page not found. Your pixels are in another canvas." -sitemap: false -permalink: /404.html ---- - -Sorry, but the page you were trying to view does not exist. - diff --git a/_pages/aboutwebsite.md b/_pages/aboutwebsite.md deleted file mode 100644 index 9613ee89..00000000 --- a/_pages/aboutwebsite.md +++ /dev/null @@ -1,48 +0,0 @@ ---- -title: "About the website" -layout: textlay -excerpt: "About the website." -sitemap: false -permalink: /aboutwebsite.html ---- - -# Use this website as a template for your academic research group - -This website is powered by [Jekyll](https://jekyllrb.com) and uses some [Bootstrap](http://www.getbootstrap.com) and [Bootswatch](http://www.bootswatch.com). It was adapted from different sources, primarily [Allan's Lab](https://www.allanlab.org), and refactored to use Jekyll Scholar. - -### Getting started -All pages are written in [markdown](https://github.com/adam-p/markdown-here/wiki/Markdown-Cheatsheet) for easy editing, and [Jekyll](https://jekyllrb.com) uses Liquid for the data-driven pages. The publicaion list, news items, and group members are stored as `.yml` data sheets (plain text) in the `_data folder`, so that one can update the website easily. The pages are in the `_pages` folder. Updating and maintaining is easy using [Github](http://www.github.com) (not worldpress-easy, but there are other advantages (see e.g. [this](https://www.taniarascia.com/make-a-static-website-with-jekyll/), or [this](http://www.webdesignerdepot.com/2015/11/jekyll-against-the-rest-of-the-world/)). [Jekyll](https://jekyllrb.com) takes all the markdown and data files, and creates beautiful `html` files in the `_site` folder. - -If you never used [Jekyll](https://jekyllrb.com), read the [wikipedia article](https://en.wikipedia.org/wiki/Jekyll_(software)) article and check out [their website](https://jekyllrb.com). Same for [Github](http://www.github.com), which will host your first website draft. - -Create and open a github account, go to [our repository](https://github.com/allanlab/allanlab), and click 'fork'. This is now your copy of the website, and you can change and adapt it as you want. You don't have to link to us or mention us (but of course we appreciate it). Then change the name of the repository to "your_username" and the name of the branch to "gh-pages". Your website is now automatically published under *your_username.github.io/your_username/*. Except that it probably still looks like our website. - -To modify the webpage, you can either do everything on on github.com (go to a file, click "edit", then "commit", "push"), or install [Jekyll](https://jekyllrb.com) on your computer and play with your local copy that you sync with the branch on github.com. The former is much easier in the beginning, but a bit less convenient once you start rewriting everythint. To get it to work on your computer (and to learn a bit more about [Jekyll](https://jekyllrb.com)), [here](https://www.taniarascia.com/make-a-static-website-with-jekyll/) and [here](https://scotch.io/tutorials/getting-started-with-jekyll-plus-a-free-bootstrap-3-starter-theme) are tutorials on how to use it and how set it up locally. Also, consider using the [Github desktop app](http://www.desktop.github.com), I found it helpful. - -### Customization -Now let's make this *your* website. - -First, go to the `news.ylm`, `publist.ylm`, and `team.ylm` files in the `_data` folder and insert your own data into the data fields. Watch out: [Jekyll](https://jekyllrb.com) is quite strict about extra or missing spaces etc. Adhere to the format. In the beginning, test each change: commit, push, and check the published website. - -For publications, you can add a "1" in the highlight field, then it will be featured prominently. You can add important news items (red, "news1"), and less important news items (blue, "news2"). - -For the news items, just keep adding them. The first 10 will be displayed on the 'home' page. - -For the `team.ylm` file - -Next, change the content of all files in the `_pages` folder. To change the title in the homepage, go to `homelay.html` in the `_layout` folder. - -Lastly, change the footer and perhaps header appropriately (in `_include`). - -You might also want to change the style or theme. I imported style files (in sass) from Bootstrap/Bootwatch, you can replace them with your own (in the `_sass directory`). For small changes, just work on the override stuff in the `main.sass` file in the `CSS` folder. Or change some variables in the `_variables.sass` file, like the background color etc. - -As said, [Jekyll](https://jekyllrb.com) takes all the markdown and data files, and creates beautiful `html` files in the `_site` folder.In the end, either upload these files to your server, or buy yourself a domain and check the instructions on github on how to host it there. - -### Copyright / credit - -You can use this template as you please. - -Code released under the MIT License. - - - diff --git a/_pages/allnews.md b/_pages/allnews.md deleted file mode 100644 index d65b8959..00000000 --- a/_pages/allnews.md +++ /dev/null @@ -1,16 +0,0 @@ ---- -title: "News" -layout: textlay -excerpt: "Secure Learning and Control Lab at Uppsala University." -sitemap: false -permalink: /allnews.html ---- - -# News - -{% for article in site.data.news %} -{{ article.date }} -{{ article.headline | markdownify}} -
- -{% endfor %} diff --git a/_pages/allprojects.md b/_pages/allprojects.md deleted file mode 100644 index 66958d83..00000000 --- a/_pages/allprojects.md +++ /dev/null @@ -1,62 +0,0 @@ ---- -title: "Projects" -layout: textlay -excerpt: "Secure Learning and Control Lab at Uppsala University." -sitemap: false -permalink: /allprojects.html ---- - -# All projects - -### Ongoing projects - -{% for project in site.data.project %} - -{% if project.ongoing == 1 %} -
-
- -#### {{ project.title }} ({{ project.period}}) - -**Call:** {{project.category}}, *funded by the* {{ project.agency}} - -**Awarded to:** {{project.lead}} - -**USLC Members:** {{project.member}} - - -
-{{ project.summary }} -
-
-
- -{% endif %} - -{% endfor %} - -### Past projects - -{% for project in site.data.project %} - -{% if project.ongoing == 0 %} -
-
- -#### {{ project.title }} ({{ project.period}}) - -**Call:** {{project.category}}, *funded by the* {{ project.agency}} - -**Awarded to:** {{project.lead}} - - -
-{{ project.summary }} -
-
-
-
- -{% endif %} - -{% endfor %} diff --git a/_pages/funding.md b/_pages/funding.md deleted file mode 100644 index f900f8c2..00000000 --- a/_pages/funding.md +++ /dev/null @@ -1,89 +0,0 @@ ---- -title: "Secure Learning and Control Lab - Funding" -layout: textlay -excerpt: "Secure Learning and Control Lab -- Funding." -sitemap: false -permalink: /funding/ ---- - -# Our Funding -We are grateful to the following organizations that generously fund our activities: -- [Uppsala University](http://www.it.uu.se), - - [UU Graduate School in Cybersecurity](http://www.it.uu.se/research/research-arenas/security/graduate_school), an initiative from the Department of Information Technology, -- [Knut and Alice Wallenberg Foundation](https://kaw.wallenberg.org/) ([Wallenberg Academy Fellow](https://kaw.wallenberg.org/en/andre-teixeira)), -- [Swedish Research Council](https://www.vr.se), -- [Swedish Foundation for Strategic Research](https://strategiska.se) ([Future Research Leaders 7](https://strategiska.se/en/research/ongoing-research/framtidens-forskningsledare-7/)), -- [Swedish Energy Agency](https://www.energimyndigheten.se/en/), -- [Sweden's Innovation Agency](https://www.vinnova.se/en/), -- [eSSENCE-SciLife Graduate School in Data-Intensive Science](https://essenceofescience.se/graduate-school/). - -
- -
- - -
- -
- - -
- -
- - -
- -
- -
-
- -
- -
- -
- -
- -
- -
- -
- - -
- -Their funding supports our work in research, education, and outreach, not the least through our scientific projects. - -### Ongoing projects - -{% for project in site.data.project %} - -{% if project.ongoing == 1 %} -
-
- -#### {{ project.title }} ({{ project.period}}) - -**Call:** {{project.category}}, *funded by the* {{ project.agency}} - -**Awarded to:** {{project.lead}} - -**USLC Members:** {{project.member}} - - -
-{{ project.summary }} -
-
-
- -{% endif %} - -{% endfor %} - - -

... see all Projects

diff --git a/_pages/home.md b/_pages/home.md deleted file mode 100644 index e8a8359a..00000000 --- a/_pages/home.md +++ /dev/null @@ -1,82 +0,0 @@ ---- -title: "Phong Lam - Home" -layout: homelay -excerpt: "Phong Lam" -sitemap: false -permalink: / ---- - -### Vision -Our vision is to develop methodologies for designing intelligent autonomous decision-making systems that are secure and resilient against malicious adversaries and natural failures. - - - - -### Research -Our research incorporates elements from cybersecurity, control theory, optimization and machine learning, reinforcement learning, game-theory and networked / distributed systems. You can find an overview of some of our research themes at our [Research page](research). - - -### Scientific environment -We are a dynamic research group at the [Department of Information Technology, Uppsala University](http://www.it.uu.se), Sweden. We exchange ideas and work with our colleagues from the several of the Department's research areas, namely [Cybersecurity](https://www.it.uu.se/research/cybersecurity), [AI](https://www.it.uu.se/research/artificial-intelligence), [Data Science](https://www.it.uu.se/research/data-science), and [Control Systems](https://www.it.uu.se/research/control-and-dynamical-systems). We also have ongoing collaborations with our neighboring Department of Electrical Engineering. We are driving local research initiatives related to cybersecurity, through the [Graduate School in Cybersecurity](http://www.it.uu.se/research/research-arenas/security/graduate_school) and the [Cybersecurity Arena](http://www.it.uu.se/research/research-arenas/security). - - **We are looking for driven new PhD students, Postdocs, and Master students to join the team** [(more info)]({{ site.url }}{{ site.baseurl }}/openings) **!** - - -### Our support -We are grateful for the early-career funding from [Uppsala University](http://www.it.uu.se), the [Knut and Alice Wallenberg Foundation](https://kaw.wallenberg.org/) ([Wallenberg Academy Fellow](https://kaw.wallenberg.org/en/andre-teixeira)), the [Swedish Research Council](https://www.vr.se) ([Starting Grant](https://www.vr.se/english/applying-for-funding/calls/2018-03-07-starting-grant-within-natural-and-engineering-sciences.html)), and the [Swedish Foundation for Strategic Research](https://strategiska.se) ([Future Research Leaders Grant](https://strategiska.se/en/research/ongoing-research/framtidens-forskningsledare-7/)). - -
- -
- - -
- -
- - -
- -
- - -
- -
- - -
- -
- -See our funding and ongoing projects at our [Funding page](funding). - - diff --git a/_pages/openings.md b/_pages/openings.md deleted file mode 100644 index 7094cd30..00000000 --- a/_pages/openings.md +++ /dev/null @@ -1,62 +0,0 @@ ---- -title: "Secure Learning and Control Lab - Vacancies" -layout: textlay -excerpt: "Openings" -sitemap: false -permalink: /openings ---- - -# Open positions -[//]: # (**At the moment, we do not have any open positions. We do plan to PhD positions in late 2023 and early 2024 for our recently awarded projects.**) - -**At the moment, we have the following positions open:** -* **Deadline March 25, 2024:** [1 PhD position in Automatic Control focusing on probabilistic methods for secure control](https://www.jobb.uu.se/details/?positionId=697970&languageId=1). -* **Deadline March 28, 2024:** [1 PhD position in Automatic Control focusing on data-driven methods](https://www.jobb.uu.se/details/?positionId=701901&languageId=1). -* **Deadline April 18, 2024:** [1 Postdoc position in Machine Learning focusing on secure federated learning](https://uu.varbi.com/what:job/jobID:707876/). - -[//]: # (**We do plan to PhD positions in late 2023 and early 2024 for our recently awarded projects, so stay tuned!**) - -[//]: # ( **Deadline January 30, 2024:** [1 PhD position in Automatic Control focusing on Distributed Voltage Control](https://uu.varbi.com/en/what:job/jobID:680621/). ) -[//]: # (**Deadline August 21:** [1 PhD position in Automatic Control focusing on Secure Control](https://www.jobb.uu.se/details/?positionId=637356).) - - - - - -[//]: # (Our vision is to develop methodologies for designing intelligent autonomous decision-making systems that are secure and resilient against malicious adversaries.) - -We are always looking for new group members with passion, talent, and grit! - -You will have the chance to work on basic and applied research at the intersection of cybersecurity, control theory, and machine learning. - -You will take an acive role in determining the important and interesting research questions to tackle, creating novel scientific methodologies and tailoring them for specific practical applications, developing new adversary models and defense mechanisms, and evaluating the proposed methods on experimental setups. - - -**Note: Sometimes we do not have funding for additional PhD and postdoc positions. In those periods, we can only welcome you if you have a fellowship. We would be happy to support you after you apply to our group. Take a look at the [VR International Postdoc grant](https://www.vr.se/english/applying-for-funding/calls/2021-11-17-international-post-doc-grant-within-natural-and-engineering-sciences-spring-call.html) or the [Marie Curie Postdoc fellowship](https://marie-sklodowska-curie-actions.ec.europa.eu/actions/postdoctoral-fellowships).** - - -### Past open positions - -You find some of the past job openings here: -* [PhD position in Automatic Control focusing on Secure Control Systems]({{ site.baseurl }}/assets/vacancies/PhD_SSF_2023.pdf), -* [Postdoc positions in Secure Learning and Control]({{ site.baseurl }}/assets/vacancies/PD_SSF_VR_2022.pdf), -* [PhD in Scientific Computing with focus on Cybersecurity and Machine Learning for Critical Infrastructures]({{ site.baseurl }}/assets/vacancies/PhD_essence_2022.pdf). - -### Applications for PhD and Postdoc positions -Applications for fully-funded PhD or Postdoc positions can only be done for a specific advertisement and through the [official application portal](https://uu.varbi.com/). All positions at Uppsala University are advertised at the [university website](https://www.uu.se/en/about-uu/join-us/jobs/). - -Other types of PhD and Postdoc positions may also be possible, for instance through the applicant's own fellowship or scholarship. If you are interested in working with us as a PhD student or postdoc, please send an [email](mailto:andre.teixeira@it.uu.se). State briefly why you are interested and attach a CV, including information about the grades you had as an undergraduate. - - -### Master and Bachelor projects for Uppsala University students -If you are a Master or Bachelor student at Uppsala University looking for a degree project, contact me (or any group member) per email or drop by my office. - -At the moment, we have several proposals for MSc thesis projects at our group, candidates are interviewed continuously **until early December 2023**. See [the list and details](https://tinyurl.com/MSc2024-SysCon) for how to apply! - -### Master students from elsewhere -If you are interested in pursuing a Master degree at Uppsala University, see [the University's website](https://www.uu.se/en/admissions/master/). We may take external master students for a degree project or a short stay on their own funding, if we get exceptional applicants (this usually means very good grades and a personal recommendation). - - -
- -
diff --git a/_pages/publications.md b/_pages/publications.md deleted file mode 100644 index 5b7520ed..00000000 --- a/_pages/publications.md +++ /dev/null @@ -1,93 +0,0 @@ ---- -title: "Secure Learning and Control Lab - Publications" -layout: gridlay -excerpt: "Secure Learning and Control Lab -- Publications." -sitemap: false -years: [2024, 2023, 2022, 2021, 2020, 2019, 2018, 2017, 2016, 2015, 2014, 2013, 2012, 2011, 2010] -permalink: /publications/ ---- - - -# Publications - - -(See also the personal webpage of our group members) - - -## Group highlights - -(For a full list of publications, see [below](#list-of-publications), and see also the personal webpage of our group members) - - -{% assign number_printed = 0 %} -{% for publi in site.data.publist %} - -{% assign even_odd = number_printed | modulo: 2 %} -{% if publi.highlight == 1 %} - -{% if even_odd == 0 %} -
-{% endif %} - -{% if publi.long == 1 %} -
-
- {{ publi.title }} - -

{{ publi.description }}

-

{{ publi.authors }}

-

{{ publi.link.display }}

-

{{ publi.news1 }}

-

{{ publi.news2 }}

-
-
-{% else %} -
-
- {{ publi.title }} - -

{{ publi.description }}

-

{{ publi.authors }}

-

{{ publi.link.display }}

-

{{ publi.news1 }}

-

{{ publi.news2 }}

-
-
- -{% assign number_printed = number_printed | plus: 1 %} - -{% if even_odd == 1 %} -
-{% endif %} - -{% endif %} - -{% endif %} -{% endfor %} - -{% assign even_odd = number_printed | modulo: 2 %} -{% if even_odd == 1 %} - -{% endif %} - -

 

- - -## List of Publications - -### Under Review -
- -{% bibliography -f uscl_publications -q @*[published={{0}}]* %} - -
- -### Published -
- -{%- for y in page.years %} -

{{y}}

- {% bibliography -f uscl_publications -q @*[year={{y}}]* %} -{% endfor %} - -
diff --git a/_pages/research.md b/_pages/research.md deleted file mode 100644 index 10ff4dcb..00000000 --- a/_pages/research.md +++ /dev/null @@ -1,103 +0,0 @@ ---- -title: "Secure Learning and Control Lab - Research" -layout: gridlay2 -excerpt: "Secure Learning and Control Lab -- Research" -sitemap: false -tags: [10001, 10002,10003, 10004, 10005, 10006] -permalink: /research/ ---- - -# Our Research - - -Our vision is to develop methodologies for designing intelligent autonomous decision-making systems that are secure and resilient against malicious adversaries and natural failures. - -To do so, we look into these sytems from a security perspective, under various adversary models. Specifically, we develop techniques to assess the risk (i.e., impact and likelihood) of adversaries and failures, and propose methodologies to design and systematically deploy defense measures to prevent, detect, and mitigate malicious attacks and natural disruptive events. In our research, we combine methodologies from cybersecurity, control theory, optimization and machine learning, game-theory and networked systems. - -[//]: # (For a high-level summary of a selection of our results, see [Research Results](research_results).) - -Have a look at a popular science video about our research on developing secure control systems. You can also find some of our recent research themes described at the end of this page. - -## Popular science video -{% include youtubePlayer.html id="k01OGxClLXE?si=Awnl9VCWb7bxCm_F" %} - - - - - -## Selected research themes -{% assign paper_show = true %} - - -{% assign number_printed = 0 %} -{% for theme-item in site.data.research_themes %} - -{% assign even_odd = number_printed | modulo: 2 %} -{% if theme-item.highlight == 1 %} - -{% if even_odd == 0 %} -
-{% endif %} -{% if theme-item.long == 1 %} -
-
- {% if theme-item.hasimage == 1 %} - - {% endif %} -

{{ theme-item.title }}

-

{{ theme-item.description }}

-

Team members: {{ theme-item.authors }}

-

{{ theme-item.news1 }}

-

{{ theme-item.news2 }}

- -
-{%- for y in page.tags %} -{%- if y == theme-item.tag -%} -{% bibliography -f uscl_publications -q @*[tag={{y}}]* %} -{% endif %} -{% endfor %} -
-
-
-
-{% else %} -
-
- {% if theme-item.hasimage == 1 %} - - {% endif %} -

{{ theme-item.title }}

- {{ theme-item.description }} -

Team members: {{ theme-item.authors }}

-

{{ theme-item.news1 }}

-

{{ theme-item.news2 }}

- -
-{%- for y in page.tags %} -{%- if y == theme-item.tag or y == theme-item.taga -%} -{% bibliography -f uscl_publications -q @*[tag={{y}} || taga={{y}}]]* %} -{% endif %} -{% endfor %} -
-
-
-{% assign number_printed = number_printed | plus: 1 %} -{% if even_odd == 1 %} - -{% endif %} - -{% endif %} -{% endif %} -{% endfor %} - -{% assign even_odd = number_printed | modulo: 2 %} -{% if even_odd == 1 %} - -{% endif %} - -

 

- - -[//]: # (**Watermarking schemes for attack detection:**) - -### ... and more. diff --git a/_pages/research_results.md b/_pages/research_results.md deleted file mode 100644 index 2cb43696..00000000 --- a/_pages/research_results.md +++ /dev/null @@ -1,87 +0,0 @@ ---- -title: "Secure Learning and Control Lab - Publications" -layout: gridlay2 -excerpt: "Secure Learning and Control Lab -- Publications." -sitemap: false -tags: [10001, 10002, 10003, 10004, 10005, 10006] -permalink: /research/research_results/ ---- - - -# Research themes - - -(See also the personal webpage of our group members) - - -## Here are our main themes -{% assign paper_show = true %} - - -{% assign number_printed = 0 %} -{% for theme-item in site.data.research_themes %} - -{% assign even_odd = number_printed | modulo: 2 %} -{% if theme-item.highlight == 1 %} - -{% if even_odd == 0 %} -
-{% endif %} -{% if theme-item.long == 1 %} -
-
- {% if theme-item.hasimage == 1 %} - - {% endif %} -

{{ theme-item.title }}

-

{{ theme-item.description }}

-

Team members: {{ theme-item.authors }}

-

{{ theme-item.news1 }}

-

{{ theme-item.news2 }}

- -
-{%- for y in page.tags %} -{%- if y == theme-item.tag -%} -{% bibliography -f uscl_publications -q @*[tag={{y}}]* %} -{% endif %} -{% endfor %} -
-
-
-
-{% else %} -
-
- {% if theme-item.hasimage == 1 %} - - {% endif %} -

{{ theme-item.title }}

- {{ theme-item.description }} -

Team members: {{ theme-item.authors }}

-

{{ theme-item.news1 }}

-

{{ theme-item.news2 }}

- -
-{%- for y in page.tags %} -{%- if y == theme-item.tag -%} -{% bibliography -f uscl_publications -q @*[tag={{y}}]* %} -{% endif %} -{% endfor %} -
-
-
-{% assign number_printed = number_printed | plus: 1 %} -{% if even_odd == 1 %} - -{% endif %} - -{% endif %} -{% endif %} -{% endfor %} - -{% assign even_odd = number_printed | modulo: 2 %} -{% if even_odd == 1 %} - -{% endif %} - -

 

diff --git a/_pages/team.md b/_pages/team.md deleted file mode 100644 index 708960b2..00000000 --- a/_pages/team.md +++ /dev/null @@ -1,193 +0,0 @@ ---- -title: "Secure Learning and Control Lab - Team" -layout: gridlay -excerpt: "Team members" -sitemap: false -permalink: /team/ ---- - - - -# Group Members - - **We are looking for new PhD students, Postdocs, and Master students to join the team** [(see openings)]({{ site.url }}{{ site.baseurl }}/openings) **!** - - -Jump to [staff](#staff), [master and bachelor students](#master-and-bachelor-students). -{::comment} -, [alumni](#alumni), [lab visitors](#lab-visitors). -{:/comment} - - -## Staff -{% for member in site.data.team_members %} - -
- -
- - -
-

{{ member.name }}

- {{ member.info }} - -

{{ member.short_bio }}

-
- -

- - -
- -
- - -{% endfor %} - - - -## Master and Bachelor Students -{% assign number_printed = 0 %} -{% for member in site.data.students %} - -{% assign even_odd = number_printed | modulo: 2 %} - -{% if even_odd == 0 %} -
-{% endif %} - -
-

{{ member.name }}

- {{ member.info }} -
    - - {% if member.number_educ == 1 %} -
  • {{ member.education1 }}
  • - {% endif %} - - {% if member.number_educ == 2 %} -
  • {{ member.education1 }}
  • -
  • {{ member.education2 }}
  • - {% endif %} - - {% if member.number_educ == 3 %} -
  • {{ member.education1 }}
  • -
  • {{ member.education2 }}
  • -
  • {{ member.education3 }}
  • - {% endif %} - - {% if member.number_educ == 4 %} -
  • {{ member.education1 }}
  • -
  • {{ member.education2 }}
  • -
  • {{ member.education3 }}
  • -
  • {{ member.education4 }}
  • - {% endif %} - -
-
- -{% assign number_printed = number_printed | plus: 1 %} - -{% if even_odd == 1 %} -
-{% endif %} - -{% endfor %} - -{% assign even_odd = number_printed | modulo: 2 %} -{% if even_odd == 1 %} - -{% endif %} - - -## Alumni - -{% assign number_printed = 0 %} -{% for member in site.data.alumni_members %} - -{% assign even_odd = number_printed | modulo: 2 %} - -{% if even_odd == 0 %} -
-{% endif %} - -
- -

{{ member.name }}

- {{ member.duration }}
Role: {{ member.position }}

({{ member.info_current }})
ORCID: [{{member.ORCID}}](https://orcid.org/{{member.ORCID}}) -
    - -
-
- -{% assign number_printed = number_printed | plus: 1 %} - -{% if even_odd == 1 %} -
-{% endif %} - -{% endfor %} - -{% assign even_odd = number_printed | modulo: 2 %} -{% if even_odd == 1 %} - -{% endif %} - - -## Former visitors, BSc/MSc students -
- -{::comment} -
-

Visitors

-{% for member in site.data.alumni_visitors %} -{{ member.name }} -{% endfor %} -
-{:/comment} - - -
-

Master students

-{% for member in site.data.alumni_msc %} -{{ member.name }} -{{ member.info }} -{% endfor %} -
- -{::comment} -
-

Bachelor Students

-{% for member in site.data.alumni_bsc %} -{{ member.name }} -{% endfor %} -
-{:/comment} - -
- diff --git a/_plugins/hideCustomBibtex.rb b/_plugins/hideCustomBibtex.rb deleted file mode 100644 index 6af93ae9..00000000 --- a/_plugins/hideCustomBibtex.rb +++ /dev/null @@ -1,15 +0,0 @@ - module Jekyll - module HideCustomBibtex - def hideCustomBibtex(input) - keywords = @context.registers[:site].config['filtered_bibtex_keywords'] - - keywords.each do |keyword| - input = input.gsub(/^.*#{keyword}.*$\n/, '') - end - - return input - end - end -end - -Liquid::Template.register_filter(Jekyll::HideCustomBibtex) \ No newline at end of file diff --git a/_plugins/markdown.rb b/_plugins/markdown.rb deleted file mode 100644 index 727bf402..00000000 --- a/_plugins/markdown.rb +++ /dev/null @@ -1,23 +0,0 @@ -=begin - Jekyll tag to include Markdown text from _includes directory preprocessing with Liquid. - Usage: - {% markdown %} - Dependency: - - kramdown -=end -module Jekyll - class MarkdownTag < Liquid::Tag - def initialize(tag_name, text, tokens) - super - @text = text.strip - end - require "kramdown" - def render(context) - tmpl = File.read File.join Dir.pwd, "_includes", @text - site = context.registers[:site] - tmpl = (Liquid::Template.parse tmpl).render site.site_payload - html = Kramdown::Document.new(tmpl).to_html - end - end -end -Liquid::Template.register_tag('markdown', Jekyll::MarkdownTag) diff --git a/_sass/_bootstrap.scss b/_sass/_bootstrap.scss deleted file mode 100644 index 9babefd5..00000000 --- a/_sass/_bootstrap.scss +++ /dev/null @@ -1,58 +0,0 @@ -/*! - * Bootstrap v3.3.7 (http://getbootstrap.com) - * Copyright 2011-2016 Twitter, Inc. - * Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE) - */ - -// Core variables and mixins -@import "bootstrap/variables"; -@import "bootstrap/mixins"; - -// Reset and dependencies -@import "bootstrap/normalize"; -@import "bootstrap/print"; -@import "bootstrap/glyphicons"; - -// Core CSS -@import "bootstrap/scaffolding"; -@import "bootstrap/type"; -@import "bootstrap/code"; -@import "bootstrap/grid"; -@import "bootstrap/tables"; -@import "bootstrap/forms"; -@import "bootstrap/buttons"; - -// Components -@import "bootstrap/component-animations"; -@import "bootstrap/dropdowns"; -@import "bootstrap/button-groups"; -@import "bootstrap/input-groups"; -@import "bootstrap/navs"; -@import "bootstrap/navbar"; -@import "bootstrap/breadcrumbs"; -@import "bootstrap/pagination"; -@import "bootstrap/pager"; -@import "bootstrap/labels"; -@import "bootstrap/badges"; -@import "bootstrap/jumbotron"; -@import "bootstrap/thumbnails"; -@import "bootstrap/alerts"; -@import "bootstrap/progress-bars"; -@import "bootstrap/media"; -@import "bootstrap/list-group"; -@import "bootstrap/panels"; -@import "bootstrap/responsive-embed"; -@import "bootstrap/wells"; -@import "bootstrap/close"; - -// Components w/ JavaScript -@import "bootstrap/modals"; -@import "bootstrap/tooltip"; -@import "bootstrap/popovers"; -@import "bootstrap/carousel"; - -// Utility classes -@import "bootstrap/utilities"; -@import "bootstrap/responsive-utilities"; -@import "bootstrap/bootswatch"; - diff --git a/_sass/_publications.scss b/_sass/_publications.scss deleted file mode 100644 index e152eb11..00000000 --- a/_sass/_publications.scss +++ /dev/null @@ -1,133 +0,0 @@ -/******************************************************************************* - * Styles for the base elements of the theme. - ******************************************************************************/ - -// Typography - -blockquote { - background: var(--global-bg-color); - border-left: 2px solid var(--global-theme-color); - margin: 1.5em 10px; - padding: 0.5em 10px; - font-size: 1.2rem; -} - -// Math - -.equation { - margin-bottom: 1rem; - text-align: center; -} - -// Caption - -.caption { - font-size: 0.875rem; - margin-top: 0.75rem; - margin-bottom: 1.5rem; - text-align: center; -} - - -// Citation - -.citation, .citation-number { - color: var(--global-theme-color); -} - - - -// Publications -.citation strong { - display: block; -} -.publications { - margin-top: 2rem; - h1 { - color: var(--global-theme-color); - font-size: 2rem; - text-align: center; - margin-top: 1em; - margin-bottom: 1em; - } - h2 { - margin-bottom: 1rem; - span { - font-size: 1.5rem; - } - } - h2.year { - color: var(--global-divider-color); - border-top: 1px solid var(--global-divider-color); - padding-top: 1rem; - margin-top: 2rem; - margin-bottom: -2rem; - text-align: right; - } - ol.bibliography { - list-style: none; - padding: 0; - margin-top: 0; - - li { - margin-bottom: 1rem; - .abbr { - height: 2rem; - margin-bottom: 0.5rem; - abbr { - display: inline-block; - background-color: var(--global-theme-color); - padding-left: 1rem; - padding-right: 1rem; - a { - color: white; - &:hover { - text-decoration: none; - } - } - } - .award { - color: var(--global-theme-color) !important; - border: 1px solid var(--global-theme-color); - } - } - .title { - font-weight: bolder; - } - .author { - a { - border-bottom: 1px dashed var(--global-theme-color); - &:hover { - border-bottom-style: solid; - text-decoration: none; - } - } - > em { - border-bottom: 1px solid; - font-style: normal; - } - } - - p { - line-height: 1.4em; - margin: 10px; - } - pre { - font-size: 1em; - line-height: 1.4em; - padding: 10px; - } - - - } - } -} - -// Transitioning Themes -html.transition, -html.transition *, -html.transition *:before, -html.transition *:after { - transition: all 750ms !important; - transition-delay: 0 !important; -} \ No newline at end of file diff --git a/_sass/_themes.scss b/_sass/_themes.scss deleted file mode 100644 index d817345a..00000000 --- a/_sass/_themes.scss +++ /dev/null @@ -1,65 +0,0 @@ -/******************************************************************************* - * Themes - ******************************************************************************/ - -:root { - --global-bg-color: #{$white-color}; - --global-code-bg-color: #{$code-bg-color-light}; - --global-text-color: #{$black-color}; - --global-text-color-light: #{$grey-color}; - --global-theme-color: #{$purple-color}; - --global-hover-color: #{$purple-color}; - --global-footer-bg-color: #{$grey-color-dark}; - --global-footer-text-color: #{$grey-color-light}; - --global-footer-link-color: #{$white-color}; - --global-distill-app-color: #{$grey-color}; - --global-divider-color: rgba(0,0,0,.1); - --global-card-bg-color: #{$white-color}; - - .fa-sun { - display : none; - } - .fa-moon { - padding-left: 10px; - padding-top: 12px; - display : block; - } - - .repo-img-light { - display: block; - } - .repo-img-dark { - display: none; - } -} - -html[data-theme='dark'] { - --global-bg-color: #{$grey-color-dark}; - --global-code-bg-color: #{$code-bg-color-dark}; - --global-text-color: #{$grey-color-light}; - --global-text-color-light: #{$grey-color-light}; - --global-theme-color: #{$cyan-color}; - --global-hover-color: #{$cyan-color}; - --global-footer-bg-color: #{$grey-color-light}; - --global-footer-text-color: #{$grey-color-dark}; - --global-footer-link-color: #{$black-color}; - --global-distill-app-color: #{$grey-color-light}; - --global-divider-color: #424246; - --global-card-bg-color: #{$grey-900}; - - .fa-sun { - padding-left: 10px; - padding-top: 12px; - display : block; - } - .fa-moon { - display : none; - } - - .repo-img-light { - display: none; - } - .repo-img-dark { - display: block; - } -} \ No newline at end of file diff --git a/_sass/_variables.scss b/_sass/_variables.scss deleted file mode 100644 index e3fdecc4..00000000 --- a/_sass/_variables.scss +++ /dev/null @@ -1,38 +0,0 @@ -/******************************************************************************* - * Variables used throughout the theme. - * To adjust anything, simply edit the variables below and rebuild the theme. - ******************************************************************************/ - - -// Colors -$red-color: #FF3636 !default; -$red-color-dark: #B71C1C !default; -$orange-color: #F29105 !default; -$blue-color: #0076df !default; -$blue-color-dark: #00369f !default; -$cyan-color: #2698BA !default; -$light-cyan-color: lighten($cyan-color, 25%); -$green-color: #00ab37 !default; -$green-color-lime: #B7D12A !default; -$green-color-dark: #009f06 !default; -$green-color-light: #ddffdd !default; -$green-color-bright: #11D68B !default; -$purple-color: #B509AC !default; -$light-purple-color: lighten($purple-color, 25%); -$pink-color: #f92080 !default; -$pink-color-light: #ffdddd !default; -$yellow-color: #efcc00 !default; - -$grey-color: #828282 !default; -$grey-color-light: lighten($grey-color, 40%); -$grey-color-dark: #1C1C1D; -$grey-900: #212529; - -$white-color: #ffffff !default; -$black-color: #000000 !default; - - -// Theme colors - -$code-bg-color-light: rgba($purple-color, 0.05); -$code-bg-color-dark: #2c3237 !default; \ No newline at end of file diff --git a/_sass/bootstrap/_alerts.scss b/_sass/bootstrap/_alerts.scss deleted file mode 100644 index 7d1e1fdd..00000000 --- a/_sass/bootstrap/_alerts.scss +++ /dev/null @@ -1,73 +0,0 @@ -// -// Alerts -// -------------------------------------------------- - - -// Base styles -// ------------------------- - -.alert { - padding: $alert-padding; - margin-bottom: $line-height-computed; - border: 1px solid transparent; - border-radius: $alert-border-radius; - - // Headings for larger alerts - h4 { - margin-top: 0; - // Specified for the h4 to prevent conflicts of changing $headings-color - color: inherit; - } - - // Provide class for links that match alerts - .alert-link { - font-weight: $alert-link-font-weight; - } - - // Improve alignment and spacing of inner content - > p, - > ul { - margin-bottom: 0; - } - - > p + p { - margin-top: 5px; - } -} - -// Dismissible alerts -// -// Expand the right padding and account for the close button's positioning. - -.alert-dismissable, // The misspelled .alert-dismissable was deprecated in 3.2.0. -.alert-dismissible { - padding-right: ($alert-padding + 20); - - // Adjust close link position - .close { - position: relative; - top: -2px; - right: -21px; - color: inherit; - } -} - -// Alternate styles -// -// Generate contextual modifier classes for colorizing the alert. - -.alert-success { - @include alert-variant($alert-success-bg, $alert-success-border, $alert-success-text); -} - -.alert-info { - @include alert-variant($alert-info-bg, $alert-info-border, $alert-info-text); -} - -.alert-warning { - @include alert-variant($alert-warning-bg, $alert-warning-border, $alert-warning-text); -} - -.alert-danger { - @include alert-variant($alert-danger-bg, $alert-danger-border, $alert-danger-text); -} diff --git a/_sass/bootstrap/_badges.scss b/_sass/bootstrap/_badges.scss deleted file mode 100644 index 70002e08..00000000 --- a/_sass/bootstrap/_badges.scss +++ /dev/null @@ -1,68 +0,0 @@ -// -// Badges -// -------------------------------------------------- - - -// Base class -.badge { - display: inline-block; - min-width: 10px; - padding: 3px 7px; - font-size: $font-size-small; - font-weight: $badge-font-weight; - color: $badge-color; - line-height: $badge-line-height; - vertical-align: middle; - white-space: nowrap; - text-align: center; - background-color: $badge-bg; - border-radius: $badge-border-radius; - - // Empty badges collapse automatically (not available in IE8) - &:empty { - display: none; - } - - // Quick fix for badges in buttons - .btn & { - position: relative; - top: -1px; - } - - .btn-xs &, - .btn-group-xs > .btn & { - top: 0; - padding: 1px 5px; - } - - // [converter] extracted a& to a.badge - - // Account for badges in navs - .list-group-item.active > &, - .nav-pills > .active > a > & { - color: $badge-active-color; - background-color: $badge-active-bg; - } - - .list-group-item > & { - float: right; - } - - .list-group-item > & + & { - margin-right: 5px; - } - - .nav-pills > li > a > & { - margin-left: 3px; - } -} - -// Hover state, but only for links -a.badge { - &:hover, - &:focus { - color: $badge-link-hover-color; - text-decoration: none; - cursor: pointer; - } -} diff --git a/_sass/bootstrap/_bootswatch.scss b/_sass/bootstrap/_bootswatch.scss deleted file mode 100644 index 2d35f522..00000000 --- a/_sass/bootstrap/_bootswatch.scss +++ /dev/null @@ -1,523 +0,0 @@ -// Lumen 3.3.7 -// Bootswatch -// ----------------------------------------------------- - -$web-font-path: "https://fonts.googleapis.com/css?family=Source+Sans+Pro:300,400,700,400italic" !default; -@import url($web-font-path); - -@mixin shadow($width: 4px){ - border-width: 0 1px $width 1px; -} - -// Navbar ===================================================================== - -.navbar { - @include shadow(); -} - -// Buttons ==================================================================== - -.btn { - padding: ($padding-base-vertical + 2) $padding-base-horizontal $padding-base-vertical; - @include shadow(); - font-size: 12px; - font-weight: bold; - text-transform: uppercase; - - &:hover { - margin-top: 1px; - border-bottom-width: 3px; - } - - &:active { - margin-top: 2px; - border-bottom-width: 2px; - @include box-shadow(none); - } - - &-lg, - &-group-lg > .btn { - padding: ($padding-large-vertical + 2) $padding-large-horizontal $padding-large-vertical; - line-height: 15px; - } - - &-sm, - &-group-sm > .btn { - padding: ($padding-small-vertical + 2) $padding-small-horizontal $padding-small-vertical; - } - - &-xs, - &-group-xs > .btn { - padding: ($padding-xs-vertical + 2) $padding-xs-horizontal $padding-xs-vertical; - } - - &-default:hover, - &-default:focus, - &-group.open .dropdown-toggle.btn-default { - background-color: $btn-default-bg; - border-color: $btn-default-border; - } - - &-primary:hover, - &-primary:focus, - &-group.open .dropdown-toggle.btn-primary { - background-color: $btn-primary-bg; - border-color: $btn-primary-border; - } - - &-success:hover, - &-success:focus, - &-group.open .dropdown-toggle.btn-success { - background-color: $btn-success-bg; - border-color: $btn-success-border; - } - - &-info:hover, - &-info:focus, - &-group.open .dropdown-toggle.btn-info { - background-color: $btn-info-bg; - border-color: $btn-info-border; - } - - &-warning:hover, - &-warning:focus, - &-group.open .dropdown-toggle.btn-warning { - background-color: $btn-warning-bg; - border-color: $btn-warning-border; - } - - &-danger:hover, - &-danger:focus, - &-group.open .dropdown-toggle.btn-danger { - background-color: $btn-danger-bg; - border-color: $btn-danger-border; - } - - &-group.open .dropdown-toggle { - @include box-shadow(none); - } -} - -.navbar-btn { - &:hover { - margin-top: 8px - } - - &:active { - margin-top: 9px - } - - &.btn-sm { - &:hover { - margin-top: 11px - } - - &:active { - margin-top: 12px - } - } - - &.btn-xs { - &:hover { - margin-top: 15px - } - - &:active { - margin-top: 16px - } - } -} - -.btn-group-vertical { - .btn + .btn { - &:hover { - border-top-width: 1px; - } - - &:active { - border-top-width: 2px; - } - } -} - -// Typography ================================================================= - -.text-primary, -.text-primary:hover { - color: $brand-primary; -} - -.text-success, -.text-success:hover { - color: $brand-success; -} - -.text-danger, -.text-danger:hover { - color: $brand-danger; -} - -.text-warning, -.text-warning:hover { - color: $brand-warning; -} - -.text-info, -.text-info:hover { - color: $brand-info; -} - -// Tables ===================================================================== - -table, -.table { - - a:not(.btn) { - text-decoration: underline; - } - - .dropdown-menu a { - text-decoration: none; - } - - .success, - .warning, - .danger, - .info { - color: #fff; - - a:not(.btn) { - color: #fff; - } - } - - &:not(.table-bordered) { - > thead > tr > th, - > tbody > tr > th, - > tfoot > tr > th, - > thead > tr > td, - > tbody > tr > td, - > tfoot > tr > td { - border-color: transparent; - } - } -} - -// Forms ====================================================================== - -.form-control { - @include box-shadow(inset 0 2px 0 rgba(0, 0, 0, 0.075)); -} - -label { - font-weight: normal; -} - -.has-warning { - .help-block, - .control-label, - .radio, - .checkbox, - .radio-inline, - .checkbox-inline, - &.radio label, - &.checkbox label, - &.radio-inline label, - &.checkbox-inline label, - .form-control-feedback { - color: $brand-warning; - } - - .form-control, - .form-control:focus { - border: 1px solid $brand-warning; - @include box-shadow(inset 0 2px 0 rgba(0, 0, 0, 0.075)); - } - - .input-group-addon { - border: 1px solid $brand-warning; - } -} - -.has-error { - .help-block, - .control-label, - .radio, - .checkbox, - .radio-inline, - .checkbox-inline, - &.radio label, - &.checkbox label, - &.radio-inline label, - &.checkbox-inline label, - .form-control-feedback { - color: $brand-danger; - } - - .form-control, - .form-control:focus { - border: 1px solid $brand-danger; - @include box-shadow(inset 0 2px 0 rgba(0, 0, 0, 0.075)); - } - - .input-group-addon { - border: 1px solid $brand-danger; - } -} - -.has-success { - .help-block, - .control-label, - .radio, - .checkbox, - .radio-inline, - .checkbox-inline, - &.radio label, - &.checkbox label, - &.radio-inline label, - &.checkbox-inline label, - .form-control-feedback { - color: $brand-success; - } - - .form-control, - .form-control:focus { - border: 1px solid $brand-success; - @include box-shadow(inset 0 2px 0 rgba(0, 0, 0, 0.075)); - } - - .input-group-addon { - border: 1px solid $brand-success; - } -} - -// Navs ======================================================================= - -.nav { - .open > a, - .open > a:hover, - .open > a:focus { - border-color: transparent; - } -} - -.nav-tabs { - - > li > a { - margin-top: 6px; - border-color: $navbar-default-border; - color: $gray-dark; - @include transition(all 0.2s ease-in-out); - } - - > li > a:hover, - > li > a:focus, - > li.active > a, - > li.active > a:hover, - > li.active > a:focus, - .open > a, - .open > a:hover, - .open > a:focus { - padding-bottom: ($padding-large-vertical + 3); - margin-top: 0; - } - - .open > a, - .open > a:hover, - .open > a:focus { - border-color: $navbar-default-border; - } - - > li.disabled > a:hover, - > li.disabled > a:focus { - padding-top: 10px; - padding-bottom: 10px; - margin-top: 6px; - } - - &.nav-justified > li { - vertical-align: bottom; - } -} - -.dropdown-menu { - margin-top: 0; - @include shadow(); - border-top-width: 1px; - @include box-shadow(none); -} - -.breadcrumb { - border-color: darken($breadcrumb-bg, 5%); - border-style: solid; - @include shadow(); -} - -.pagination, -.pager { - - > li > a, - > li > span { - position: relative; - top: 0; - @include shadow(); - color: $pagination-color; - font-size: 12px; - font-weight: bold; - text-transform: uppercase; - - &:hover { - top: 1px; - border-bottom-width: 3px; - } - - &:active { - top: 2px; - border-bottom-width: 2px; - } - } - - > .disabled > a, - > .disabled > span { - - &:hover { - top: 0; - @include shadow(); - } - - &:active { - top: 0; - @include shadow(); - } - } -} - -.pager { - - > li > a, - > li > span, - > .disabled > a, - > .disabled > span { - - &, - &:hover, - &:active { - border-left-width: 2px; - border-right-width: 2px; - } - } -} - -// Indicators ================================================================= - -.close { - color: #fff; - text-decoration: none; - opacity: 0.4; - - &:hover, - &:focus { - color: #fff; - opacity: 1; - } -} - -.alert { - @include shadow(); - - .alert-link { - font-weight: normal; - color: #fff; - text-decoration: underline; - } -} - -.label { - font-weight: normal; -} - -// Progress bars ============================================================== - -.progress { - border: 1px solid $navbar-default-border; - @include box-shadow(inset 0 2px 0 rgba(0, 0, 0, 0.1)); - - &-bar { - @include box-shadow(inset 0 -4px 0 rgba(0, 0, 0, 0.15)); - } -} - -// Containers ================================================================= - -.well { - border: 1px solid $navbar-default-border; - @include box-shadow(inset 0 2px 0 rgba(0, 0, 0, 0.05)); -} - -a.list-group-item { - - &.active, - &.active:hover, - &.active:focus { - border-color: $list-group-border; - } - - &-success { - &.active { - background-color: $state-success-bg; - } - - &.active:hover, - &.active:focus { - background-color: darken($state-success-bg, 5%); - } - } - - &-warning { - &.active { - background-color: $state-warning-bg; - } - - &.active:hover, - &.active:focus { - background-color: darken($state-warning-bg, 5%); - } - } - - &-danger { - &.active { - background-color: $state-danger-bg; - } - - &.active:hover, - &.active:focus { - background-color: darken($state-danger-bg, 5%); - } - } -} - -.jumbotron { - border: 1px solid $navbar-default-border; - @include box-shadow(inset 0 2px 0 rgba(0, 0, 0, 0.05)); -} - -.panel { - border: 1px solid $navbar-default-border; - @include shadow(); - - &-default { - .close { - color: $text-color; - } - } -} - -.modal { - .close { - color: $text-color; - } -} - -.popover { - color: $text-color; -} diff --git a/_sass/bootstrap/_breadcrumbs.scss b/_sass/bootstrap/_breadcrumbs.scss deleted file mode 100644 index b61f0c73..00000000 --- a/_sass/bootstrap/_breadcrumbs.scss +++ /dev/null @@ -1,28 +0,0 @@ -// -// Breadcrumbs -// -------------------------------------------------- - - -.breadcrumb { - padding: $breadcrumb-padding-vertical $breadcrumb-padding-horizontal; - margin-bottom: $line-height-computed; - list-style: none; - background-color: $breadcrumb-bg; - border-radius: $border-radius-base; - - > li { - display: inline-block; - - + li:before { - // [converter] Workaround for https://github.com/sass/libsass/issues/1115 - $nbsp: "\00a0"; - content: "#{$breadcrumb-separator}#{$nbsp}"; // Unicode space added since inline-block means non-collapsing white-space - padding: 0 5px; - color: $breadcrumb-color; - } - } - - > .active { - color: $breadcrumb-active-color; - } -} diff --git a/_sass/bootstrap/_button-groups.scss b/_sass/bootstrap/_button-groups.scss deleted file mode 100644 index 4b385f56..00000000 --- a/_sass/bootstrap/_button-groups.scss +++ /dev/null @@ -1,244 +0,0 @@ -// -// Button groups -// -------------------------------------------------- - -// Make the div behave like a button -.btn-group, -.btn-group-vertical { - position: relative; - display: inline-block; - vertical-align: middle; // match .btn alignment given font-size hack above - > .btn { - position: relative; - float: left; - // Bring the "active" button to the front - &:hover, - &:focus, - &:active, - &.active { - z-index: 2; - } - } -} - -// Prevent double borders when buttons are next to each other -.btn-group { - .btn + .btn, - .btn + .btn-group, - .btn-group + .btn, - .btn-group + .btn-group { - margin-left: -1px; - } -} - -// Optional: Group multiple button groups together for a toolbar -.btn-toolbar { - margin-left: -5px; // Offset the first child's margin - @include clearfix; - - .btn, - .btn-group, - .input-group { - float: left; - } - > .btn, - > .btn-group, - > .input-group { - margin-left: 5px; - } -} - -.btn-group > .btn:not(:first-child):not(:last-child):not(.dropdown-toggle) { - border-radius: 0; -} - -// Set corners individual because sometimes a single button can be in a .btn-group and we need :first-child and :last-child to both match -.btn-group > .btn:first-child { - margin-left: 0; - &:not(:last-child):not(.dropdown-toggle) { - @include border-right-radius(0); - } -} -// Need .dropdown-toggle since :last-child doesn't apply, given that a .dropdown-menu is used immediately after it -.btn-group > .btn:last-child:not(:first-child), -.btn-group > .dropdown-toggle:not(:first-child) { - @include border-left-radius(0); -} - -// Custom edits for including btn-groups within btn-groups (useful for including dropdown buttons within a btn-group) -.btn-group > .btn-group { - float: left; -} -.btn-group > .btn-group:not(:first-child):not(:last-child) > .btn { - border-radius: 0; -} -.btn-group > .btn-group:first-child:not(:last-child) { - > .btn:last-child, - > .dropdown-toggle { - @include border-right-radius(0); - } -} -.btn-group > .btn-group:last-child:not(:first-child) > .btn:first-child { - @include border-left-radius(0); -} - -// On active and open, don't show outline -.btn-group .dropdown-toggle:active, -.btn-group.open .dropdown-toggle { - outline: 0; -} - - -// Sizing -// -// Remix the default button sizing classes into new ones for easier manipulation. - -.btn-group-xs > .btn { @extend .btn-xs; } -.btn-group-sm > .btn { @extend .btn-sm; } -.btn-group-lg > .btn { @extend .btn-lg; } - - -// Split button dropdowns -// ---------------------- - -// Give the line between buttons some depth -.btn-group > .btn + .dropdown-toggle { - padding-left: 8px; - padding-right: 8px; -} -.btn-group > .btn-lg + .dropdown-toggle { - padding-left: 12px; - padding-right: 12px; -} - -// The clickable button for toggling the menu -// Remove the gradient and set the same inset shadow as the :active state -.btn-group.open .dropdown-toggle { - @include box-shadow(inset 0 3px 5px rgba(0,0,0,.125)); - - // Show no shadow for `.btn-link` since it has no other button styles. - &.btn-link { - @include box-shadow(none); - } -} - - -// Reposition the caret -.btn .caret { - margin-left: 0; -} -// Carets in other button sizes -.btn-lg .caret { - border-width: $caret-width-large $caret-width-large 0; - border-bottom-width: 0; -} -// Upside down carets for .dropup -.dropup .btn-lg .caret { - border-width: 0 $caret-width-large $caret-width-large; -} - - -// Vertical button groups -// ---------------------- - -.btn-group-vertical { - > .btn, - > .btn-group, - > .btn-group > .btn { - display: block; - float: none; - width: 100%; - max-width: 100%; - } - - // Clear floats so dropdown menus can be properly placed - > .btn-group { - @include clearfix; - > .btn { - float: none; - } - } - - > .btn + .btn, - > .btn + .btn-group, - > .btn-group + .btn, - > .btn-group + .btn-group { - margin-top: -1px; - margin-left: 0; - } -} - -.btn-group-vertical > .btn { - &:not(:first-child):not(:last-child) { - border-radius: 0; - } - &:first-child:not(:last-child) { - @include border-top-radius($btn-border-radius-base); - @include border-bottom-radius(0); - } - &:last-child:not(:first-child) { - @include border-top-radius(0); - @include border-bottom-radius($btn-border-radius-base); - } -} -.btn-group-vertical > .btn-group:not(:first-child):not(:last-child) > .btn { - border-radius: 0; -} -.btn-group-vertical > .btn-group:first-child:not(:last-child) { - > .btn:last-child, - > .dropdown-toggle { - @include border-bottom-radius(0); - } -} -.btn-group-vertical > .btn-group:last-child:not(:first-child) > .btn:first-child { - @include border-top-radius(0); -} - - -// Justified button groups -// ---------------------- - -.btn-group-justified { - display: table; - width: 100%; - table-layout: fixed; - border-collapse: separate; - > .btn, - > .btn-group { - float: none; - display: table-cell; - width: 1%; - } - > .btn-group .btn { - width: 100%; - } - - > .btn-group .dropdown-menu { - left: auto; - } -} - - -// Checkbox and radio options -// -// In order to support the browser's form validation feedback, powered by the -// `required` attribute, we have to "hide" the inputs via `clip`. We cannot use -// `display: none;` or `visibility: hidden;` as that also hides the popover. -// Simply visually hiding the inputs via `opacity` would leave them clickable in -// certain cases which is prevented by using `clip` and `pointer-events`. -// This way, we ensure a DOM element is visible to position the popover from. -// -// See https://github.com/twbs/bootstrap/pull/12794 and -// https://github.com/twbs/bootstrap/pull/14559 for more information. - -[data-toggle="buttons"] { - > .btn, - > .btn-group > .btn { - input[type="radio"], - input[type="checkbox"] { - position: absolute; - clip: rect(0,0,0,0); - pointer-events: none; - } - } -} diff --git a/_sass/bootstrap/_buttons.scss b/_sass/bootstrap/_buttons.scss deleted file mode 100644 index e91db2f6..00000000 --- a/_sass/bootstrap/_buttons.scss +++ /dev/null @@ -1,349 +0,0 @@ -// -// Buttons -// -------------------------------------------------- - - -// Base styles -// -------------------------------------------------- - -// ------ custom-made for publications - -.btn-abstract { - display: inline-block; - border: 1px solid var(--global-text-color); - padding-left: 1rem; - padding-right: 1rem; - padding-top: 0.25rem; - padding-bottom: 0.25rem; - color: $gray-lighter; - &:hover { - color: var(--global-theme-color); - border-color: var(--global-theme-color); - } - - margin-bottom: 0; // For input.btn - font-weight: bold; - // font-weight: $btn-font-weight; - text-align: center; - vertical-align: middle; - touch-action: manipulation; - cursor: pointer; - background-image: none; // Reset unusual Firefox-on-Android default style; see https://github.com/necolas/normalize.css/issues/214 - white-space: nowrap; - background-color: #03888a; - @include button-size($padding-base-vertical*0.3, $padding-base-horizontal, $font-size-small, $line-height-base, $btn-border-radius-base); - @include user-select(none); - - &.disabled, - &[disabled], - fieldset[disabled] & { - cursor: $cursor-disabled; - @include opacity(.65); - @include box-shadow(none); - } -} - -.btn-video { - display: inline-block; - border: 1px solid var(--global-text-color); - padding-left: 1rem; - padding-right: 1rem; - padding-top: 0.25rem; - padding-bottom: 0.25rem; - color: $gray-lighter; - &:hover { - color: var(--global-theme-color); - border-color: var(--global-theme-color); - } - - margin-bottom: 0; // For input.btn - font-weight: bold; - // font-weight: $btn-font-weight; - text-align: center; - vertical-align: middle; - touch-action: manipulation; - cursor: pointer; - background-image: none; // Reset unusual Firefox-on-Android default style; see https://github.com/necolas/normalize.css/issues/214 - white-space: nowrap; - background-color: #0000CD; - @include button-size($padding-base-vertical*0.3, $padding-base-horizontal, $font-size-small, $line-height-base, $btn-border-radius-base); - @include user-select(none); - - &.disabled, - &[disabled], - fieldset[disabled] & { - cursor: $cursor-disabled; - @include opacity(.65); - @include box-shadow(none); - } -} - -.btn-pdf { - display: inline-block; - margin-bottom: 0; // For input.btn - font-weight: bold; - // font-weight: $btn-font-weight; - text-align: center; - vertical-align: middle; - touch-action: manipulation; - cursor: pointer; - background-image: none; // Reset unusual Firefox-on-Android default style; see https://github.com/necolas/normalize.css/issues/214 - border: 0px solid transparent; - white-space: nowrap; - color: $gray-lighter; - background-color: $btn-warning-bg; - @include button-size($padding-base-vertical*0.3, $padding-base-horizontal, $font-size-small, $line-height-base, $btn-border-radius-base); - @include user-select(none); - - &.disabled, - &[disabled], - fieldset[disabled] & { - cursor: $cursor-disabled; - @include opacity(.65); - @include box-shadow(none); - } -} - - -.btn-arxiv { - display: inline-block; - margin-bottom: 0; // For input.btn - font-weight: bold; - // font-weight: $btn-font-weight; - text-align: center; - vertical-align: middle; - touch-action: manipulation; - cursor: pointer; - background-image: none; // Reset unusual Firefox-on-Android default style; see https://github.com/necolas/normalize.css/issues/214 - border: 0px solid transparent; - white-space: nowrap; - color: $gray-lighter; - background-color: $btn-info-bg; - @include button-size($padding-base-vertical*0.3, $padding-base-horizontal, $font-size-small, $line-height-base, $btn-border-radius-base); - @include user-select(none); - - &.disabled, - &[disabled], - fieldset[disabled] & { - cursor: $cursor-disabled; - @include opacity(.65); - @include box-shadow(none); - } -} - -.btn-doi { - display: inline-block; - margin-bottom: 0; // For input.btn - font-weight: bold; - // font-weight: $btn-font-weight; - text-align: center; - vertical-align: middle; - touch-action: manipulation; - cursor: pointer; - background-image: none; // Reset unusual Firefox-on-Android default style; see https://github.com/necolas/normalize.css/issues/214 - border: 0px solid transparent; - white-space: nowrap; - color: $gray-lighter; - background-color: $btn-danger-bg; - @include button-size($padding-base-vertical*0.3, $padding-base-horizontal, $font-size-small, $line-height-base, $btn-border-radius-base); - @include user-select(none); - - &.disabled, - &[disabled], - fieldset[disabled] & { - cursor: $cursor-disabled; - @include opacity(.65); - @include box-shadow(none); - } -} - -.btn-bib { - display: inline-block; - margin-bottom: 0; // For input.btn - font-weight: bold; - // font-weight: $btn-font-weight; - text-align: center; - vertical-align: middle; - touch-action: manipulation; - cursor: pointer; - background-image: none; // Reset unusual Firefox-on-Android default style; see https://github.com/necolas/normalize.css/issues/214 - border: 0px solid transparent; - white-space: nowrap; - color: $gray-lighter; - background-color: $btn-success-bg; - @include button-size($padding-base-vertical*0.3, $padding-base-horizontal, $font-size-small, $line-height-base, $btn-border-radius-base); - @include user-select(none); - - &.disabled, - &[disabled], - fieldset[disabled] & { - cursor: $cursor-disabled; - @include opacity(.65); - @include box-shadow(none); - } -} - - - -// ---------- - -.btn { - display: inline-block; - margin-bottom: 0; // For input.btn - font-weight: $btn-font-weight; - text-align: center; - vertical-align: middle; - touch-action: manipulation; - cursor: pointer; - background-image: none; // Reset unusual Firefox-on-Android default style; see https://github.com/necolas/normalize.css/issues/214 - border: 1px solid transparent; - white-space: nowrap; - @include button-size($padding-base-vertical, $padding-base-horizontal, $font-size-base, $line-height-base, $btn-border-radius-base); - @include user-select(none); - - &, - &:active, - &.active { - &:focus, - &.focus { - @include tab-focus; - } - } - - &:hover, - &:focus, - &.focus { - color: $btn-default-color; - text-decoration: none; - } - - &:active, - &.active { - outline: 0; - background-image: none; - @include box-shadow(inset 0 3px 5px rgba(0,0,0,.125)); - } - - &.disabled, - &[disabled], - fieldset[disabled] & { - cursor: $cursor-disabled; - @include opacity(.65); - @include box-shadow(none); - } - - // [converter] extracted a& to a.btn -} - -a.btn { - &.disabled, - fieldset[disabled] & { - pointer-events: none; // Future-proof disabling of clicks on `` elements - } -} - - -// Alternate buttons -// -------------------------------------------------- - -.btn-default { - @include button-variant($btn-default-color, $btn-default-bg, $btn-default-border); -} -.btn-primary { - @include button-variant($btn-primary-color, $btn-primary-bg, $btn-primary-border); -} -// Success appears as green -.btn-success { - @include button-variant($btn-success-color, $btn-success-bg, $btn-success-border); -} -// Info appears as blue-green -.btn-info { - @include button-variant($btn-info-color, $btn-info-bg, $btn-info-border); -} -// Warning appears as orange -.btn-warning { - @include button-variant($btn-warning-color, $btn-warning-bg, $btn-warning-border); -} -// Danger and error appear as red -.btn-danger { - @include button-variant($btn-danger-color, $btn-danger-bg, $btn-danger-border); -} - - -// Link buttons -// ------------------------- - -// Make a button look and behave like a link -.btn-link { - color: $link-color; - font-weight: normal; - border-radius: 0; - - &, - &:active, - &.active, - &[disabled], - fieldset[disabled] & { - background-color: transparent; - @include box-shadow(none); - } - &, - &:hover, - &:focus, - &:active { - border-color: transparent; - } - &:hover, - &:focus { - color: $link-hover-color; - text-decoration: $link-hover-decoration; - background-color: transparent; - } - &[disabled], - fieldset[disabled] & { - &:hover, - &:focus { - color: $btn-link-disabled-color; - text-decoration: none; - } - } -} - - -// Button Sizes -// -------------------------------------------------- - -.btn-lg { - // line-height: ensure even-numbered height of button next to large input - @include button-size($padding-large-vertical, $padding-large-horizontal, $font-size-large, $line-height-large, $btn-border-radius-large); -} -.btn-sm { - // line-height: ensure proper height of button next to small input - @include button-size($padding-small-vertical, $padding-small-horizontal, $font-size-small, $line-height-small, $btn-border-radius-small); -} -.btn-xs { - @include button-size($padding-xs-vertical, $padding-xs-horizontal, $font-size-small, $line-height-small, $btn-border-radius-small); -} - - -// Block button -// -------------------------------------------------- - -.btn-block { - display: block; - width: 100%; -} - -// Vertically space out multiple block buttons -.btn-block + .btn-block { - margin-top: 5px; -} - -// Specificity overrides -input[type="submit"], -input[type="reset"], -input[type="button"] { - &.btn-block { - width: 100%; - } -} diff --git a/_sass/bootstrap/_carousel.scss b/_sass/bootstrap/_carousel.scss deleted file mode 100644 index 823476ac..00000000 --- a/_sass/bootstrap/_carousel.scss +++ /dev/null @@ -1,270 +0,0 @@ -// -// Carousel -// -------------------------------------------------- - - -// Wrapper for the slide container and indicators -.carousel { - position: relative; -} - -.carousel-inner { - position: relative; - overflow: hidden; - width: 100%; - - > .item { - display: none; - position: relative; - @include transition(.6s ease-in-out left); - - // Account for jankitude on images - > img, - > a > img { - @include img-responsive; - line-height: 1; - } - - // WebKit CSS3 transforms for supported devices - @media all and (transform-3d), (-webkit-transform-3d) { - @include transition-transform(0.6s ease-in-out); - @include backface-visibility(hidden); - @include perspective(1000px); - - &.next, - &.active.right { - @include translate3d(100%, 0, 0); - left: 0; - } - &.prev, - &.active.left { - @include translate3d(-100%, 0, 0); - left: 0; - } - &.next.left, - &.prev.right, - &.active { - @include translate3d(0, 0, 0); - left: 0; - } - } - } - - > .active, - > .next, - > .prev { - display: block; - } - - > .active { - left: 0; - } - - > .next, - > .prev { - position: absolute; - top: 0; - width: 100%; - } - - > .next { - left: 100%; - } - > .prev { - left: -100%; - } - > .next.left, - > .prev.right { - left: 0; - } - - > .active.left { - left: -100%; - } - > .active.right { - left: 100%; - } - -} - -// Left/right controls for nav -// --------------------------- - -.carousel-control { - position: absolute; - top: 0; - left: 0; - bottom: 0; - width: $carousel-control-width; - @include opacity($carousel-control-opacity); - font-size: $carousel-control-font-size; - color: $carousel-control-color; - text-align: center; - text-shadow: $carousel-text-shadow; - background-color: rgba(0, 0, 0, 0); // Fix IE9 click-thru bug - // We can't have this transition here because WebKit cancels the carousel - // animation if you trip this while in the middle of another animation. - - // Set gradients for backgrounds - &.left { - @include gradient-horizontal($start-color: rgba(0,0,0,.0001), $end-color: rgba(0,0,0,.0001)); - } - &.right { - left: auto; - right: 0; - @include gradient-horizontal($start-color: rgba(0,0,0,.0001), $end-color: rgba(0,0,0,.0001)); - } - - // Hover/focus state - &:hover, - &:focus { - outline: 0; - color: $carousel-control-color; - text-decoration: none; - @include opacity(.9); - } - - // Toggles - .icon-prev, - .icon-next, - .glyphicon-chevron-left, - .glyphicon-chevron-right { - position: absolute; - top: 50%; - margin-top: -10px; - z-index: 5; - display: inline-block; - } - .icon-prev, - .glyphicon-chevron-left { - left: 50%; - margin-left: -10px; - } - .icon-next, - .glyphicon-chevron-right { - right: 50%; - margin-right: -10px; - } - .icon-prev, - .icon-next { - width: 20px; - height: 20px; - line-height: 1; - font-family: serif; - } - - - .icon-prev { - &:before { - content: '\2039';// SINGLE LEFT-POINTING ANGLE QUOTATION MARK (U+2039) - } - } - .icon-next { - &:before { - content: '\203a';// SINGLE RIGHT-POINTING ANGLE QUOTATION MARK (U+203A) - } - } -} - -// Optional indicator pips -// -// Add an unordered list with the following class and add a list item for each -// slide your carousel holds. - -.carousel-indicators { - position: absolute; - bottom: 10px; - left: 50%; - z-index: 15; - width: 60%; - margin-left: -30%; - padding-left: 0; - list-style: none; - text-align: center; - - li { - display: inline-block; - width: 10px; - height: 10px; - margin: 1px; - text-indent: -999px; - border: 1px solid $carousel-indicator-border-color; - border-radius: 10px; - cursor: pointer; - - // IE8-9 hack for event handling - // - // Internet Explorer 8-9 does not support clicks on elements without a set - // `background-color`. We cannot use `filter` since that's not viewed as a - // background color by the browser. Thus, a hack is needed. - // See https://developer.mozilla.org/en-US/docs/Web/Events/click#Internet_Explorer - // - // For IE8, we set solid black as it doesn't support `rgba()`. For IE9, we - // set alpha transparency for the best results possible. - background-color: #000 \9; // IE8 - background-color: rgba(0,0,0,0); // IE9 - } - .active { - margin: 0; - width: 12px; - height: 12px; - background-color: $carousel-indicator-active-bg; - } -} - -// Optional captions -// ----------------------------- -// Hidden by default for smaller viewports -.carousel-caption { - position: absolute; - left: 15%; - right: 15%; - bottom: 20px; - z-index: 10; - padding-top: 20px; - padding-bottom: 20px; - color: $carousel-caption-color; - text-align: center; - text-shadow: $carousel-text-shadow; - & .btn { - text-shadow: none; // No shadow for button elements in carousel-caption - } -} - - -// Scale up controls for tablets and up -@media screen and (min-width: $screen-sm-min) { - - // Scale up the controls a smidge - .carousel-control { - .glyphicon-chevron-left, - .glyphicon-chevron-right, - .icon-prev, - .icon-next { - width: ($carousel-control-font-size * 1.5); - height: ($carousel-control-font-size * 1.5); - margin-top: ($carousel-control-font-size / -2); - font-size: ($carousel-control-font-size * 1.5); - } - .glyphicon-chevron-left, - .icon-prev { - margin-left: ($carousel-control-font-size / -2); - } - .glyphicon-chevron-right, - .icon-next { - margin-right: ($carousel-control-font-size / -2); - } - } - - // Show and left align the captions - .carousel-caption { - left: 20%; - right: 20%; - padding-bottom: 30px; - } - - // Move up the indicators - .carousel-indicators { - bottom: 20px; - } -} diff --git a/_sass/bootstrap/_close.scss b/_sass/bootstrap/_close.scss deleted file mode 100644 index 3b74d8a9..00000000 --- a/_sass/bootstrap/_close.scss +++ /dev/null @@ -1,36 +0,0 @@ -// -// Close icons -// -------------------------------------------------- - - -.close { - float: right; - font-size: ($font-size-base * 1.5); - font-weight: $close-font-weight; - line-height: 1; - color: $close-color; - text-shadow: $close-text-shadow; - @include opacity(.2); - - &:hover, - &:focus { - color: $close-color; - text-decoration: none; - cursor: pointer; - @include opacity(.5); - } - - // [converter] extracted button& to button.close -} - -// Additional properties for button version -// iOS requires the button element instead of an anchor tag. -// If you want the anchor version, it requires `href="#"`. -// See https://developer.mozilla.org/en-US/docs/Web/Events/click#Safari_Mobile -button.close { - padding: 0; - cursor: pointer; - background: transparent; - border: 0; - -webkit-appearance: none; -} diff --git a/_sass/bootstrap/_code.scss b/_sass/bootstrap/_code.scss deleted file mode 100644 index 246228ac..00000000 --- a/_sass/bootstrap/_code.scss +++ /dev/null @@ -1,69 +0,0 @@ -// -// Code (inline and block) -// -------------------------------------------------- - - -// Inline and block code styles -code, -kbd, -pre, -samp { - font-family: $font-family-monospace; -} - -// Inline code -code { - padding: 2px 4px; - font-size: 90%; - color: $code-color; - background-color: $code-bg; - border-radius: $border-radius-base; -} - -// User input typically entered via keyboard -kbd { - padding: 2px 4px; - font-size: 90%; - color: $kbd-color; - background-color: $kbd-bg; - border-radius: $border-radius-small; - box-shadow: inset 0 -1px 0 rgba(0,0,0,.25); - - kbd { - padding: 0; - font-size: 100%; - font-weight: bold; - box-shadow: none; - } -} - -// Blocks of code -pre { - display: block; - padding: (($line-height-computed - 1) / 2); - margin: 0 0 ($line-height-computed / 2); - font-size: ($font-size-base - 1); // 14px to 13px - line-height: $line-height-base; - word-break: break-all; - word-wrap: break-word; - color: $pre-color; - // background-color: $pre-bg; - //border: 1px solid $pre-border-color; - //border-radius: $border-radius-base; - - // Account for some code outputs that place code tags in pre tags - code { - padding: 0; - font-size: inherit; - color: inherit; - white-space: pre-wrap; - background-color: transparent; - border-radius: 0; - } -} - -// Enable scrollable blocks of code -.pre-scrollable { - max-height: $pre-scrollable-max-height; - overflow-y: scroll; -} diff --git a/_sass/bootstrap/_component-animations.scss b/_sass/bootstrap/_component-animations.scss deleted file mode 100644 index ca3b43ca..00000000 --- a/_sass/bootstrap/_component-animations.scss +++ /dev/null @@ -1,37 +0,0 @@ -// -// Component animations -// -------------------------------------------------- - -// Heads up! -// -// We don't use the `.opacity()` mixin here since it causes a bug with text -// fields in IE7-8. Source: https://github.com/twbs/bootstrap/pull/3552. - -.fade { - opacity: 0; - @include transition(opacity .15s linear); - &.in { - opacity: 1; - } -} - -.collapse { - display: none; - - &.in { display: block; } - // [converter] extracted tr&.in to tr.collapse.in - // [converter] extracted tbody&.in to tbody.collapse.in -} - -tr.collapse.in { display: table-row; } - -tbody.collapse.in { display: table-row-group; } - -.collapsing { - position: relative; - height: 0; - overflow: hidden; - @include transition-property(height, visibility); - @include transition-duration(.35s); - @include transition-timing-function(ease); -} diff --git a/_sass/bootstrap/_dropdowns.scss b/_sass/bootstrap/_dropdowns.scss deleted file mode 100644 index aac84597..00000000 --- a/_sass/bootstrap/_dropdowns.scss +++ /dev/null @@ -1,216 +0,0 @@ -// -// Dropdown menus -// -------------------------------------------------- - - -// Dropdown arrow/caret -.caret { - display: inline-block; - width: 0; - height: 0; - margin-left: 2px; - vertical-align: middle; - border-top: $caret-width-base dashed; - border-top: $caret-width-base solid \9; // IE8 - border-right: $caret-width-base solid transparent; - border-left: $caret-width-base solid transparent; -} - -// The dropdown wrapper (div) -.dropup, -.dropdown { - position: relative; -} - -// Prevent the focus on the dropdown toggle when closing dropdowns -.dropdown-toggle:focus { - outline: 0; -} - -// The dropdown menu (ul) -.dropdown-menu { - position: absolute; - top: 100%; - left: 0; - z-index: $zindex-dropdown; - display: none; // none by default, but block on "open" of the menu - float: left; - min-width: 160px; - padding: 5px 0; - margin: 2px 0 0; // override default ul - list-style: none; - font-size: $font-size-base; - text-align: left; // Ensures proper alignment if parent has it changed (e.g., modal footer) - background-color: $dropdown-bg; - border: 1px solid $dropdown-fallback-border; // IE8 fallback - border: 1px solid $dropdown-border; - border-radius: $border-radius-base; - @include box-shadow(0 6px 12px rgba(0,0,0,.175)); - background-clip: padding-box; - - // Aligns the dropdown menu to right - // - // Deprecated as of 3.1.0 in favor of `.dropdown-menu-[dir]` - &.pull-right { - right: 0; - left: auto; - } - - // Dividers (basically an hr) within the dropdown - .divider { - @include nav-divider($dropdown-divider-bg); - } - - // Links within the dropdown menu - > li > a { - display: block; - padding: 3px 20px; - clear: both; - font-weight: normal; - line-height: $line-height-base; - color: $dropdown-link-color; - white-space: nowrap; // prevent links from randomly breaking onto new lines - } -} - -// Hover/Focus state -.dropdown-menu > li > a { - &:hover, - &:focus { - text-decoration: none; - color: $dropdown-link-hover-color; - background-color: $dropdown-link-hover-bg; - } -} - -// Active state -.dropdown-menu > .active > a { - &, - &:hover, - &:focus { - color: $dropdown-link-active-color; - text-decoration: none; - outline: 0; - background-color: $dropdown-link-active-bg; - } -} - -// Disabled state -// -// Gray out text and ensure the hover/focus state remains gray - -.dropdown-menu > .disabled > a { - &, - &:hover, - &:focus { - color: $dropdown-link-disabled-color; - } - - // Nuke hover/focus effects - &:hover, - &:focus { - text-decoration: none; - background-color: transparent; - background-image: none; // Remove CSS gradient - @include reset-filter; - cursor: $cursor-disabled; - } -} - -// Open state for the dropdown -.open { - // Show the menu - > .dropdown-menu { - display: block; - } - - // Remove the outline when :focus is triggered - > a { - outline: 0; - } -} - -// Menu positioning -// -// Add extra class to `.dropdown-menu` to flip the alignment of the dropdown -// menu with the parent. -.dropdown-menu-right { - left: auto; // Reset the default from `.dropdown-menu` - right: 0; -} -// With v3, we enabled auto-flipping if you have a dropdown within a right -// aligned nav component. To enable the undoing of that, we provide an override -// to restore the default dropdown menu alignment. -// -// This is only for left-aligning a dropdown menu within a `.navbar-right` or -// `.pull-right` nav component. -.dropdown-menu-left { - left: 0; - right: auto; -} - -// Dropdown section headers -.dropdown-header { - display: block; - padding: 3px 20px; - font-size: $font-size-small; - line-height: $line-height-base; - color: $dropdown-header-color; - white-space: nowrap; // as with > li > a -} - -// Backdrop to catch body clicks on mobile, etc. -.dropdown-backdrop { - position: fixed; - left: 0; - right: 0; - bottom: 0; - top: 0; - z-index: ($zindex-dropdown - 10); -} - -// Right aligned dropdowns -.pull-right > .dropdown-menu { - right: 0; - left: auto; -} - -// Allow for dropdowns to go bottom up (aka, dropup-menu) -// -// Just add .dropup after the standard .dropdown class and you're set, bro. -// TODO: abstract this so that the navbar fixed styles are not placed here? - -.dropup, -.navbar-fixed-bottom .dropdown { - // Reverse the caret - .caret { - border-top: 0; - border-bottom: $caret-width-base dashed; - border-bottom: $caret-width-base solid \9; // IE8 - content: ""; - } - // Different positioning for bottom up menu - .dropdown-menu { - top: auto; - bottom: 100%; - margin-bottom: 2px; - } -} - - -// Component alignment -// -// Reiterate per navbar.less and the modified component alignment there. - -@media (min-width: $grid-float-breakpoint) { - .navbar-right { - .dropdown-menu { - right: 0; left: auto; - } - // Necessary for overrides of the default right aligned menu. - // Will remove come v4 in all likelihood. - .dropdown-menu-left { - left: 0; right: auto; - } - } -} diff --git a/_sass/bootstrap/_forms.scss b/_sass/bootstrap/_forms.scss deleted file mode 100644 index ac26a6ad..00000000 --- a/_sass/bootstrap/_forms.scss +++ /dev/null @@ -1,617 +0,0 @@ -// -// Forms -// -------------------------------------------------- - - -// Normalize non-controls -// -// Restyle and baseline non-control form elements. - -fieldset { - padding: 0; - margin: 0; - border: 0; - // Chrome and Firefox set a `min-width: min-content;` on fieldsets, - // so we reset that to ensure it behaves more like a standard block element. - // See https://github.com/twbs/bootstrap/issues/12359. - min-width: 0; -} - -legend { - display: block; - width: 100%; - padding: 0; - margin-bottom: $line-height-computed; - font-size: ($font-size-base * 1.5); - line-height: inherit; - color: $legend-color; - border: 0; - border-bottom: 1px solid $legend-border-color; -} - -label { - display: inline-block; - max-width: 100%; // Force IE8 to wrap long content (see https://github.com/twbs/bootstrap/issues/13141) - margin-bottom: 5px; - font-weight: bold; -} - - -// Normalize form controls -// -// While most of our form styles require extra classes, some basic normalization -// is required to ensure optimum display with or without those classes to better -// address browser inconsistencies. - -// Override content-box in Normalize (* isn't specific enough) -input[type="search"] { - @include box-sizing(border-box); -} - -// Position radios and checkboxes better -input[type="radio"], -input[type="checkbox"] { - margin: 4px 0 0; - margin-top: 1px \9; // IE8-9 - line-height: normal; -} - -input[type="file"] { - display: block; -} - -// Make range inputs behave like textual form controls -input[type="range"] { - display: block; - width: 100%; -} - -// Make multiple select elements height not fixed -select[multiple], -select[size] { - height: auto; -} - -// Focus for file, radio, and checkbox -input[type="file"]:focus, -input[type="radio"]:focus, -input[type="checkbox"]:focus { - @include tab-focus; -} - -// Adjust output element -output { - display: block; - padding-top: ($padding-base-vertical + 1); - font-size: $font-size-base; - line-height: $line-height-base; - color: $input-color; -} - - -// Common form controls -// -// Shared size and type resets for form controls. Apply `.form-control` to any -// of the following form controls: -// -// select -// textarea -// input[type="text"] -// input[type="password"] -// input[type="datetime"] -// input[type="datetime-local"] -// input[type="date"] -// input[type="month"] -// input[type="time"] -// input[type="week"] -// input[type="number"] -// input[type="email"] -// input[type="url"] -// input[type="search"] -// input[type="tel"] -// input[type="color"] - -.form-control { - display: block; - width: 100%; - height: $input-height-base; // Make inputs at least the height of their button counterpart (base line-height + padding + border) - padding: $padding-base-vertical $padding-base-horizontal; - font-size: $font-size-base; - line-height: $line-height-base; - color: $input-color; - background-color: $input-bg; - background-image: none; // Reset unusual Firefox-on-Android default style; see https://github.com/necolas/normalize.css/issues/214 - border: 1px solid $input-border; - border-radius: $input-border-radius; // Note: This has no effect on s in CSS. - @include box-shadow(inset 0 1px 1px rgba(0,0,0,.075)); - @include transition(border-color ease-in-out .15s, box-shadow ease-in-out .15s); - - // Customize the `:focus` state to imitate native WebKit styles. - @include form-control-focus; - - // Placeholder - @include placeholder; - - // Unstyle the caret on `` background color -$input-bg: #fff !default; -//** `` background color -$input-bg-disabled: $gray-lighter !default; - -//** Text color for ``s -$input-color: $gray !default; -//** `` border color -$input-border: #ccc !default; - -// TODO: Rename `$input-border-radius` to `$input-border-radius-base` in v4 -//** Default `.form-control` border radius -// This has no effect on ``s in CSS. -$input-border-radius: $border-radius-base !default; -//** Large `.form-control` border radius -$input-border-radius-large: $border-radius-large !default; -//** Small `.form-control` border radius -$input-border-radius-small: $border-radius-small !default; - -//** Border color for inputs on focus -$input-border-focus: #66afe9 !default; - -//** Placeholder text color -$input-color-placeholder: #999 !default; - -//** Default `.form-control` height -$input-height-base: ($line-height-computed + ($padding-base-vertical * 2) + 2) !default; -//** Large `.form-control` height -$input-height-large: (ceil($font-size-large * $line-height-large) + ($padding-large-vertical * 2) + 2) !default; -//** Small `.form-control` height -$input-height-small: (floor($font-size-small * $line-height-small) + ($padding-small-vertical * 2) + 2) !default; - -//** `.form-group` margin -$form-group-margin-bottom: 15px !default; - -$legend-color: $gray-dark !default; -$legend-border-color: #e5e5e5 !default; - -//** Background color for textual input addons -$input-group-addon-bg: $gray-lighter !default; -//** Border color for textual input addons -$input-group-addon-border-color: $input-border !default; - -//** Disabled cursor for form controls and buttons. -$cursor-disabled: not-allowed !default; - - -//== Dropdowns -// -//## Dropdown menu container and contents. - -//** Background for the dropdown menu. -$dropdown-bg: #fff !default; -//** Dropdown menu `border-color`. -$dropdown-border: rgba(0,0,0,.15) !default; -//** Dropdown menu `border-color` **for IE8**. -$dropdown-fallback-border: #ccc !default; -//** Divider color for between dropdown items. -$dropdown-divider-bg: #e5e5e5 !default; - -//** Dropdown link text color. -$dropdown-link-color: $gray-dark !default; -//** Hover color for dropdown links. -$dropdown-link-hover-color: darken($gray-dark, 5%) !default; -//** Hover background for dropdown links. -$dropdown-link-hover-bg: #f5f5f5 !default; - -//** Active dropdown menu item text color. -$dropdown-link-active-color: $component-active-color !default; -//** Active dropdown menu item background color. -$dropdown-link-active-bg: $component-active-bg !default; - -//** Disabled dropdown menu item background color. -$dropdown-link-disabled-color: $gray-light !default; - -//** Text color for headers within dropdown menus. -$dropdown-header-color: $gray-light !default; - -//** Deprecated `$dropdown-caret-color` as of v3.1.0 -$dropdown-caret-color: #000 !default; - - -//-- Z-index master list -// -// Warning: Avoid customizing these values. They're used for a bird's eye view -// of components dependent on the z-axis and are designed to all work together. -// -// Note: These variables are not generated into the Customizer. - -$zindex-navbar: 1000 !default; -$zindex-dropdown: 1000 !default; -$zindex-popover: 1060 !default; -$zindex-tooltip: 1070 !default; -$zindex-navbar-fixed: 1030 !default; -$zindex-modal-background: 1040 !default; -$zindex-modal: 1050 !default; - - -//== Media queries breakpoints -// -//## Define the breakpoints at which your layout will change, adapting to different screen sizes. - -// Extra small screen / phone -//** Deprecated `$screen-xs` as of v3.0.1 -$screen-xs: 480px !default; -//** Deprecated `$screen-xs-min` as of v3.2.0 -$screen-xs-min: $screen-xs !default; -//** Deprecated `$screen-phone` as of v3.0.1 -$screen-phone: $screen-xs-min !default; - -// Small screen / tablet -//** Deprecated `$screen-sm` as of v3.0.1 -$screen-sm: 768px !default; -$screen-sm-min: $screen-sm !default; -//** Deprecated `$screen-tablet` as of v3.0.1 -$screen-tablet: $screen-sm-min !default; - -// Medium screen / desktop -//** Deprecated `$screen-md` as of v3.0.1 -$screen-md: 992px !default; -$screen-md-min: $screen-md !default; -//** Deprecated `$screen-desktop` as of v3.0.1 -$screen-desktop: $screen-md-min !default; - -// Large screen / wide desktop -//** Deprecated `$screen-lg` as of v3.0.1 -$screen-lg: 1200px !default; -$screen-lg-min: $screen-lg !default; -//** Deprecated `$screen-lg-desktop` as of v3.0.1 -$screen-lg-desktop: $screen-lg-min !default; - -// So media queries don't overlap when required, provide a maximum -$screen-xs-max: ($screen-sm-min - 1) !default; -$screen-sm-max: ($screen-md-min - 1) !default; -$screen-md-max: ($screen-lg-min - 1) !default; - - -//== Grid system -// -//## Define your custom responsive grid. - -//** Number of columns in the grid. -$grid-columns: 12 !default; -//** Padding between columns. Gets divided in half for the left and right. -$grid-gutter-width: 30px !default; -// Navbar collapse -//** Point at which the navbar becomes uncollapsed. -$grid-float-breakpoint: $screen-sm-min !default; -//** Point at which the navbar begins collapsing. -$grid-float-breakpoint-max: ($grid-float-breakpoint - 1) !default; - - -//== Container sizes -// -//## Define the maximum width of `.container` for different screen sizes. - -// Small screen / tablet -$container-tablet: (720px + $grid-gutter-width) !default; -//** For `$screen-sm-min` and up. -$container-sm: $container-tablet !default; - -// Medium screen / desktop -$container-desktop: (940px + $grid-gutter-width) !default; -//** For `$screen-md-min` and up. -$container-md: $container-desktop !default; - -// Large screen / wide desktop -$container-large-desktop: (1140px + $grid-gutter-width) !default; -//** For `$screen-lg-min` and up. -$container-lg: $container-large-desktop !default; - - -//== Navbar -// -//## - -// Basics of a navbar -$navbar-height: 50px !default; -$navbar-margin-bottom: $line-height-computed !default; -$navbar-border-radius: $border-radius-base !default; -$navbar-padding-horizontal: floor(($grid-gutter-width / 2)) !default; -$navbar-padding-vertical: (($navbar-height - $line-height-computed) / 2) !default; -$navbar-collapse-max-height: 340px !default; - -$navbar-default-color: #777 !default; -$navbar-default-bg: #f8f8f8 !default; -$navbar-default-border: darken($navbar-default-bg, 6.5%) !default; - -// Navbar links -$navbar-default-link-color: #777 !default; -$navbar-default-link-hover-color: #333 !default; -$navbar-default-link-hover-bg: transparent !default; -$navbar-default-link-active-color: #555 !default; -$navbar-default-link-active-bg: darken($navbar-default-bg, 6.5%) !default; -$navbar-default-link-disabled-color: #ccc !default; -$navbar-default-link-disabled-bg: transparent !default; - -// Navbar brand label -$navbar-default-brand-color: $navbar-default-link-color !default; -$navbar-default-brand-hover-color: darken($navbar-default-brand-color, 10%) !default; -$navbar-default-brand-hover-bg: transparent !default; - -// Navbar toggle -$navbar-default-toggle-hover-bg: #ddd !default; -$navbar-default-toggle-icon-bar-bg: #888 !default; -$navbar-default-toggle-border-color: #ddd !default; - - -//=== Inverted navbar -// Reset inverted navbar basics -$navbar-inverse-color: lighten($gray-light, 15%) !default; -$navbar-inverse-bg: #222 !default; -$navbar-inverse-border: darken($navbar-inverse-bg, 10%) !default; - -// Inverted navbar links -$navbar-inverse-link-color: lighten($gray-light, 15%) !default; -$navbar-inverse-link-hover-color: #fff !default; -$navbar-inverse-link-hover-bg: transparent !default; -$navbar-inverse-link-active-color: $navbar-inverse-link-hover-color !default; -$navbar-inverse-link-active-bg: darken($navbar-inverse-bg, 10%) !default; -$navbar-inverse-link-disabled-color: #444 !default; -$navbar-inverse-link-disabled-bg: transparent !default; - -// Inverted navbar brand label -$navbar-inverse-brand-color: $navbar-inverse-link-color !default; -$navbar-inverse-brand-hover-color: #fff !default; -$navbar-inverse-brand-hover-bg: transparent !default; - -// Inverted navbar toggle -$navbar-inverse-toggle-hover-bg: #333 !default; -$navbar-inverse-toggle-icon-bar-bg: #fff !default; -$navbar-inverse-toggle-border-color: #333 !default; - - -//== Navs -// -//## - -//=== Shared nav styles -$nav-link-padding: 10px 15px !default; -$nav-link-hover-bg: $gray-lighter !default; - -$nav-disabled-link-color: $gray-light !default; -$nav-disabled-link-hover-color: $gray-light !default; - -//== Tabs -$nav-tabs-border-color: #ddd !default; - -$nav-tabs-link-hover-border-color: $gray-lighter !default; - -$nav-tabs-active-link-hover-bg: $body-bg !default; -$nav-tabs-active-link-hover-color: $gray !default; -$nav-tabs-active-link-hover-border-color: #ddd !default; - -$nav-tabs-justified-link-border-color: #ddd !default; -$nav-tabs-justified-active-link-border-color: $body-bg !default; - -//== Pills -$nav-pills-border-radius: $border-radius-base !default; -$nav-pills-active-link-hover-bg: $component-active-bg !default; -$nav-pills-active-link-hover-color: $component-active-color !default; - - -//== Pagination -// -//## - -$pagination-color: $link-color !default; -$pagination-bg: #fff !default; -$pagination-border: #ddd !default; - -$pagination-hover-color: $link-hover-color !default; -$pagination-hover-bg: $gray-lighter !default; -$pagination-hover-border: #ddd !default; - -$pagination-active-color: #fff !default; -$pagination-active-bg: $brand-primary !default; -$pagination-active-border: $brand-primary !default; - -$pagination-disabled-color: $gray-light !default; -$pagination-disabled-bg: #fff !default; -$pagination-disabled-border: #ddd !default; - - -//== Pager -// -//## - -$pager-bg: $pagination-bg !default; -$pager-border: $pagination-border !default; -$pager-border-radius: 15px !default; - -$pager-hover-bg: $pagination-hover-bg !default; - -$pager-active-bg: $pagination-active-bg !default; -$pager-active-color: $pagination-active-color !default; - -$pager-disabled-color: $pagination-disabled-color !default; - - -//== Jumbotron -// -//## - -$jumbotron-padding: 30px !default; -$jumbotron-color: inherit !default; -$jumbotron-bg: $gray-lighter !default; -$jumbotron-heading-color: inherit !default; -$jumbotron-font-size: ceil(($font-size-base * 1.5)) !default; -$jumbotron-heading-font-size: ceil(($font-size-base * 4.5)) !default; - - -//== Form states and alerts -// -//## Define colors for form feedback states and, by default, alerts. - -$state-success-text: #3c763d !default; -$state-success-bg: #dff0d8 !default; -$state-success-border: darken(adjust-hue($state-success-bg, -10), 5%) !default; - -$state-info-text: #31708f !default; -$state-info-bg: #d9edf7 !default; -$state-info-border: darken(adjust-hue($state-info-bg, -10), 7%) !default; - -$state-warning-text: #8a6d3b !default; -$state-warning-bg: #fcf8e3 !default; -$state-warning-border: darken(adjust-hue($state-warning-bg, -10), 5%) !default; - -$state-danger-text: #a94442 !default; -$state-danger-bg: #f2dede !default; -$state-danger-border: darken(adjust-hue($state-danger-bg, -10), 5%) !default; - - -//== Tooltips -// -//## - -//** Tooltip max width -$tooltip-max-width: 200px !default; -//** Tooltip text color -$tooltip-color: #fff !default; -//** Tooltip background color -$tooltip-bg: #000 !default; -$tooltip-opacity: .9 !default; - -//** Tooltip arrow width -$tooltip-arrow-width: 5px !default; -//** Tooltip arrow color -$tooltip-arrow-color: $tooltip-bg !default; - - -//== Popovers -// -//## - -//** Popover body background color -$popover-bg: #fff !default; -//** Popover maximum width -$popover-max-width: 276px !default; -//** Popover border color -$popover-border-color: rgba(0,0,0,.2) !default; -//** Popover fallback border color -$popover-fallback-border-color: #ccc !default; - -//** Popover title background color -$popover-title-bg: darken($popover-bg, 3%) !default; - -//** Popover arrow width -$popover-arrow-width: 10px !default; -//** Popover arrow color -$popover-arrow-color: $popover-bg !default; - -//** Popover outer arrow width -$popover-arrow-outer-width: ($popover-arrow-width + 1) !default; -//** Popover outer arrow color -$popover-arrow-outer-color: fade_in($popover-border-color, 0.05) !default; -//** Popover outer arrow fallback color -$popover-arrow-outer-fallback-color: darken($popover-fallback-border-color, 20%) !default; - - -//== Labels -// -//## - -//** Default label background color -$label-default-bg: $gray-light !default; -//** Primary label background color -$label-primary-bg: $brand-primary !default; -//** Success label background color -$label-success-bg: $brand-success !default; -//** Info label background color -$label-info-bg: $brand-info !default; -//** Warning label background color -$label-warning-bg: $brand-warning !default; -//** Danger label background color -$label-danger-bg: $brand-danger !default; - -//** Default label text color -$label-color: #fff !default; -//** Default text color of a linked label -$label-link-hover-color: #fff !default; - - -//== Modals -// -//## - -//** Padding applied to the modal body -$modal-inner-padding: 15px !default; - -//** Padding applied to the modal title -$modal-title-padding: 15px !default; -//** Modal title line-height -$modal-title-line-height: $line-height-base !default; - -//** Background color of modal content area -$modal-content-bg: #fff !default; -//** Modal content border color -$modal-content-border-color: rgba(0,0,0,.2) !default; -//** Modal content border color **for IE8** -$modal-content-fallback-border-color: #999 !default; - -//** Modal backdrop background color -$modal-backdrop-bg: #000 !default; -//** Modal backdrop opacity -$modal-backdrop-opacity: .5 !default; -//** Modal header border color -$modal-header-border-color: #e5e5e5 !default; -//** Modal footer border color -$modal-footer-border-color: $modal-header-border-color !default; - -$modal-lg: 900px !default; -$modal-md: 600px !default; -$modal-sm: 300px !default; - - -//== Alerts -// -//## Define alert colors, border radius, and padding. - -$alert-padding: 15px !default; -$alert-border-radius: $border-radius-base !default; -$alert-link-font-weight: bold !default; - -$alert-success-bg: $state-success-bg !default; -$alert-success-text: $state-success-text !default; -$alert-success-border: $state-success-border !default; - -$alert-info-bg: $state-info-bg !default; -$alert-info-text: $state-info-text !default; -$alert-info-border: $state-info-border !default; - -$alert-warning-bg: $state-warning-bg !default; -$alert-warning-text: $state-warning-text !default; -$alert-warning-border: $state-warning-border !default; - -$alert-danger-bg: $state-danger-bg !default; -$alert-danger-text: $state-danger-text !default; -$alert-danger-border: $state-danger-border !default; - - -//== Progress bars -// -//## - -//** Background color of the whole progress component -$progress-bg: #f5f5f5 !default; -//** Progress bar text color -$progress-bar-color: #fff !default; -//** Variable for setting rounded corners on progress bar. -$progress-border-radius: $border-radius-base !default; - -//** Default progress bar color -$progress-bar-bg: $brand-primary !default; -//** Success progress bar color -$progress-bar-success-bg: $brand-success !default; -//** Warning progress bar color -$progress-bar-warning-bg: $brand-warning !default; -//** Danger progress bar color -$progress-bar-danger-bg: $brand-danger !default; -//** Info progress bar color -$progress-bar-info-bg: $brand-info !default; - - -//== List group -// -//## - -//** Background color on `.list-group-item` -$list-group-bg: #fff !default; -//** `.list-group-item` border color -$list-group-border: #ddd !default; -//** List group border radius -$list-group-border-radius: $border-radius-base !default; - -//** Background color of single list items on hover -$list-group-hover-bg: #f5f5f5 !default; -//** Text color of active list items -$list-group-active-color: $component-active-color !default; -//** Background color of active list items -$list-group-active-bg: $component-active-bg !default; -//** Border color of active list elements -$list-group-active-border: $list-group-active-bg !default; -//** Text color for content within active list items -$list-group-active-text-color: lighten($list-group-active-bg, 40%) !default; - -//** Text color of disabled list items -$list-group-disabled-color: $gray-light !default; -//** Background color of disabled list items -$list-group-disabled-bg: $gray-lighter !default; -//** Text color for content within disabled list items -$list-group-disabled-text-color: $list-group-disabled-color !default; - -$list-group-link-color: #555 !default; -$list-group-link-hover-color: $list-group-link-color !default; -$list-group-link-heading-color: #333 !default; - - -//== Panels -// -//## - -$panel-bg: #fff !default; -$panel-body-padding: 15px !default; -$panel-heading-padding: 10px 15px !default; -$panel-footer-padding: $panel-heading-padding !default; -$panel-border-radius: $border-radius-base !default; - -//** Border color for elements within panels -$panel-inner-border: #ddd !default; -$panel-footer-bg: #f5f5f5 !default; - -$panel-default-text: $gray-dark !default; -$panel-default-border: #ddd !default; -$panel-default-heading-bg: #f5f5f5 !default; - -$panel-primary-text: #fff !default; -$panel-primary-border: $brand-primary !default; -$panel-primary-heading-bg: $brand-primary !default; - -$panel-success-text: $state-success-text !default; -$panel-success-border: $state-success-border !default; -$panel-success-heading-bg: $state-success-bg !default; - -$panel-info-text: $state-info-text !default; -$panel-info-border: $state-info-border !default; -$panel-info-heading-bg: $state-info-bg !default; - -$panel-warning-text: $state-warning-text !default; -$panel-warning-border: $state-warning-border !default; -$panel-warning-heading-bg: $state-warning-bg !default; - -$panel-danger-text: $state-danger-text !default; -$panel-danger-border: $state-danger-border !default; -$panel-danger-heading-bg: $state-danger-bg !default; - - -//== Thumbnails -// -//## - -//** Padding around the thumbnail image -$thumbnail-padding: 4px !default; -//** Thumbnail background color -$thumbnail-bg: $body-bg !default; -//** Thumbnail border color -$thumbnail-border: #ddd !default; -//** Thumbnail border radius -$thumbnail-border-radius: $border-radius-base !default; - -//** Custom text color for thumbnail captions -$thumbnail-caption-color: $text-color !default; -//** Padding around the thumbnail caption -$thumbnail-caption-padding: 9px !default; - - -//== Wells -// -//## - -$well-bg: #f5f5f5 !default; -$well-border: darken($well-bg, 7%) !default; - - -//== Badges -// -//## - -$badge-color: #fff !default; -//** Linked badge text color on hover -$badge-link-hover-color: #fff !default; -$badge-bg: $gray-light !default; - -//** Badge text color in active nav link -$badge-active-color: $link-color !default; -//** Badge background color in active nav link -$badge-active-bg: #fff !default; - -$badge-font-weight: bold !default; -$badge-line-height: 1 !default; -$badge-border-radius: 10px !default; - - -//== Breadcrumbs -// -//## - -$breadcrumb-padding-vertical: 8px !default; -$breadcrumb-padding-horizontal: 15px !default; -//** Breadcrumb background color -$breadcrumb-bg: #f5f5f5 !default; -//** Breadcrumb text color -$breadcrumb-color: #ccc !default; -//** Text color of current page in the breadcrumb -$breadcrumb-active-color: $gray-light !default; -//** Textual separator for between breadcrumb elements -$breadcrumb-separator: "/" !default; - - -//== Carousel -// -//## - -$carousel-text-shadow: 0 1px 2px rgba(0,0,0,.6) !default; - -$carousel-control-color: #fff !default; -$carousel-control-width: 15% !default; -$carousel-control-opacity: .5 !default; -$carousel-control-font-size: 20px !default; - -$carousel-indicator-active-bg: #fff !default; -$carousel-indicator-border-color: #fff !default; - -$carousel-caption-color: #fff !default; - - -//== Close -// -//## - -$close-font-weight: bold !default; -$close-color: #000 !default; -$close-text-shadow: 0 1px 0 #fff !default; - - -//== Code -// -//## - -$code-color: #c7254e !default; -$code-bg: #f9f2f4 !default; - -$kbd-color: #fff !default; -$kbd-bg: #333 !default; - -$pre-bg: #f5f5f5 !default; -$pre-color: $gray-dark !default; -$pre-border-color: #ccc !default; -$pre-scrollable-max-height: 340px !default; - - -//== Type -// -//## - -//** Horizontal offset for forms and lists. -$component-offset-horizontal: 180px !default; -//** Text muted color -$text-muted: $gray-light !default; -//** Abbreviations and acronyms border color -$abbr-border-color: $gray-light !default; -//** Headings small color -$headings-small-color: $gray-light !default; -//** Blockquote small color -$blockquote-small-color: $gray-light !default; -//** Blockquote font size -$blockquote-font-size: ($font-size-base * 1.25) !default; -//** Blockquote border color -$blockquote-border-color: $gray-lighter !default; -//** Page header border color -$page-header-border-color: $gray-lighter !default; -//** Width of horizontal description list titles -$dl-horizontal-offset: $component-offset-horizontal !default; -//** Point at which .dl-horizontal becomes horizontal -$dl-horizontal-breakpoint: $grid-float-breakpoint !default; -//** Horizontal line color. -$hr-border: $gray-lighter !default; diff --git a/_sass/bootstrap/_variables.scss b/_sass/bootstrap/_variables.scss deleted file mode 100644 index 26e7e3be..00000000 --- a/_sass/bootstrap/_variables.scss +++ /dev/null @@ -1,870 +0,0 @@ -$bootstrap-sass-asset-helper: false !default; -// Lumen 3.3.7 -// Variables -// -------------------------------------------------- - - -//== Colors -// -//## Gray and brand colors for use across Bootstrap. - -$gray-base: #000 !default; -$gray-darker: lighten($gray-base, 13.5%) !default; // #222 -$gray-dark: lighten($gray-base, 20%) !default; // #333 -$gray: lighten($gray-base, 33.5%) !default; // #555 -$gray-light: lighten($gray-base, 60%) !default; // #999 -$gray-lighter: lighten($gray-base, 93.5%) !default; // #eee - -$brand-primary: #158CBA !default; -$brand-success: #28B62C !default; -$brand-info: #75CAEB !default; -$brand-warning: #FF851B !default; -$brand-danger: #FF4136 !default; - - -//== Scaffolding -// -//## Settings for some of the most global styles. - -//** Background color for ``. -$body-bg: #fff !default; -//** Global text color on ``. -$text-color: $gray !default; - -//** Global textual link color. -$link-color: $brand-primary !default; -//** Link hover color set via `darken()` function. -$link-hover-color: $link-color !default; -//** Link hover decoration. -$link-hover-decoration: underline !default; - - -//== Typography -// -//## Font, line-height, and color for body text, headings, and more. - -$font-family-sans-serif: "Source Sans Pro", "Helvetica Neue", Helvetica, Arial, sans-serif !default; -$font-family-serif: Georgia, "Times New Roman", Times, serif !default; -//** Default monospace fonts for ``, ``, and `
`.
-$font-family-monospace:   Menlo, Monaco, Consolas, "Courier New", monospace !default;
-$font-family-base:        $font-family-sans-serif !default;
-
-$font-size-base:          16px !default;
-$font-size-large:         ceil(($font-size-base * 1.25)) !default; // ~18px
-$font-size-small:         ceil(($font-size-base * 0.85)) !default; // ~12px
-
-$font-size-h1:            floor(($font-size-base * 2.6)) !default; // ~36px
-$font-size-h2:            floor(($font-size-base * 2.15)) !default; // ~30px
-$font-size-h3:            ceil(($font-size-base * 1.7)) !default; // ~24px
-$font-size-h4:            ceil(($font-size-base * 1.25)) !default; // ~18px
-$font-size-h5:            $font-size-base !default;
-$font-size-h6:            ceil(($font-size-base * 0.85)) !default; // ~12px
-
-//** Unit-less `line-height` for use in components like buttons.
-$line-height-base:        1.428571429 !default; // 20/14
-//** Computed "line-height" (`font-size` * `line-height`) for use with `margin`, `padding`, etc.
-$line-height-computed:    floor(($font-size-base * $line-height-base)) !default; // ~20px
-
-//** By default, this inherits from the ``.
-$headings-font-family:    inherit !default;
-$headings-font-weight:    400 !default;
-$headings-line-height:    1.1 !default;
-$headings-color:          $gray-dark !default;
-
-
-//== Iconography
-//
-//## Specify custom location and filename of the included Glyphicons icon font. Useful for those including Bootstrap via Bower.
-
-//** Load fonts from this directory.
-$icon-font-path: if($bootstrap-sass-asset-helper, "bootstrap/", "../fonts/") !default;
-//** File name for all font files.
-$icon-font-name:          "glyphicons-halflings-regular" !default;
-//** Element ID within SVG icon file.
-$icon-font-svg-id:        "glyphicons_halflingsregular" !default;
-
-
-//== Components
-//
-//## Define common padding and border radius sizes and more. Values based on 14px text and 1.428 line-height (~20px to start).
-
-$padding-base-vertical:     7px !default;
-$padding-base-horizontal:   12px !default;
-
-$padding-large-vertical:    13px !default;
-$padding-large-horizontal:  16px !default;
-
-$padding-small-vertical:    4px !default;
-$padding-small-horizontal:  10px !default;
-
-$padding-xs-vertical:       1px !default;
-$padding-xs-horizontal:     5px !default;
-
-$line-height-large:         1.3333333 !default; // extra decimals for Win 8.1 Chrome
-$line-height-small:         1.5 !default;
-
-$border-radius-base:        4px !default;
-$border-radius-large:       5px !default;
-$border-radius-small:       2px !default;
-
-//** Global color for active items (e.g., navs or dropdowns).
-$component-active-color:    #fff !default;
-//** Global background color for active items (e.g., navs or dropdowns).
-$component-active-bg:       $brand-primary !default;
-
-//** Width of the `border` for generating carets that indicate dropdowns.
-$caret-width-base:          4px !default;
-//** Carets increase slightly in size for larger components.
-$caret-width-large:         5px !default;
-
-
-//== Tables
-//
-//## Customizes the `.table` component with basic values, each used across all table variations.
-
-//** Padding for ``s and ``s.
-$table-cell-padding:            8px !default;
-//** Padding for cells in `.table-condensed`.
-$table-condensed-cell-padding:  5px !default;
-
-//** Default background color used for all tables.
-$table-bg:                      transparent !default;
-//** Background color used for `.table-striped`.
-$table-bg-accent:               #f9f9f9 !default;
-//** Background color used for `.table-hover`.
-$table-bg-hover:                #f5f5f5 !default;
-$table-bg-active:               $table-bg-hover !default;
-
-//** Border color for table and cell borders.
-$table-border-color:            $gray-lighter !default;
-
-
-//== Buttons
-//
-//## For each of Bootstrap's buttons, define text, background and border color.
-
-$btn-font-weight:                normal !default;
-
-$btn-default-color:              $gray !default;
-$btn-default-bg:                 $gray-lighter !default;
-$btn-default-border:             darken($btn-default-bg, 5%) !default;
-
-$btn-primary-color:              #fff !default;
-$btn-primary-bg:                 $brand-primary !default;
-$btn-primary-border:             darken($btn-primary-bg, 5%) !default;
-
-$btn-success-color:              #fff !default;
-$btn-success-bg:                 $brand-success !default;
-$btn-success-border:             darken($btn-success-bg, 5%) !default;
-
-$btn-info-color:                 #fff !default;
-$btn-info-bg:                    $brand-info !default;
-$btn-info-border:                darken($btn-info-bg, 5%) !default;
-
-$btn-warning-color:              #fff !default;
-$btn-warning-bg:                 $brand-warning !default;
-$btn-warning-border:             darken($btn-warning-bg, 5%) !default;
-
-$btn-danger-color:               #fff !default;
-$btn-danger-bg:                  $brand-danger !default;
-$btn-danger-border:              darken($btn-danger-bg, 5%) !default;
-
-$btn-link-disabled-color:        $gray-light !default;
-
-// Allows for customizing button radius independently from global border radius
-$btn-border-radius-base:         $border-radius-base !default;
-$btn-border-radius-large:        $border-radius-large !default;
-$btn-border-radius-small:        $border-radius-small !default;
-
-
-//== Forms
-//
-//##
-
-//** `` background color
-$input-bg:                       #fff !default;
-//** `` background color
-$input-bg-disabled:              $gray-lighter !default;
-
-//** Text color for ``s
-$input-color:                    $gray !default;
-//** `` border color
-$input-border:                   darken(#f8f8f8, 6.5%) !default;
-
-// TODO: Rename `$input-border-radius` to `$input-border-radius-base` in v4
-//** Default `.form-control` border radius
-// This has no effect on ``s in CSS.
-$input-border-radius:            $border-radius-base !default;
-//** Large `.form-control` border radius
-$input-border-radius-large:      $border-radius-large !default;
-//** Small `.form-control` border radius
-$input-border-radius-small:      $border-radius-small !default;
-
-//** Border color for inputs on focus
-$input-border-focus:             #66afe9 !default;
-
-//** Placeholder text color
-$input-color-placeholder:        $gray-light !default;
-
-//** Default `.form-control` height
-$input-height-base:              ($line-height-computed + ($padding-base-vertical * 2) + 4) !default;
-//** Large `.form-control` height
-$input-height-large:             (ceil($font-size-large * $line-height-large) + ($padding-large-vertical * 2) + 2) !default;
-//** Small `.form-control` height
-$input-height-small:             (floor($font-size-small * $line-height-small) + ($padding-small-vertical * 2) + 2) !default;
-
-//** `.form-group` margin
-$form-group-margin-bottom:       15px !default;
-
-$legend-color:                   $gray-dark !default;
-$legend-border-color:            #e5e5e5 !default;
-
-//** Background color for textual input addons
-$input-group-addon-bg:           $gray-lighter !default;
-//** Border color for textual input addons
-$input-group-addon-border-color: $input-border !default;
-
-//** Disabled cursor for form controls and buttons.
-$cursor-disabled:                not-allowed !default;
-
-
-//== Dropdowns
-//
-//## Dropdown menu container and contents.
-
-//** Background for the dropdown menu.
-$dropdown-bg:                    #fff !default;
-//** Dropdown menu `border-color`.
-$dropdown-border:                $input-border !default;
-//** Dropdown menu `border-color` **for IE8**.
-$dropdown-fallback-border:       #ccc !default;
-//** Divider color for between dropdown items.
-$dropdown-divider-bg:            $gray-lighter !default;
-
-//** Dropdown link text color.
-$dropdown-link-color:            $gray-light !default;
-//** Hover color for dropdown links.
-$dropdown-link-hover-color:      $gray-dark !default;
-//** Hover background for dropdown links.
-$dropdown-link-hover-bg:         transparent !default;
-
-//** Active dropdown menu item text color.
-$dropdown-link-active-color:     $component-active-color !default;
-//** Active dropdown menu item background color.
-$dropdown-link-active-bg:        $component-active-bg !default;
-
-//** Disabled dropdown menu item background color.
-$dropdown-link-disabled-color:   $gray-lighter !default;
-
-//** Text color for headers within dropdown menus.
-$dropdown-header-color:          $gray-light !default;
-
-//** Deprecated `$dropdown-caret-color` as of v3.1.0
-$dropdown-caret-color:           #000 !default;
-
-
-//-- Z-index master list
-//
-// Warning: Avoid customizing these values. They're used for a bird's eye view
-// of components dependent on the z-axis and are designed to all work together.
-//
-// Note: These variables are not generated into the Customizer.
-
-$zindex-navbar:            1000 !default;
-$zindex-dropdown:          1000 !default;
-$zindex-popover:           1060 !default;
-$zindex-tooltip:           1070 !default;
-$zindex-navbar-fixed:      1030 !default;
-$zindex-modal-background:  1040 !default;
-$zindex-modal:             1050 !default;
-
-
-//== Media queries breakpoints
-//
-//## Define the breakpoints at which your layout will change, adapting to different screen sizes.
-
-// Extra small screen / phone
-//** Deprecated `$screen-xs` as of v3.0.1
-$screen-xs:                  480px !default;
-//** Deprecated `$screen-xs-min` as of v3.2.0
-$screen-xs-min:              $screen-xs !default;
-//** Deprecated `$screen-phone` as of v3.0.1
-$screen-phone:               $screen-xs-min !default;
-
-// Small screen / tablet
-//** Deprecated `$screen-sm` as of v3.0.1
-$screen-sm:                  768px !default;
-$screen-sm-min:              $screen-sm !default;
-//** Deprecated `$screen-tablet` as of v3.0.1
-$screen-tablet:              $screen-sm-min !default;
-
-// Medium screen / desktop
-//** Deprecated `$screen-md` as of v3.0.1
-$screen-md:                  992px !default;
-$screen-md-min:              $screen-md !default;
-//** Deprecated `$screen-desktop` as of v3.0.1
-$screen-desktop:             $screen-md-min !default;
-
-// Large screen / wide desktop
-//** Deprecated `$screen-lg` as of v3.0.1
-$screen-lg:                  200px !default;
-$screen-lg-min:              $screen-lg !default;
-//** Deprecated `$screen-lg-desktop` as of v3.0.1
-$screen-lg-desktop:          $screen-lg-min !default;
-
-// So media queries don't overlap when required, provide a maximum
-$screen-xs-max:              ($screen-sm-min - 1) !default;
-$screen-sm-max:              ($screen-md-min - 1) !default;
-$screen-md-max:              ($screen-lg-min - 1) !default;
-
-
-//== Grid system
-//
-//## Define your custom responsive grid.
-
-//** Number of columns in the grid.
-$grid-columns:              12 !default;
-//** Padding between columns. Gets divided in half for the left and right.
-$grid-gutter-width:         30px !default;
-// Navbar collapse
-//** Point at which the navbar becomes uncollapsed.
-$grid-float-breakpoint:     $screen-sm-min !default;
-//** Point at which the navbar begins collapsing.
-$grid-float-breakpoint-max: ($grid-float-breakpoint - 1) !default;
-
-
-//== Container sizes
-//
-//## Define the maximum width of `.container` for different screen sizes.
-
-// Small screen / tablet
-$container-tablet:             (720px + $grid-gutter-width) !default;
-//** For `$screen-sm-min` and up.
-$container-sm:                 $container-tablet !default;
-
-// Medium screen / desktop
-$container-desktop:            (940px + $grid-gutter-width) !default;
-//** For `$screen-md-min` and up.
-$container-md:                 $container-desktop !default;
-
-// Large screen / wide desktop
-$container-large-desktop:      (1140px + $grid-gutter-width) !default;
-//** For `$screen-lg-min` and up.
-$container-lg:                 $container-large-desktop !default;
-
-
-//== Navbar
-//
-//##
-
-// Basics of a navbar
-$navbar-height:                    50px !default;
-$navbar-margin-bottom:             $line-height-computed !default;
-$navbar-border-radius:             $border-radius-base !default;
-$navbar-padding-horizontal:        floor(($grid-gutter-width / 2)) !default;
-$navbar-padding-vertical:          (($navbar-height - $line-height-computed) / 2) !default;
-$navbar-collapse-max-height:       340px !default;
-
-$navbar-default-color:             $text-color !default;
-$navbar-default-bg:                #f8f8f8 !default;
-$navbar-default-border:            $input-border !default;
-
-// Navbar links
-$navbar-default-link-color:                $gray-light !default;
-$navbar-default-link-hover-color:          $gray-dark !default;
-$navbar-default-link-hover-bg:             transparent !default;
-$navbar-default-link-active-color:         $navbar-default-link-hover-color !default;
-$navbar-default-link-active-bg:            transparent !default;
-$navbar-default-link-disabled-color:       $gray-lighter !default;
-$navbar-default-link-disabled-bg:          transparent !default;
-
-// Navbar brand label
-$navbar-default-brand-color:               $navbar-default-link-hover-color !default;
-$navbar-default-brand-hover-color:         $navbar-default-link-hover-color !default;
-$navbar-default-brand-hover-bg:            transparent !default;
-
-// Navbar toggle
-$navbar-default-toggle-hover-bg:           #fff !default;
-$navbar-default-toggle-icon-bar-bg:        $gray-light !default;
-$navbar-default-toggle-border-color:       $gray-lighter !default;
-
-
-//=== Inverted navbar
-// Reset inverted navbar basics
-$navbar-inverse-color:                      $gray-light !default;
-$navbar-inverse-bg:                         #fff !default;
-$navbar-inverse-border:                     darken($navbar-inverse-bg, 10%) !default;
-
-// Inverted navbar links
-$navbar-inverse-link-color:                 $gray-light !default;
-$navbar-inverse-link-hover-color:           $gray-dark !default;
-$navbar-inverse-link-hover-bg:              transparent !default;
-$navbar-inverse-link-active-color:          $navbar-inverse-link-hover-color !default;
-$navbar-inverse-link-active-bg:             transparent !default;
-$navbar-inverse-link-disabled-color:        $gray-lighter !default;
-$navbar-inverse-link-disabled-bg:           transparent !default;
-
-// Inverted navbar brand label
-$navbar-inverse-brand-color:                $navbar-inverse-link-color !default;
-$navbar-inverse-brand-hover-color:          $navbar-inverse-link-hover-color !default;
-$navbar-inverse-brand-hover-bg:             transparent !default;
-
-// Inverted navbar toggle
-$navbar-inverse-toggle-hover-bg:            $gray-lighter !default;
-$navbar-inverse-toggle-icon-bar-bg:         $gray-light !default;
-$navbar-inverse-toggle-border-color:        $gray-lighter !default;
-
-
-//== Navs
-//
-//##
-
-//=== Shared nav styles
-$nav-link-padding:                          10px 15px !default;
-$nav-link-hover-bg:                         #fff !default;
-
-$nav-disabled-link-color:                   $gray-light !default;
-$nav-disabled-link-hover-color:             $gray-light !default;
-
-//== Tabs
-$nav-tabs-border-color:                     $navbar-default-border !default;
-
-$nav-tabs-link-hover-border-color:          $gray-lighter !default;
-
-$nav-tabs-active-link-hover-bg:             #fff !default;
-$nav-tabs-active-link-hover-color:          $gray !default;
-$nav-tabs-active-link-hover-border-color:   $nav-tabs-border-color !default;
-
-$nav-tabs-justified-link-border-color:            $nav-tabs-border-color !default;
-$nav-tabs-justified-active-link-border-color:     $body-bg !default;
-
-//== Pills
-$nav-pills-border-radius:                   $border-radius-base !default;
-$nav-pills-active-link-hover-bg:            $component-active-bg !default;
-$nav-pills-active-link-hover-color:         $component-active-color !default;
-
-
-//== Pagination
-//
-//##
-
-$pagination-color:                     $btn-default-color !default;
-$pagination-bg:                        $btn-default-bg !default;
-$pagination-border:                    $btn-default-border !default;
-
-$pagination-hover-color:               $pagination-color !default;
-$pagination-hover-bg:                  $pagination-bg !default;
-$pagination-hover-border:              $pagination-border !default;
-
-$pagination-active-color:              #fff !default;
-$pagination-active-bg:                 $brand-primary !default;
-$pagination-active-border:             $btn-primary-border !default;
-
-$pagination-disabled-color:            $gray-light !default;
-$pagination-disabled-bg:               $pagination-bg !default;
-$pagination-disabled-border:           $pagination-border !default;
-
-
-//== Pager
-//
-//##
-
-$pager-bg:                             $pagination-bg !default;
-$pager-border:                         $pagination-border !default;
-$pager-border-radius:                  15px !default;
-
-$pager-hover-bg:                       $pagination-hover-bg !default;
-
-$pager-active-bg:                      $pagination-active-bg !default;
-$pager-active-color:                   $pagination-active-color !default;
-
-$pager-disabled-color:                 $pagination-disabled-color !default;
-
-
-//== Jumbotron
-//
-//##
-
-$jumbotron-padding:              30px !default;
-$jumbotron-color:                inherit !default;
-$jumbotron-bg:                   #fafafa !default;
-$jumbotron-heading-color:        inherit !default;
-$jumbotron-font-size:            ceil(($font-size-base * 1.5)) !default;
-$jumbotron-heading-font-size:    ceil(($font-size-base * 4.5)) !default;
-
-
-//== Form states and alerts
-//
-//## Define colors for form feedback states and, by default, alerts.
-
-$state-success-text:             #fff !default;
-$state-success-bg:               $brand-success !default;
-$state-success-border:           darken($state-success-bg, 4%) !default;
-
-$state-info-text:                #fff !default;
-$state-info-bg:                  $brand-info !default;
-$state-info-border:              darken($state-info-bg, 12%) !default;
-
-$state-warning-text:             #fff !default;
-$state-warning-bg:               $brand-warning !default;
-$state-warning-border:           darken($state-warning-bg, 5%) !default;
-
-$state-danger-text:              #fff !default;
-$state-danger-bg:                $brand-danger !default;
-$state-danger-border:            darken($state-danger-bg, 10%) !default;
-
-
-//== Tooltips
-//
-//##
-
-//** Tooltip max width
-$tooltip-max-width:           200px !default;
-//** Tooltip text color
-$tooltip-color:               #fff !default;
-//** Tooltip background color
-$tooltip-bg:                  #000 !default;
-$tooltip-opacity:             .9 !default;
-
-//** Tooltip arrow width
-$tooltip-arrow-width:         5px !default;
-//** Tooltip arrow color
-$tooltip-arrow-color:         $tooltip-bg !default;
-
-
-//== Popovers
-//
-//##
-
-//** Popover body background color
-$popover-bg:                          #fff !default;
-//** Popover maximum width
-$popover-max-width:                   276px !default;
-//** Popover border color
-$popover-border-color:                rgba(0,0,0,.2) !default;
-//** Popover fallback border color
-$popover-fallback-border-color:       #ccc !default;
-
-//** Popover title background color
-$popover-title-bg:                    darken($popover-bg, 3%) !default;
-
-//** Popover arrow width
-$popover-arrow-width:                 10px !default;
-//** Popover arrow color
-$popover-arrow-color:                 $popover-bg !default;
-
-//** Popover outer arrow width
-$popover-arrow-outer-width:           ($popover-arrow-width + 1) !default;
-//** Popover outer arrow color
-$popover-arrow-outer-color:           fadein($popover-border-color, 5%) !default;
-//** Popover outer arrow fallback color
-$popover-arrow-outer-fallback-color:  darken($popover-fallback-border-color, 20%) !default;
-
-
-//== Labels
-//
-//##
-
-//** Default label background color
-$label-default-bg:            $gray-light !default;
-//** Primary label background color
-$label-primary-bg:            $brand-primary !default;
-//** Success label background color
-$label-success-bg:            $brand-success !default;
-//** Info label background color
-$label-info-bg:               $brand-info !default;
-//** Warning label background color
-$label-warning-bg:            $brand-warning !default;
-//** Danger label background color
-$label-danger-bg:             $brand-danger !default;
-
-//** Default label text color
-$label-color:                 #fff !default;
-//** Default text color of a linked label
-$label-link-hover-color:      #fff !default;
-
-
-//== Modals
-//
-//##
-
-//** Padding applied to the modal body
-$modal-inner-padding:         20px !default;
-
-//** Padding applied to the modal title
-$modal-title-padding:         15px !default;
-//** Modal title line-height
-$modal-title-line-height:     $line-height-base !default;
-
-//** Background color of modal content area
-$modal-content-bg:                             #fff !default;
-//** Modal content border color
-$modal-content-border-color:                   rgba(0,0,0,.05) !default;
-//** Modal content border color **for IE8**
-$modal-content-fallback-border-color:          $gray-lighter !default;
-
-//** Modal backdrop background color
-$modal-backdrop-bg:           #000 !default;
-//** Modal backdrop opacity
-$modal-backdrop-opacity:      .5 !default;
-//** Modal header border color
-$modal-header-border-color:   #e5e5e5 !default;
-//** Modal footer border color
-$modal-footer-border-color:   $modal-header-border-color !default;
-
-$modal-lg:                    900px !default;
-$modal-md:                    600px !default;
-$modal-sm:                    300px !default;
-
-
-//== Alerts
-//
-//## Define alert colors, border radius, and padding.
-
-$alert-padding:               15px !default;
-$alert-border-radius:         $border-radius-base !default;
-$alert-link-font-weight:      bold !default;
-
-$alert-success-bg:            $state-success-bg !default;
-$alert-success-text:          $state-success-text !default;
-$alert-success-border:        $state-success-border !default;
-
-$alert-info-bg:               $state-info-bg !default;
-$alert-info-text:             $state-info-text !default;
-$alert-info-border:           $state-info-border !default;
-
-$alert-warning-bg:            $state-warning-bg !default;
-$alert-warning-text:          $state-warning-text !default;
-$alert-warning-border:        $state-warning-border !default;
-
-$alert-danger-bg:             $state-danger-bg !default;
-$alert-danger-text:           $state-danger-text !default;
-$alert-danger-border:         $state-danger-border !default;
-
-
-//== Progress bars
-//
-//##
-
-//** Background color of the whole progress component
-$progress-bg:                 $jumbotron-bg !default;
-//** Progress bar text color
-$progress-bar-color:          #fff !default;
-//** Variable for setting rounded corners on progress bar.
-$progress-border-radius:      $border-radius-base !default;
-
-//** Default progress bar color
-$progress-bar-bg:             $brand-primary !default;
-//** Success progress bar color
-$progress-bar-success-bg:     $brand-success !default;
-//** Warning progress bar color
-$progress-bar-warning-bg:     $brand-warning !default;
-//** Danger progress bar color
-$progress-bar-danger-bg:      $brand-danger !default;
-//** Info progress bar color
-$progress-bar-info-bg:        $brand-info !default;
-
-
-//== List group
-//
-//##
-
-//** Background color on `.list-group-item`
-$list-group-bg:                 #fff !default;
-//** `.list-group-item` border color
-$list-group-border:             $gray-lighter !default;
-//** List group border radius
-$list-group-border-radius:      $border-radius-base !default;
-
-//** Background color of single list items on hover
-$list-group-hover-bg:           #f5f5f5 !default;
-//** Text color of active list items
-$list-group-active-color:       $component-active-color !default;
-//** Background color of active list elements
-$list-group-active-bg:          $component-active-bg !default;
-//** Background color of active list items
-$list-group-active-border:      $list-group-active-bg !default;
-//** Text color for content within active list items
-$list-group-active-text-color:  lighten($list-group-active-bg, 40%) !default;
-
-//** Text color of disabled list items
-$list-group-disabled-color:      $gray-light !default;
-//** Background color of disabled list items
-$list-group-disabled-bg:         $gray-lighter !default;
-//** Text color for content within disabled list items
-$list-group-disabled-text-color: $list-group-disabled-color !default;
-
-$list-group-link-color:         #555 !default;
-$list-group-link-hover-color:   $list-group-link-color !default;
-$list-group-link-heading-color: #333 !default;
-
-
-//== Panels
-//
-//##
-
-$panel-bg:                    #fff !default;
-$panel-body-padding:          15px !default;
-$panel-heading-padding:       10px 15px !default;
-$panel-footer-padding:        $panel-heading-padding !default;
-$panel-border-radius:         $border-radius-base !default;
-
-//** Border color for elements within panels
-$panel-inner-border:          transparent !default;
-$panel-footer-bg:             #f5f5f5 !default;
-
-$panel-default-text:          $gray-dark !default;
-$panel-default-border:        transparent !default;
-$panel-default-heading-bg:    #f5f5f5 !default;
-
-$panel-primary-text:          #fff !default;
-$panel-primary-border:        transparent !default;
-$panel-primary-heading-bg:    $brand-primary !default;
-
-$panel-success-text:          $state-success-text !default;
-$panel-success-border:        transparent !default;
-$panel-success-heading-bg:    $state-success-bg !default;
-
-$panel-info-text:             $state-info-text !default;
-$panel-info-border:           transparent !default;
-$panel-info-heading-bg:       $state-info-bg !default;
-
-$panel-warning-text:          $state-warning-text !default;
-$panel-warning-border:        transparent !default;
-$panel-warning-heading-bg:    $state-warning-bg !default;
-
-$panel-danger-text:           $state-danger-text !default;
-$panel-danger-border:         transparent !default;
-$panel-danger-heading-bg:     $state-danger-bg !default;
-
-
-//== Thumbnails
-//
-//##
-
-//** Padding around the thumbnail image
-$thumbnail-padding:           4px !default;
-//** Thumbnail background color
-$thumbnail-bg:                $body-bg !default;
-//** Thumbnail border color
-$thumbnail-border:            $gray-lighter !default;
-//** Thumbnail border radius
-$thumbnail-border-radius:     $border-radius-base !default;
-
-//** Custom text color for thumbnail captions
-$thumbnail-caption-color:     $text-color !default;
-//** Padding around the thumbnail caption
-$thumbnail-caption-padding:   9px !default;
-
-
-//== Wells
-//
-//##
-
-$well-bg:                     $jumbotron-bg !default;
-$well-border:                 darken($well-bg, 7%) !default;
-
-
-//== Badges
-//
-//##
-
-$badge-color:                 #fff !default;
-//** Linked badge text color on hover
-$badge-link-hover-color:      #fff !default;
-$badge-bg:                    $brand-primary !default;
-
-//** Badge text color in active nav link
-$badge-active-color:          $link-color !default;
-//** Badge background color in active nav link
-$badge-active-bg:             #fff !default;
-
-$badge-font-weight:           normal !default;
-$badge-line-height:           1 !default;
-$badge-border-radius:         10px !default;
-
-
-//== Breadcrumbs
-//
-//##
-
-$breadcrumb-padding-vertical:   8px !default;
-$breadcrumb-padding-horizontal: 15px !default;
-//** Breadcrumb background color
-$breadcrumb-bg:                 $well-bg !default;
-//** Breadcrumb text color
-$breadcrumb-color:              $gray-light !default;
-//** Text color of current page in the breadcrumb
-$breadcrumb-active-color:       $gray-light !default;
-//** Textual separator for between breadcrumb elements
-$breadcrumb-separator:          ">" !default;
-
-
-//== Carousel
-//
-//##
-
-$carousel-text-shadow:                        0 1px 2px rgba(0,0,0,.6) !default;
-
-$carousel-control-color:                      #fff !default;
-$carousel-control-width:                      15% !default;
-$carousel-control-opacity:                    .7 !default;
-$carousel-control-font-size:                  20px !default;
-
-$carousel-indicator-active-bg:                #fff !default;
-$carousel-indicator-border-color:             #fff !default;
-
-$carousel-caption-color:                      #fff !default;
-
-
-//== Close
-//
-//##
-
-$close-font-weight:           bold !default;
-$close-color:                 #fff !default;
-$close-text-shadow:           0 1px 0 #fff !default;
-
-
-//== Code
-//
-//##
-
-$code-color:                  #c7254e !default;
-$code-bg:                     #f9f2f4 !default;
-
-$kbd-color:                   #fff !default;
-$kbd-bg:                      #333 !default;
-
-$pre-bg:                      #f5f5f5 !default;
-$pre-color:                   $gray-dark !default;
-$pre-border-color:            #ccc !default;
-$pre-scrollable-max-height:   340px !default;
-
-
-//== Type
-//
-//##
-
-//** Horizontal offset for forms and lists.
-$component-offset-horizontal: 180px !default;
-//** Text muted color
-$text-muted:                  $gray-light !default;
-//** Abbreviations and acronyms border color
-$abbr-border-color:           $gray-light !default;
-//** Headings small color
-$headings-small-color:        $gray-light !default;
-//** Blockquote small color
-$blockquote-small-color:      $gray-light !default;
-//** Blockquote font size
-$blockquote-font-size:        ($font-size-base * 1.25) !default;
-//** Blockquote border color
-$blockquote-border-color:     $gray-lighter !default;
-//** Page header border color
-$page-header-border-color:    $gray-lighter !default;
-//** Width of horizontal description list titles
-$dl-horizontal-offset:        $component-offset-horizontal !default;
-//** Point at which .dl-horizontal becomes horizontal
-$dl-horizontal-breakpoint:    $grid-float-breakpoint !default;
-//** Horizontal line color.
-$hr-border:                   $gray-lighter !default;
diff --git a/_sass/bootstrap/_wells.scss b/_sass/bootstrap/_wells.scss
deleted file mode 100644
index d7a65258..00000000
--- a/_sass/bootstrap/_wells.scss
+++ /dev/null
@@ -1,67 +0,0 @@
-//
-// Wells
-// --------------------------------------------------
-
-// Customized
-.well-abstract {
-  padding-left: 20px;
-  padding-right: 20px;
-  padding-top: 12px;
-  padding-bottom: 4px;
-  border-radius: 7px;
-  min-height: 1px;
-  // margin-bottom: 10px;
-  margin-top: 15px;
-  background-color: $gray-lighter;
-  border: 2px solid $well-border;
-  @include box-shadow(inset 0 1px 1px rgba(0,0,0,.05));
-  blockquote {
-    border-color: #ddd;
-    border-color: rgba(0,0,0,.15);
-  }
-}
-
-
-.well-bib {
-  padding-left: 20px;
-  padding-right: 20px;
-  padding-top: 6px;
-  padding-bottom: 2px;
-  border-radius: 3px;
-  min-height: 1px;
-  // margin-bottom: 10px;
-  margin-top: 4px;
-  font-size: ($font-size-base - 5);
-  background-color: $gray-lighter;
-  border: 2px solid $well-border;
-  @include box-shadow(inset 0 1px 1px rgba(0,0,0,.05));
-  blockquote {
-    border-color: #ddd;
-    border-color: rgba(0,0,0,.15);
-  }
-}
-
-// Base class
-.well {
-  min-height: 20px;
-  padding: 19px;
-  margin-bottom: 20px;
-  background-color: $well-bg;
-  border: 1px solid $well-border;
-  border-radius: $border-radius-base;
-  @include box-shadow(inset 0 1px 1px rgba(0,0,0,.05));
-  blockquote {
-    border-color: #ddd;
-    border-color: rgba(0,0,0,.15);
-  }
-}
-
-// Sizes
-.well-lg {
-  padding: 24px;
-  border-radius: $border-radius-large;
-}
-.well-sm {
-  padding: 9px;
-  border-radius: $border-radius-small;
-}
diff --git a/_sass/bootstrap/mixins/_alerts.scss b/_sass/bootstrap/mixins/_alerts.scss
deleted file mode 100644
index 3faf0b5a..00000000
--- a/_sass/bootstrap/mixins/_alerts.scss
+++ /dev/null
@@ -1,14 +0,0 @@
-// Alerts
-
-@mixin alert-variant($background, $border, $text-color) {
-  background-color: $background;
-  border-color: $border;
-  color: $text-color;
-
-  hr {
-    border-top-color: darken($border, 5%);
-  }
-  .alert-link {
-    color: darken($text-color, 10%);
-  }
-}
diff --git a/_sass/bootstrap/mixins/_background-variant.scss b/_sass/bootstrap/mixins/_background-variant.scss
deleted file mode 100644
index 4c7769e1..00000000
--- a/_sass/bootstrap/mixins/_background-variant.scss
+++ /dev/null
@@ -1,12 +0,0 @@
-// Contextual backgrounds
-
-// [converter] $parent hack
-@mixin bg-variant($parent, $color) {
-  #{$parent} {
-    background-color: $color;
-  }
-  a#{$parent}:hover,
-  a#{$parent}:focus {
-    background-color: darken($color, 10%);
-  }
-}
diff --git a/_sass/bootstrap/mixins/_border-radius.scss b/_sass/bootstrap/mixins/_border-radius.scss
deleted file mode 100644
index ce194998..00000000
--- a/_sass/bootstrap/mixins/_border-radius.scss
+++ /dev/null
@@ -1,18 +0,0 @@
-// Single side border-radius
-
-@mixin border-top-radius($radius) {
-  border-top-right-radius: $radius;
-   border-top-left-radius: $radius;
-}
-@mixin border-right-radius($radius) {
-  border-bottom-right-radius: $radius;
-     border-top-right-radius: $radius;
-}
-@mixin border-bottom-radius($radius) {
-  border-bottom-right-radius: $radius;
-   border-bottom-left-radius: $radius;
-}
-@mixin border-left-radius($radius) {
-  border-bottom-left-radius: $radius;
-     border-top-left-radius: $radius;
-}
diff --git a/_sass/bootstrap/mixins/_buttons.scss b/_sass/bootstrap/mixins/_buttons.scss
deleted file mode 100644
index b93f84b2..00000000
--- a/_sass/bootstrap/mixins/_buttons.scss
+++ /dev/null
@@ -1,65 +0,0 @@
-// Button variants
-//
-// Easily pump out default styles, as well as :hover, :focus, :active,
-// and disabled options for all buttons
-
-@mixin button-variant($color, $background, $border) {
-  color: $color;
-  background-color: $background;
-  border-color: $border;
-
-  &:focus,
-  &.focus {
-    color: $color;
-    background-color: darken($background, 10%);
-        border-color: darken($border, 25%);
-  }
-  &:hover {
-    color: $color;
-    background-color: darken($background, 10%);
-        border-color: darken($border, 12%);
-  }
-  &:active,
-  &.active,
-  .open > &.dropdown-toggle {
-    color: $color;
-    background-color: darken($background, 10%);
-        border-color: darken($border, 12%);
-
-    &:hover,
-    &:focus,
-    &.focus {
-      color: $color;
-      background-color: darken($background, 17%);
-          border-color: darken($border, 25%);
-    }
-  }
-  &:active,
-  &.active,
-  .open > &.dropdown-toggle {
-    background-image: none;
-  }
-  &.disabled,
-  &[disabled],
-  fieldset[disabled] & {
-    &:hover,
-    &:focus,
-    &.focus {
-      background-color: $background;
-          border-color: $border;
-    }
-  }
-
-  .badge {
-    color: $background;
-    background-color: $color;
-  }
-}
-
-// Button sizes
-@mixin button-size($padding-vertical, $padding-horizontal, $font-size, $line-height, $border-radius) {
-  padding: $padding-vertical $padding-horizontal;
-  font-size: $font-size;
-  line-height: $line-height;
-  border-radius: $border-radius;
-}
diff --git a/_sass/bootstrap/mixins/_center-block.scss b/_sass/bootstrap/mixins/_center-block.scss
deleted file mode 100644
index e06fb5e2..00000000
--- a/_sass/bootstrap/mixins/_center-block.scss
+++ /dev/null
@@ -1,7 +0,0 @@
-// Center-align a block level element
-
-@mixin center-block() {
-  display: block;
-  margin-left: auto;
-  margin-right: auto;
-}
diff --git a/_sass/bootstrap/mixins/_clearfix.scss b/_sass/bootstrap/mixins/_clearfix.scss
deleted file mode 100644
index dc3e2ab4..00000000
--- a/_sass/bootstrap/mixins/_clearfix.scss
+++ /dev/null
@@ -1,22 +0,0 @@
-// Clearfix
-//
-// For modern browsers
-// 1. The space content is one way to avoid an Opera bug when the
-//    contenteditable attribute is included anywhere else in the document.
-//    Otherwise it causes space to appear at the top and bottom of elements
-//    that are clearfixed.
-// 2. The use of `table` rather than `block` is only necessary if using
-//    `:before` to contain the top-margins of child elements.
-//
-// Source: http://nicolasgallagher.com/micro-clearfix-hack/
-
-@mixin clearfix() {
-  &:before,
-  &:after {
-    content: " "; // 1
-    display: table; // 2
-  }
-  &:after {
-    clear: both;
-  }
-}
diff --git a/_sass/bootstrap/mixins/_forms.scss b/_sass/bootstrap/mixins/_forms.scss
deleted file mode 100644
index 277aa5f8..00000000
--- a/_sass/bootstrap/mixins/_forms.scss
+++ /dev/null
@@ -1,88 +0,0 @@
-// Form validation states
-//
-// Used in forms.less to generate the form validation CSS for warnings, errors,
-// and successes.
-
-@mixin form-control-validation($text-color: #555, $border-color: #ccc, $background-color: #f5f5f5) {
-  // Color the label and help text
-  .help-block,
-  .control-label,
-  .radio,
-  .checkbox,
-  .radio-inline,
-  .checkbox-inline,
-  &.radio label,
-  &.checkbox label,
-  &.radio-inline label,
-  &.checkbox-inline label  {
-    color: $text-color;
-  }
-  // Set the border and box shadow on specific inputs to match
-  .form-control {
-    border-color: $border-color;
-    @include box-shadow(inset 0 1px 1px rgba(0,0,0,.075)); // Redeclare so transitions work
-    &:focus {
-      border-color: darken($border-color, 10%);
-      $shadow: inset 0 1px 1px rgba(0,0,0,.075), 0 0 6px lighten($border-color, 20%);
-      @include box-shadow($shadow);
-    }
-  }
-  // Set validation states also for addons
-  .input-group-addon {
-    color: $text-color;
-    border-color: $border-color;
-    background-color: $background-color;
-  }
-  // Optional feedback icon
-  .form-control-feedback {
-    color: $text-color;
-  }
-}
-
-
-// Form control focus state
-//
-// Generate a customized focus state and for any input with the specified color,
-// which defaults to the `$input-border-focus` variable.
-//
-// We highly encourage you to not customize the default value, but instead use
-// this to tweak colors on an as-needed basis. This aesthetic change is based on
-// WebKit's default styles, but applicable to a wider range of browsers. Its
-// usability and accessibility should be taken into account with any change.
-//
-// Example usage: change the default blue border and shadow to white for better
-// contrast against a dark gray background.
-@mixin form-control-focus($color: $input-border-focus) {
-  $color-rgba: rgba(red($color), green($color), blue($color), .6);
-  &:focus {
-    border-color: $color;
-    outline: 0;
-    @include box-shadow(inset 0 1px 1px rgba(0,0,0,.075), 0 0 8px $color-rgba);
-  }
-}
-
-// Form control sizing
-//
-// Relative text size, padding, and border-radii changes for form controls. For
-// horizontal sizing, wrap controls in the predefined grid classes. `` background color\n$input-bg:                       #fff !default;\n//** `` background color\n$input-bg-disabled:              $gray-lighter !default;\n\n//** Text color for ``s\n$input-color:                    $gray !default;\n//** `` border color\n$input-border:                   darken(#f8f8f8, 6.5%) !default;\n\n// TODO: Rename `$input-border-radius` to `$input-border-radius-base` in v4\n//** Default `.form-control` border radius\n// This has no effect on ``s in CSS.\n$input-border-radius:            $border-radius-base !default;\n//** Large `.form-control` border radius\n$input-border-radius-large:      $border-radius-large !default;\n//** Small `.form-control` border radius\n$input-border-radius-small:      $border-radius-small !default;\n\n//** Border color for inputs on focus\n$input-border-focus:             #66afe9 !default;\n\n//** Placeholder text color\n$input-color-placeholder:        $gray-light !default;\n\n//** Default `.form-control` height\n$input-height-base:              ($line-height-computed + ($padding-base-vertical * 2) + 4) !default;\n//** Large `.form-control` height\n$input-height-large:             (ceil($font-size-large * $line-height-large) + ($padding-large-vertical * 2) + 2) !default;\n//** Small `.form-control` height\n$input-height-small:             (floor($font-size-small * $line-height-small) + ($padding-small-vertical * 2) + 2) !default;\n\n//** `.form-group` margin\n$form-group-margin-bottom:       15px !default;\n\n$legend-color:                   $gray-dark !default;\n$legend-border-color:            #e5e5e5 !default;\n\n//** Background color for textual input addons\n$input-group-addon-bg:           $gray-lighter !default;\n//** Border color for textual input addons\n$input-group-addon-border-color: $input-border !default;\n\n//** Disabled cursor for form controls and buttons.\n$cursor-disabled:                not-allowed !default;\n\n\n//== Dropdowns\n//\n//## Dropdown menu container and contents.\n\n//** Background for the dropdown menu.\n$dropdown-bg:                    #fff !default;\n//** Dropdown menu `border-color`.\n$dropdown-border:                $input-border !default;\n//** Dropdown menu `border-color` **for IE8**.\n$dropdown-fallback-border:       #ccc !default;\n//** Divider color for between dropdown items.\n$dropdown-divider-bg:            $gray-lighter !default;\n\n//** Dropdown link text color.\n$dropdown-link-color:            $gray-light !default;\n//** Hover color for dropdown links.\n$dropdown-link-hover-color:      $gray-dark !default;\n//** Hover background for dropdown links.\n$dropdown-link-hover-bg:         transparent !default;\n\n//** Active dropdown menu item text color.\n$dropdown-link-active-color:     $component-active-color !default;\n//** Active dropdown menu item background color.\n$dropdown-link-active-bg:        $component-active-bg !default;\n\n//** Disabled dropdown menu item background color.\n$dropdown-link-disabled-color:   $gray-lighter !default;\n\n//** Text color for headers within dropdown menus.\n$dropdown-header-color:          $gray-light !default;\n\n//** Deprecated `$dropdown-caret-color` as of v3.1.0\n$dropdown-caret-color:           #000 !default;\n\n\n//-- Z-index master list\n//\n// Warning: Avoid customizing these values. They're used for a bird's eye view\n// of components dependent on the z-axis and are designed to all work together.\n//\n// Note: These variables are not generated into the Customizer.\n\n$zindex-navbar:            1000 !default;\n$zindex-dropdown:          1000 !default;\n$zindex-popover:           1060 !default;\n$zindex-tooltip:           1070 !default;\n$zindex-navbar-fixed:      1030 !default;\n$zindex-modal-background:  1040 !default;\n$zindex-modal:             1050 !default;\n\n\n//== Media queries breakpoints\n//\n//## Define the breakpoints at which your layout will change, adapting to different screen sizes.\n\n// Extra small screen / phone\n//** Deprecated `$screen-xs` as of v3.0.1\n$screen-xs:                  480px !default;\n//** Deprecated `$screen-xs-min` as of v3.2.0\n$screen-xs-min:              $screen-xs !default;\n//** Deprecated `$screen-phone` as of v3.0.1\n$screen-phone:               $screen-xs-min !default;\n\n// Small screen / tablet\n//** Deprecated `$screen-sm` as of v3.0.1\n$screen-sm:                  768px !default;\n$screen-sm-min:              $screen-sm !default;\n//** Deprecated `$screen-tablet` as of v3.0.1\n$screen-tablet:              $screen-sm-min !default;\n\n// Medium screen / desktop\n//** Deprecated `$screen-md` as of v3.0.1\n$screen-md:                  992px !default;\n$screen-md-min:              $screen-md !default;\n//** Deprecated `$screen-desktop` as of v3.0.1\n$screen-desktop:             $screen-md-min !default;\n\n// Large screen / wide desktop\n//** Deprecated `$screen-lg` as of v3.0.1\n$screen-lg:                  200px !default;\n$screen-lg-min:              $screen-lg !default;\n//** Deprecated `$screen-lg-desktop` as of v3.0.1\n$screen-lg-desktop:          $screen-lg-min !default;\n\n// So media queries don't overlap when required, provide a maximum\n$screen-xs-max:              ($screen-sm-min - 1) !default;\n$screen-sm-max:              ($screen-md-min - 1) !default;\n$screen-md-max:              ($screen-lg-min - 1) !default;\n\n\n//== Grid system\n//\n//## Define your custom responsive grid.\n\n//** Number of columns in the grid.\n$grid-columns:              12 !default;\n//** Padding between columns. Gets divided in half for the left and right.\n$grid-gutter-width:         30px !default;\n// Navbar collapse\n//** Point at which the navbar becomes uncollapsed.\n$grid-float-breakpoint:     $screen-sm-min !default;\n//** Point at which the navbar begins collapsing.\n$grid-float-breakpoint-max: ($grid-float-breakpoint - 1) !default;\n\n\n//== Container sizes\n//\n//## Define the maximum width of `.container` for different screen sizes.\n\n// Small screen / tablet\n$container-tablet:             (720px + $grid-gutter-width) !default;\n//** For `$screen-sm-min` and up.\n$container-sm:                 $container-tablet !default;\n\n// Medium screen / desktop\n$container-desktop:            (940px + $grid-gutter-width) !default;\n//** For `$screen-md-min` and up.\n$container-md:                 $container-desktop !default;\n\n// Large screen / wide desktop\n$container-large-desktop:      (1140px + $grid-gutter-width) !default;\n//** For `$screen-lg-min` and up.\n$container-lg:                 $container-large-desktop !default;\n\n\n//== Navbar\n//\n//##\n\n// Basics of a navbar\n$navbar-height:                    50px !default;\n$navbar-margin-bottom:             $line-height-computed !default;\n$navbar-border-radius:             $border-radius-base !default;\n$navbar-padding-horizontal:        floor(($grid-gutter-width / 2)) !default;\n$navbar-padding-vertical:          (($navbar-height - $line-height-computed) / 2) !default;\n$navbar-collapse-max-height:       340px !default;\n\n$navbar-default-color:             $text-color !default;\n$navbar-default-bg:                #f8f8f8 !default;\n$navbar-default-border:            $input-border !default;\n\n// Navbar links\n$navbar-default-link-color:                $gray-light !default;\n$navbar-default-link-hover-color:          $gray-dark !default;\n$navbar-default-link-hover-bg:             transparent !default;\n$navbar-default-link-active-color:         $navbar-default-link-hover-color !default;\n$navbar-default-link-active-bg:            transparent !default;\n$navbar-default-link-disabled-color:       $gray-lighter !default;\n$navbar-default-link-disabled-bg:          transparent !default;\n\n// Navbar brand label\n$navbar-default-brand-color:               $navbar-default-link-hover-color !default;\n$navbar-default-brand-hover-color:         $navbar-default-link-hover-color !default;\n$navbar-default-brand-hover-bg:            transparent !default;\n\n// Navbar toggle\n$navbar-default-toggle-hover-bg:           #fff !default;\n$navbar-default-toggle-icon-bar-bg:        $gray-light !default;\n$navbar-default-toggle-border-color:       $gray-lighter !default;\n\n\n//=== Inverted navbar\n// Reset inverted navbar basics\n$navbar-inverse-color:                      $gray-light !default;\n$navbar-inverse-bg:                         #fff !default;\n$navbar-inverse-border:                     darken($navbar-inverse-bg, 10%) !default;\n\n// Inverted navbar links\n$navbar-inverse-link-color:                 $gray-light !default;\n$navbar-inverse-link-hover-color:           $gray-dark !default;\n$navbar-inverse-link-hover-bg:              transparent !default;\n$navbar-inverse-link-active-color:          $navbar-inverse-link-hover-color !default;\n$navbar-inverse-link-active-bg:             transparent !default;\n$navbar-inverse-link-disabled-color:        $gray-lighter !default;\n$navbar-inverse-link-disabled-bg:           transparent !default;\n\n// Inverted navbar brand label\n$navbar-inverse-brand-color:                $navbar-inverse-link-color !default;\n$navbar-inverse-brand-hover-color:          $navbar-inverse-link-hover-color !default;\n$navbar-inverse-brand-hover-bg:             transparent !default;\n\n// Inverted navbar toggle\n$navbar-inverse-toggle-hover-bg:            $gray-lighter !default;\n$navbar-inverse-toggle-icon-bar-bg:         $gray-light !default;\n$navbar-inverse-toggle-border-color:        $gray-lighter !default;\n\n\n//== Navs\n//\n//##\n\n//=== Shared nav styles\n$nav-link-padding:                          10px 15px !default;\n$nav-link-hover-bg:                         #fff !default;\n\n$nav-disabled-link-color:                   $gray-light !default;\n$nav-disabled-link-hover-color:             $gray-light !default;\n\n//== Tabs\n$nav-tabs-border-color:                     $navbar-default-border !default;\n\n$nav-tabs-link-hover-border-color:          $gray-lighter !default;\n\n$nav-tabs-active-link-hover-bg:             #fff !default;\n$nav-tabs-active-link-hover-color:          $gray !default;\n$nav-tabs-active-link-hover-border-color:   $nav-tabs-border-color !default;\n\n$nav-tabs-justified-link-border-color:            $nav-tabs-border-color !default;\n$nav-tabs-justified-active-link-border-color:     $body-bg !default;\n\n//== Pills\n$nav-pills-border-radius:                   $border-radius-base !default;\n$nav-pills-active-link-hover-bg:            $component-active-bg !default;\n$nav-pills-active-link-hover-color:         $component-active-color !default;\n\n\n//== Pagination\n//\n//##\n\n$pagination-color:                     $btn-default-color !default;\n$pagination-bg:                        $btn-default-bg !default;\n$pagination-border:                    $btn-default-border !default;\n\n$pagination-hover-color:               $pagination-color !default;\n$pagination-hover-bg:                  $pagination-bg !default;\n$pagination-hover-border:              $pagination-border !default;\n\n$pagination-active-color:              #fff !default;\n$pagination-active-bg:                 $brand-primary !default;\n$pagination-active-border:             $btn-primary-border !default;\n\n$pagination-disabled-color:            $gray-light !default;\n$pagination-disabled-bg:               $pagination-bg !default;\n$pagination-disabled-border:           $pagination-border !default;\n\n\n//== Pager\n//\n//##\n\n$pager-bg:                             $pagination-bg !default;\n$pager-border:                         $pagination-border !default;\n$pager-border-radius:                  15px !default;\n\n$pager-hover-bg:                       $pagination-hover-bg !default;\n\n$pager-active-bg:                      $pagination-active-bg !default;\n$pager-active-color:                   $pagination-active-color !default;\n\n$pager-disabled-color:                 $pagination-disabled-color !default;\n\n\n//== Jumbotron\n//\n//##\n\n$jumbotron-padding:              30px !default;\n$jumbotron-color:                inherit !default;\n$jumbotron-bg:                   #fafafa !default;\n$jumbotron-heading-color:        inherit !default;\n$jumbotron-font-size:            ceil(($font-size-base * 1.5)) !default;\n$jumbotron-heading-font-size:    ceil(($font-size-base * 4.5)) !default;\n\n\n//== Form states and alerts\n//\n//## Define colors for form feedback states and, by default, alerts.\n\n$state-success-text:             #fff !default;\n$state-success-bg:               $brand-success !default;\n$state-success-border:           darken($state-success-bg, 4%) !default;\n\n$state-info-text:                #fff !default;\n$state-info-bg:                  $brand-info !default;\n$state-info-border:              darken($state-info-bg, 12%) !default;\n\n$state-warning-text:             #fff !default;\n$state-warning-bg:               $brand-warning !default;\n$state-warning-border:           darken($state-warning-bg, 5%) !default;\n\n$state-danger-text:              #fff !default;\n$state-danger-bg:                $brand-danger !default;\n$state-danger-border:            darken($state-danger-bg, 10%) !default;\n\n\n//== Tooltips\n//\n//##\n\n//** Tooltip max width\n$tooltip-max-width:           200px !default;\n//** Tooltip text color\n$tooltip-color:               #fff !default;\n//** Tooltip background color\n$tooltip-bg:                  #000 !default;\n$tooltip-opacity:             .9 !default;\n\n//** Tooltip arrow width\n$tooltip-arrow-width:         5px !default;\n//** Tooltip arrow color\n$tooltip-arrow-color:         $tooltip-bg !default;\n\n\n//== Popovers\n//\n//##\n\n//** Popover body background color\n$popover-bg:                          #fff !default;\n//** Popover maximum width\n$popover-max-width:                   276px !default;\n//** Popover border color\n$popover-border-color:                rgba(0,0,0,.2) !default;\n//** Popover fallback border color\n$popover-fallback-border-color:       #ccc !default;\n\n//** Popover title background color\n$popover-title-bg:                    darken($popover-bg, 3%) !default;\n\n//** Popover arrow width\n$popover-arrow-width:                 10px !default;\n//** Popover arrow color\n$popover-arrow-color:                 $popover-bg !default;\n\n//** Popover outer arrow width\n$popover-arrow-outer-width:           ($popover-arrow-width + 1) !default;\n//** Popover outer arrow color\n$popover-arrow-outer-color:           fadein($popover-border-color, 5%) !default;\n//** Popover outer arrow fallback color\n$popover-arrow-outer-fallback-color:  darken($popover-fallback-border-color, 20%) !default;\n\n\n//== Labels\n//\n//##\n\n//** Default label background color\n$label-default-bg:            $gray-light !default;\n//** Primary label background color\n$label-primary-bg:            $brand-primary !default;\n//** Success label background color\n$label-success-bg:            $brand-success !default;\n//** Info label background color\n$label-info-bg:               $brand-info !default;\n//** Warning label background color\n$label-warning-bg:            $brand-warning !default;\n//** Danger label background color\n$label-danger-bg:             $brand-danger !default;\n\n//** Default label text color\n$label-color:                 #fff !default;\n//** Default text color of a linked label\n$label-link-hover-color:      #fff !default;\n\n\n//== Modals\n//\n//##\n\n//** Padding applied to the modal body\n$modal-inner-padding:         20px !default;\n\n//** Padding applied to the modal title\n$modal-title-padding:         15px !default;\n//** Modal title line-height\n$modal-title-line-height:     $line-height-base !default;\n\n//** Background color of modal content area\n$modal-content-bg:                             #fff !default;\n//** Modal content border color\n$modal-content-border-color:                   rgba(0,0,0,.05) !default;\n//** Modal content border color **for IE8**\n$modal-content-fallback-border-color:          $gray-lighter !default;\n\n//** Modal backdrop background color\n$modal-backdrop-bg:           #000 !default;\n//** Modal backdrop opacity\n$modal-backdrop-opacity:      .5 !default;\n//** Modal header border color\n$modal-header-border-color:   #e5e5e5 !default;\n//** Modal footer border color\n$modal-footer-border-color:   $modal-header-border-color !default;\n\n$modal-lg:                    900px !default;\n$modal-md:                    600px !default;\n$modal-sm:                    300px !default;\n\n\n//== Alerts\n//\n//## Define alert colors, border radius, and padding.\n\n$alert-padding:               15px !default;\n$alert-border-radius:         $border-radius-base !default;\n$alert-link-font-weight:      bold !default;\n\n$alert-success-bg:            $state-success-bg !default;\n$alert-success-text:          $state-success-text !default;\n$alert-success-border:        $state-success-border !default;\n\n$alert-info-bg:               $state-info-bg !default;\n$alert-info-text:             $state-info-text !default;\n$alert-info-border:           $state-info-border !default;\n\n$alert-warning-bg:            $state-warning-bg !default;\n$alert-warning-text:          $state-warning-text !default;\n$alert-warning-border:        $state-warning-border !default;\n\n$alert-danger-bg:             $state-danger-bg !default;\n$alert-danger-text:           $state-danger-text !default;\n$alert-danger-border:         $state-danger-border !default;\n\n\n//== Progress bars\n//\n//##\n\n//** Background color of the whole progress component\n$progress-bg:                 $jumbotron-bg !default;\n//** Progress bar text color\n$progress-bar-color:          #fff !default;\n//** Variable for setting rounded corners on progress bar.\n$progress-border-radius:      $border-radius-base !default;\n\n//** Default progress bar color\n$progress-bar-bg:             $brand-primary !default;\n//** Success progress bar color\n$progress-bar-success-bg:     $brand-success !default;\n//** Warning progress bar color\n$progress-bar-warning-bg:     $brand-warning !default;\n//** Danger progress bar color\n$progress-bar-danger-bg:      $brand-danger !default;\n//** Info progress bar color\n$progress-bar-info-bg:        $brand-info !default;\n\n\n//== List group\n//\n//##\n\n//** Background color on `.list-group-item`\n$list-group-bg:                 #fff !default;\n//** `.list-group-item` border color\n$list-group-border:             $gray-lighter !default;\n//** List group border radius\n$list-group-border-radius:      $border-radius-base !default;\n\n//** Background color of single list items on hover\n$list-group-hover-bg:           #f5f5f5 !default;\n//** Text color of active list items\n$list-group-active-color:       $component-active-color !default;\n//** Background color of active list elements\n$list-group-active-bg:          $component-active-bg !default;\n//** Background color of active list items\n$list-group-active-border:      $list-group-active-bg !default;\n//** Text color for content within active list items\n$list-group-active-text-color:  lighten($list-group-active-bg, 40%) !default;\n\n//** Text color of disabled list items\n$list-group-disabled-color:      $gray-light !default;\n//** Background color of disabled list items\n$list-group-disabled-bg:         $gray-lighter !default;\n//** Text color for content within disabled list items\n$list-group-disabled-text-color: $list-group-disabled-color !default;\n\n$list-group-link-color:         #555 !default;\n$list-group-link-hover-color:   $list-group-link-color !default;\n$list-group-link-heading-color: #333 !default;\n\n\n//== Panels\n//\n//##\n\n$panel-bg:                    #fff !default;\n$panel-body-padding:          15px !default;\n$panel-heading-padding:       10px 15px !default;\n$panel-footer-padding:        $panel-heading-padding !default;\n$panel-border-radius:         $border-radius-base !default;\n\n//** Border color for elements within panels\n$panel-inner-border:          transparent !default;\n$panel-footer-bg:             #f5f5f5 !default;\n\n$panel-default-text:          $gray-dark !default;\n$panel-default-border:        transparent !default;\n$panel-default-heading-bg:    #f5f5f5 !default;\n\n$panel-primary-text:          #fff !default;\n$panel-primary-border:        transparent !default;\n$panel-primary-heading-bg:    $brand-primary !default;\n\n$panel-success-text:          $state-success-text !default;\n$panel-success-border:        transparent !default;\n$panel-success-heading-bg:    $state-success-bg !default;\n\n$panel-info-text:             $state-info-text !default;\n$panel-info-border:           transparent !default;\n$panel-info-heading-bg:       $state-info-bg !default;\n\n$panel-warning-text:          $state-warning-text !default;\n$panel-warning-border:        transparent !default;\n$panel-warning-heading-bg:    $state-warning-bg !default;\n\n$panel-danger-text:           $state-danger-text !default;\n$panel-danger-border:         transparent !default;\n$panel-danger-heading-bg:     $state-danger-bg !default;\n\n\n//== Thumbnails\n//\n//##\n\n//** Padding around the thumbnail image\n$thumbnail-padding:           4px !default;\n//** Thumbnail background color\n$thumbnail-bg:                $body-bg !default;\n//** Thumbnail border color\n$thumbnail-border:            $gray-lighter !default;\n//** Thumbnail border radius\n$thumbnail-border-radius:     $border-radius-base !default;\n\n//** Custom text color for thumbnail captions\n$thumbnail-caption-color:     $text-color !default;\n//** Padding around the thumbnail caption\n$thumbnail-caption-padding:   9px !default;\n\n\n//== Wells\n//\n//##\n\n$well-bg:                     $jumbotron-bg !default;\n$well-border:                 darken($well-bg, 7%) !default;\n\n\n//== Badges\n//\n//##\n\n$badge-color:                 #fff !default;\n//** Linked badge text color on hover\n$badge-link-hover-color:      #fff !default;\n$badge-bg:                    $brand-primary !default;\n\n//** Badge text color in active nav link\n$badge-active-color:          $link-color !default;\n//** Badge background color in active nav link\n$badge-active-bg:             #fff !default;\n\n$badge-font-weight:           normal !default;\n$badge-line-height:           1 !default;\n$badge-border-radius:         10px !default;\n\n\n//== Breadcrumbs\n//\n//##\n\n$breadcrumb-padding-vertical:   8px !default;\n$breadcrumb-padding-horizontal: 15px !default;\n//** Breadcrumb background color\n$breadcrumb-bg:                 $well-bg !default;\n//** Breadcrumb text color\n$breadcrumb-color:              $gray-light !default;\n//** Text color of current page in the breadcrumb\n$breadcrumb-active-color:       $gray-light !default;\n//** Textual separator for between breadcrumb elements\n$breadcrumb-separator:          \">\" !default;\n\n\n//== Carousel\n//\n//##\n\n$carousel-text-shadow:                        0 1px 2px rgba(0,0,0,.6) !default;\n\n$carousel-control-color:                      #fff !default;\n$carousel-control-width:                      15% !default;\n$carousel-control-opacity:                    .7 !default;\n$carousel-control-font-size:                  20px !default;\n\n$carousel-indicator-active-bg:                #fff !default;\n$carousel-indicator-border-color:             #fff !default;\n\n$carousel-caption-color:                      #fff !default;\n\n\n//== Close\n//\n//##\n\n$close-font-weight:           bold !default;\n$close-color:                 #fff !default;\n$close-text-shadow:           0 1px 0 #fff !default;\n\n\n//== Code\n//\n//##\n\n$code-color:                  #c7254e !default;\n$code-bg:                     #f9f2f4 !default;\n\n$kbd-color:                   #fff !default;\n$kbd-bg:                      #333 !default;\n\n$pre-bg:                      #f5f5f5 !default;\n$pre-color:                   $gray-dark !default;\n$pre-border-color:            #ccc !default;\n$pre-scrollable-max-height:   340px !default;\n\n\n//== Type\n//\n//##\n\n//** Horizontal offset for forms and lists.\n$component-offset-horizontal: 180px !default;\n//** Text muted color\n$text-muted:                  $gray-light !default;\n//** Abbreviations and acronyms border color\n$abbr-border-color:           $gray-light !default;\n//** Headings small color\n$headings-small-color:        $gray-light !default;\n//** Blockquote small color\n$blockquote-small-color:      $gray-light !default;\n//** Blockquote font size\n$blockquote-font-size:        ($font-size-base * 1.25) !default;\n//** Blockquote border color\n$blockquote-border-color:     $gray-lighter !default;\n//** Page header border color\n$page-header-border-color:    $gray-lighter !default;\n//** Width of horizontal description list titles\n$dl-horizontal-offset:        $component-offset-horizontal !default;\n//** Point at which .dl-horizontal becomes horizontal\n$dl-horizontal-breakpoint:    $grid-float-breakpoint !default;\n//** Horizontal line color.\n$hr-border:                   $gray-lighter !default;\n","// WebKit-style focus\n\n@mixin tab-focus() {\n  // WebKit-specific. Other browsers will keep their default outline style.\n  // (Initially tried to also force default via `outline: initial`,\n  // but that seems to erroneously remove the outline in Firefox altogether.)\n  outline: 5px auto -webkit-focus-ring-color;\n  outline-offset: -2px;\n}\n","// Image Mixins\n// - Responsive image\n// - Retina image\n\n\n// Responsive image\n//\n// Keep images from scaling beyond the width of their parents.\n@mixin img-responsive($display: block) {\n  display: $display;\n  max-width: 100%; // Part 1: Set a maximum relative to the parent\n  height: auto; // Part 2: Scale the height according to the width, otherwise you get stretching\n}\n\n\n// Retina image\n//\n// Short retina mixin for setting background-image and -size. Note that the\n// spelling of `min--moz-device-pixel-ratio` is intentional.\n@mixin img-retina($file-1x, $file-2x, $width-1x, $height-1x) {\n  background-image: url(if($bootstrap-sass-asset-helper, twbs-image-path(\"#{$file-1x}\"), \"#{$file-1x}\"));\n\n  @media\n  only screen and (-webkit-min-device-pixel-ratio: 2),\n  only screen and (   min--moz-device-pixel-ratio: 2),\n  only screen and (     -o-min-device-pixel-ratio: 2/1),\n  only screen and (        min-device-pixel-ratio: 2),\n  only screen and (                min-resolution: 192dpi),\n  only screen and (                min-resolution: 2dppx) {\n    background-image: url(if($bootstrap-sass-asset-helper, twbs-image-path(\"#{$file-2x}\"), \"#{$file-2x}\"));\n    background-size: $width-1x $height-1x;\n  }\n}\n","//\n// Typography\n// --------------------------------------------------\n\n\n// Headings\n// -------------------------\n\nh1, h2, h3, h4, h5, h6,\n.h1, .h2, .h3, .h4, .h5, .h6 {\n  font-family: $headings-font-family;\n  font-weight: $headings-font-weight;\n  line-height: $headings-line-height;\n  color: $headings-color;\n\n  small,\n  .small {\n    font-weight: normal;\n    line-height: 1;\n    color: $headings-small-color;\n  }\n}\n\nh1, .h1,\nh2, .h2,\nh3, .h3 {\n  margin-top: $line-height-computed;\n  margin-bottom: ($line-height-computed / 2);\n\n  small,\n  .small {\n    font-size: 65%;\n  }\n}\nh4, .h4,\nh5, .h5,\nh6, .h6 {\n  margin-top: ($line-height-computed / 2);\n  margin-bottom: ($line-height-computed / 2);\n\n  small,\n  .small {\n    font-size: 75%;\n  }\n}\n\nh1, .h1 { font-size: $font-size-h1; }\nh2, .h2 { font-size: $font-size-h2; }\nh3, .h3 { font-size: $font-size-h3; }\nh4, .h4 { font-size: $font-size-h4; }\nh5, .h5 { font-size: $font-size-h5; }\nh6, .h6 { font-size: $font-size-h6; }\n\n\n// Body text\n// -------------------------\n\np {\n  margin: 0 0 ($line-height-computed / 2);\n}\n\n.lead {\n  margin-bottom: $line-height-computed;\n  font-size: floor(($font-size-base * 1.15));\n  font-weight: 300;\n  line-height: 1.4;\n\n  @media (min-width: $screen-sm-min) {\n    font-size: ($font-size-base * 1.5);\n  }\n}\n\n\n// Emphasis & misc\n// -------------------------\n\n// Ex: (12px small font / 14px base font) * 100% = about 85%\nsmall,\n.small {\n  font-size: floor((100% * $font-size-small / $font-size-base));\n}\n\nmark,\n.mark {\n  background-color: $state-warning-bg;\n  padding: .2em;\n}\n\n// Alignment\n.text-left           { text-align: left; }\n.text-right          { text-align: right; }\n.text-center         { text-align: center; }\n.text-justify        { text-align: justify; }\n.text-nowrap         { white-space: nowrap; }\n\n// Transformation\n.text-lowercase      { text-transform: lowercase; }\n.text-uppercase      { text-transform: uppercase; }\n.text-capitalize     { text-transform: capitalize; }\n\n// Contextual colors\n.text-muted {\n  color: $text-muted;\n}\n\n@include text-emphasis-variant('.text-primary', $brand-primary);\n\n@include text-emphasis-variant('.text-success', $state-success-text);\n\n@include text-emphasis-variant('.text-info', $state-info-text);\n\n@include text-emphasis-variant('.text-warning', $state-warning-text);\n\n@include text-emphasis-variant('.text-danger', $state-danger-text);\n\n// Contextual backgrounds\n// For now we'll leave these alongside the text classes until v4 when we can\n// safely shift things around (per SemVer rules).\n.bg-primary {\n  // Given the contrast here, this is the only class to have its color inverted\n  // automatically.\n  color: #fff;\n}\n@include bg-variant('.bg-primary', $brand-primary);\n\n@include bg-variant('.bg-success', $state-success-bg);\n\n@include bg-variant('.bg-info', $state-info-bg);\n\n@include bg-variant('.bg-warning', $state-warning-bg);\n\n@include bg-variant('.bg-danger', $state-danger-bg);\n\n\n// Page header\n// -------------------------\n\n.page-header {\n  padding-bottom: (($line-height-computed / 2) - 1);\n  margin: ($line-height-computed * 2) 0 $line-height-computed;\n  border-bottom: 1px solid $page-header-border-color;\n}\n\n\n// Lists\n// -------------------------\n\n// Unordered and Ordered lists\nul,\nol {\n  margin-top: 0;\n  margin-bottom: ($line-height-computed / 2);\n  ul,\n  ol {\n    margin-bottom: 0;\n  }\n}\n\n// List options\n\n// [converter] extracted from `.list-unstyled` for libsass compatibility\n@mixin list-unstyled {\n  padding-left: 0;\n  list-style: none;\n}\n// [converter] extracted as `@mixin list-unstyled` for libsass compatibility\n.list-unstyled {\n  @include list-unstyled;\n}\n\n\n// Inline turns list items into inline-block\n.list-inline {\n  @include list-unstyled;\n  margin-left: -5px;\n\n  > li {\n    display: inline-block;\n    padding-left: 5px;\n    padding-right: 5px;\n  }\n}\n\n// Description Lists\ndl {\n  margin-top: 0; // Remove browser default\n  margin-bottom: $line-height-computed;\n}\ndt,\ndd {\n  line-height: $line-height-base;\n}\ndt {\n  font-weight: bold;\n}\ndd {\n  margin-left: 0; // Undo browser default\n}\n\n// Horizontal description lists\n//\n// Defaults to being stacked without any of the below styles applied, until the\n// grid breakpoint is reached (default of ~768px).\n\n.dl-horizontal {\n  dd {\n    @include clearfix; // Clear the floated `dt` if an empty `dd` is present\n  }\n\n  @media (min-width: $dl-horizontal-breakpoint) {\n    dt {\n      float: left;\n      width: ($dl-horizontal-offset - 20);\n      clear: left;\n      text-align: right;\n      @include text-overflow;\n    }\n    dd {\n      margin-left: $dl-horizontal-offset;\n    }\n  }\n}\n\n\n// Misc\n// -------------------------\n\n// Abbreviations and acronyms\nabbr[title],\n// Add data-* attribute to help out our tooltip plugin, per https://github.com/twbs/bootstrap/issues/5257\nabbr[data-original-title] {\n  cursor: help;\n  border-bottom: 1px dotted $abbr-border-color;\n}\n.initialism {\n  font-size: 90%;\n  @extend .text-uppercase;\n}\n\n// Blockquotes\nblockquote {\n  padding: ($line-height-computed / 2) $line-height-computed;\n  margin: 0 0 $line-height-computed;\n  font-size: $blockquote-font-size;\n  border-left: 5px solid $blockquote-border-color;\n\n  p,\n  ul,\n  ol {\n    &:last-child {\n      margin-bottom: 0;\n    }\n  }\n\n  // Note: Deprecated small and .small as of v3.1.0\n  // Context: https://github.com/twbs/bootstrap/issues/11660\n  footer,\n  small,\n  .small {\n    display: block;\n    font-size: 80%; // back to default font-size\n    line-height: $line-height-base;\n    color: $blockquote-small-color;\n\n    &:before {\n      content: '\\2014 \\00A0'; // em dash, nbsp\n    }\n  }\n}\n\n// Opposite alignment of blockquote\n//\n// Heads up: `blockquote.pull-right` has been deprecated as of v3.1.0.\n.blockquote-reverse,\nblockquote.pull-right {\n  padding-right: 15px;\n  padding-left: 0;\n  border-right: 5px solid $blockquote-border-color;\n  border-left: 0;\n  text-align: right;\n\n  // Account for citation\n  footer,\n  small,\n  .small {\n    &:before { content: ''; }\n    &:after {\n      content: '\\00A0 \\2014'; // nbsp, em dash\n    }\n  }\n}\n\n// Addresses\naddress {\n  margin-bottom: $line-height-computed;\n  font-style: normal;\n  line-height: $line-height-base;\n}\n","// Typography\n\n// [converter] $parent hack\n@mixin text-emphasis-variant($parent, $color) {\n  #{$parent} {\n    color: $color;\n  }\n  a#{$parent}:hover,\n  a#{$parent}:focus {\n    color: darken($color, 10%);\n  }\n}\n","// Contextual backgrounds\n\n// [converter] $parent hack\n@mixin bg-variant($parent, $color) {\n  #{$parent} {\n    background-color: $color;\n  }\n  a#{$parent}:hover,\n  a#{$parent}:focus {\n    background-color: darken($color, 10%);\n  }\n}\n","// Clearfix\n//\n// For modern browsers\n// 1. The space content is one way to avoid an Opera bug when the\n//    contenteditable attribute is included anywhere else in the document.\n//    Otherwise it causes space to appear at the top and bottom of elements\n//    that are clearfixed.\n// 2. The use of `table` rather than `block` is only necessary if using\n//    `:before` to contain the top-margins of child elements.\n//\n// Source: http://nicolasgallagher.com/micro-clearfix-hack/\n\n@mixin clearfix() {\n  &:before,\n  &:after {\n    content: \" \"; // 1\n    display: table; // 2\n  }\n  &:after {\n    clear: both;\n  }\n}\n","// Text overflow\n// Requires inline-block or block for proper styling\n\n@mixin text-overflow() {\n  overflow: hidden;\n  text-overflow: ellipsis;\n  white-space: nowrap;\n}\n","//\n// Code (inline and block)\n// --------------------------------------------------\n\n\n// Inline and block code styles\ncode,\nkbd,\npre,\nsamp {\n  font-family: $font-family-monospace;\n}\n\n// Inline code\ncode {\n  padding: 2px 4px;\n  font-size: 90%;\n  color: $code-color;\n  background-color: $code-bg;\n  border-radius: $border-radius-base;\n}\n\n// User input typically entered via keyboard\nkbd {\n  padding: 2px 4px;\n  font-size: 90%;\n  color: $kbd-color;\n  background-color: $kbd-bg;\n  border-radius: $border-radius-small;\n  box-shadow: inset 0 -1px 0 rgba(0,0,0,.25);\n\n  kbd {\n    padding: 0;\n    font-size: 100%;\n    font-weight: bold;\n    box-shadow: none;\n  }\n}\n\n// Blocks of code\npre {\n  display: block;\n  padding: (($line-height-computed - 1) / 2);\n  margin: 0 0 ($line-height-computed / 2);\n  font-size: ($font-size-base - 1); // 14px to 13px\n  line-height: $line-height-base;\n  word-break: break-all;\n  word-wrap: break-word;\n  color: $pre-color;\n  // background-color: $pre-bg;\n  //border: 1px solid $pre-border-color;\n  //border-radius: $border-radius-base;\n\n  // Account for some code outputs that place code tags in pre tags\n  code {\n    padding: 0;\n    font-size: inherit;\n    color: inherit;\n    white-space: pre-wrap;\n    background-color: transparent;\n    border-radius: 0;\n  }\n}\n\n// Enable scrollable blocks of code\n.pre-scrollable {\n  max-height: $pre-scrollable-max-height;\n  overflow-y: scroll;\n}\n","//\n// Grid system\n// --------------------------------------------------\n\n\n// Container widths\n//\n// Set the container width, and override it for fixed navbars in media queries.\n\n.container {\n  @include container-fixed;\n\n  @media (min-width: $screen-sm-min) {\n    width: $container-sm;\n  }\n  @media (min-width: $screen-md-min) {\n    width: $container-md;\n  }\n  @media (min-width: $screen-lg-min) {\n    width: $container-lg;\n  }\n}\n\n\n// Fluid container\n//\n// Utilizes the mixin meant for fixed width containers, but without any defined\n// width for fluid, full width layouts.\n\n.container-fluid {\n  @include container-fixed;\n}\n\n\n// Row\n//\n// Rows contain and clear the floats of your columns.\n\n.row {\n  @include make-row;\n}\n\n\n// Columns\n//\n// Common styles for small and large grid columns\n\n@include make-grid-columns;\n\n\n// Extra small grid\n//\n// Columns, offsets, pushes, and pulls for extra small devices like\n// smartphones.\n\n@include make-grid(xs);\n\n\n// Small grid\n//\n// Columns, offsets, pushes, and pulls for the small device range, from phones\n// to tablets.\n\n@media (min-width: $screen-sm-min) {\n  @include make-grid(sm);\n}\n\n\n// Medium grid\n//\n// Columns, offsets, pushes, and pulls for the desktop device range.\n\n@media (min-width: $screen-md-min) {\n  @include make-grid(md);\n}\n\n\n// Large grid\n//\n// Columns, offsets, pushes, and pulls for the large desktop device range.\n\n@media (min-width: $screen-lg-min) {\n  @include make-grid(lg);\n}\n","// Grid system\n//\n// Generate semantic grid columns with these mixins.\n\n// Centered container element\n@mixin container-fixed($gutter: $grid-gutter-width) {\n  margin-right: auto;\n  margin-left: auto;\n  padding-left:  floor(($gutter / 2));\n  padding-right: ceil(($gutter / 2));\n  @include clearfix;\n}\n\n// Creates a wrapper for a series of columns\n@mixin make-row($gutter: $grid-gutter-width) {\n  margin-left:  ceil(($gutter / -2));\n  margin-right: floor(($gutter / -2));\n  @include clearfix;\n}\n\n// Generate the extra small columns\n@mixin make-xs-column($columns, $gutter: $grid-gutter-width) {\n  position: relative;\n  float: left;\n  width: percentage(($columns / $grid-columns));\n  min-height: 1px;\n  padding-left:  ($gutter / 2);\n  padding-right: ($gutter / 2);\n}\n@mixin make-xs-column-offset($columns) {\n  margin-left: percentage(($columns / $grid-columns));\n}\n@mixin make-xs-column-push($columns) {\n  left: percentage(($columns / $grid-columns));\n}\n@mixin make-xs-column-pull($columns) {\n  right: percentage(($columns / $grid-columns));\n}\n\n// Generate the small columns\n@mixin make-sm-column($columns, $gutter: $grid-gutter-width) {\n  position: relative;\n  min-height: 1px;\n  padding-left:  ($gutter / 2);\n  padding-right: ($gutter / 2);\n\n  @media (min-width: $screen-sm-min) {\n    float: left;\n    width: percentage(($columns / $grid-columns));\n  }\n}\n@mixin make-sm-column-offset($columns) {\n  @media (min-width: $screen-sm-min) {\n    margin-left: percentage(($columns / $grid-columns));\n  }\n}\n@mixin make-sm-column-push($columns) {\n  @media (min-width: $screen-sm-min) {\n    left: percentage(($columns / $grid-columns));\n  }\n}\n@mixin make-sm-column-pull($columns) {\n  @media (min-width: $screen-sm-min) {\n    right: percentage(($columns / $grid-columns));\n  }\n}\n\n// Generate the medium columns\n@mixin make-md-column($columns, $gutter: $grid-gutter-width) {\n  position: relative;\n  min-height: 1px;\n  padding-left:  ($gutter / 2);\n  padding-right: ($gutter / 2);\n\n  @media (min-width: $screen-md-min) {\n    float: left;\n    width: percentage(($columns / $grid-columns));\n  }\n}\n@mixin make-md-column-offset($columns) {\n  @media (min-width: $screen-md-min) {\n    margin-left: percentage(($columns / $grid-columns));\n  }\n}\n@mixin make-md-column-push($columns) {\n  @media (min-width: $screen-md-min) {\n    left: percentage(($columns / $grid-columns));\n  }\n}\n@mixin make-md-column-pull($columns) {\n  @media (min-width: $screen-md-min) {\n    right: percentage(($columns / $grid-columns));\n  }\n}\n\n// Generate the large columns\n@mixin make-lg-column($columns, $gutter: $grid-gutter-width) {\n  position: relative;\n  min-height: 1px;\n  padding-left:  ($gutter / 2);\n  padding-right: ($gutter / 2);\n\n  @media (min-width: $screen-lg-min) {\n    float: left;\n    width: percentage(($columns / $grid-columns));\n  }\n}\n@mixin make-lg-column-offset($columns) {\n  @media (min-width: $screen-lg-min) {\n    margin-left: percentage(($columns / $grid-columns));\n  }\n}\n@mixin make-lg-column-push($columns) {\n  @media (min-width: $screen-lg-min) {\n    left: percentage(($columns / $grid-columns));\n  }\n}\n@mixin make-lg-column-pull($columns) {\n  @media (min-width: $screen-lg-min) {\n    right: percentage(($columns / $grid-columns));\n  }\n}\n","// Framework grid generation\n//\n// Used only by Bootstrap to generate the correct number of grid classes given\n// any value of `$grid-columns`.\n\n// [converter] This is defined recursively in LESS, but Sass supports real loops\n@mixin make-grid-columns($i: 1, $list: \".col-xs-#{$i}, .col-sm-#{$i}, .col-md-#{$i}, .col-lg-#{$i}\") {\n  @for $i from (1 + 1) through $grid-columns {\n    $list: \"#{$list}, .col-xs-#{$i}, .col-sm-#{$i}, .col-md-#{$i}, .col-lg-#{$i}\";\n  }\n  #{$list} {\n    position: relative;\n    // Prevent columns from collapsing when empty\n    min-height: 1px;\n    // Inner gutter via padding\n    padding-left:  ceil(($grid-gutter-width / 2));\n    padding-right: floor(($grid-gutter-width / 2));\n  }\n}\n\n\n// [converter] This is defined recursively in LESS, but Sass supports real loops\n@mixin float-grid-columns($class, $i: 1, $list: \".col-#{$class}-#{$i}\") {\n  @for $i from (1 + 1) through $grid-columns {\n    $list: \"#{$list}, .col-#{$class}-#{$i}\";\n  }\n  #{$list} {\n    float: left;\n  }\n}\n\n\n@mixin calc-grid-column($index, $class, $type) {\n  @if ($type == width) and ($index > 0) {\n    .col-#{$class}-#{$index} {\n      width: percentage(($index / $grid-columns));\n    }\n  }\n  @if ($type == push) and ($index > 0) {\n    .col-#{$class}-push-#{$index} {\n      left: percentage(($index / $grid-columns));\n    }\n  }\n  @if ($type == push) and ($index == 0) {\n    .col-#{$class}-push-0 {\n      left: auto;\n    }\n  }\n  @if ($type == pull) and ($index > 0) {\n    .col-#{$class}-pull-#{$index} {\n      right: percentage(($index / $grid-columns));\n    }\n  }\n  @if ($type == pull) and ($index == 0) {\n    .col-#{$class}-pull-0 {\n      right: auto;\n    }\n  }\n  @if ($type == offset) {\n    .col-#{$class}-offset-#{$index} {\n      margin-left: percentage(($index / $grid-columns));\n    }\n  }\n}\n\n// [converter] This is defined recursively in LESS, but Sass supports real loops\n@mixin loop-grid-columns($columns, $class, $type) {\n  @for $i from 0 through $columns {\n    @include calc-grid-column($i, $class, $type);\n  }\n}\n\n\n// Create grid for specific class\n@mixin make-grid($class) {\n  @include float-grid-columns($class);\n  @include loop-grid-columns($grid-columns, $class, width);\n  @include loop-grid-columns($grid-columns, $class, pull);\n  @include loop-grid-columns($grid-columns, $class, push);\n  @include loop-grid-columns($grid-columns, $class, offset);\n}\n","//\n// Tables\n// --------------------------------------------------\n\n\ntable {\n  background-color: $table-bg;\n}\ncaption {\n  padding-top: $table-cell-padding;\n  padding-bottom: $table-cell-padding;\n  color: $text-muted;\n  text-align: left;\n}\nth {\n  text-align: left;\n}\n\n\n// Baseline styles\n\n.table {\n  width: 100%;\n  max-width: 100%;\n  margin-bottom: $line-height-computed;\n  // Cells\n  > thead,\n  > tbody,\n  > tfoot {\n    > tr {\n      > th,\n      > td {\n        padding: $table-cell-padding;\n        line-height: $line-height-base;\n        vertical-align: top;\n        border-top: 1px solid $table-border-color;\n      }\n    }\n  }\n  // Bottom align for column headings\n  > thead > tr > th {\n    vertical-align: bottom;\n    border-bottom: 2px solid $table-border-color;\n  }\n  // Remove top border from thead by default\n  > caption + thead,\n  > colgroup + thead,\n  > thead:first-child {\n    > tr:first-child {\n      > th,\n      > td {\n        border-top: 0;\n      }\n    }\n  }\n  // Account for multiple tbody instances\n  > tbody + tbody {\n    border-top: 2px solid $table-border-color;\n  }\n\n  // Nesting\n  .table {\n    background-color: $body-bg;\n  }\n}\n\n\n// Condensed table w/ half padding\n\n.table-condensed {\n  > thead,\n  > tbody,\n  > tfoot {\n    > tr {\n      > th,\n      > td {\n        padding: $table-condensed-cell-padding;\n      }\n    }\n  }\n}\n\n\n// Bordered version\n//\n// Add borders all around the table and between all the columns.\n\n.table-bordered {\n  border: 1px solid $table-border-color;\n  > thead,\n  > tbody,\n  > tfoot {\n    > tr {\n      > th,\n      > td {\n        border: 1px solid $table-border-color;\n      }\n    }\n  }\n  > thead > tr {\n    > th,\n    > td {\n      border-bottom-width: 2px;\n    }\n  }\n}\n\n\n// Zebra-striping\n//\n// Default zebra-stripe styles (alternating gray and transparent backgrounds)\n\n.table-striped {\n  > tbody > tr:nth-of-type(odd) {\n    background-color: $table-bg-accent;\n  }\n}\n\n\n// Hover effect\n//\n// Placed here since it has to come after the potential zebra striping\n\n.table-hover {\n  > tbody > tr:hover {\n    background-color: $table-bg-hover;\n  }\n}\n\n\n// Table cell sizing\n//\n// Reset default table behavior\n\ntable col[class*=\"col-\"] {\n  position: static; // Prevent border hiding in Firefox and IE9-11 (see https://github.com/twbs/bootstrap/issues/11623)\n  float: none;\n  display: table-column;\n}\ntable {\n  td,\n  th {\n    &[class*=\"col-\"] {\n      position: static; // Prevent border hiding in Firefox and IE9-11 (see https://github.com/twbs/bootstrap/issues/11623)\n      float: none;\n      display: table-cell;\n    }\n  }\n}\n\n\n// Table backgrounds\n//\n// Exact selectors below required to override `.table-striped` and prevent\n// inheritance to nested tables.\n\n// Generate the contextual variants\n@include table-row-variant('active', $table-bg-active);\n@include table-row-variant('success', $state-success-bg);\n@include table-row-variant('info', $state-info-bg);\n@include table-row-variant('warning', $state-warning-bg);\n@include table-row-variant('danger', $state-danger-bg);\n\n\n// Responsive tables\n//\n// Wrap your tables in `.table-responsive` and we'll make them mobile friendly\n// by enabling horizontal scrolling. Only applies <768px. Everything above that\n// will display normally.\n\n.table-responsive {\n  overflow-x: auto;\n  min-height: 0.01%; // Workaround for IE9 bug (see https://github.com/twbs/bootstrap/issues/14837)\n\n  @media screen and (max-width: $screen-xs-max) {\n    width: 100%;\n    margin-bottom: ($line-height-computed * 0.75);\n    overflow-y: hidden;\n    -ms-overflow-style: -ms-autohiding-scrollbar;\n    border: 1px solid $table-border-color;\n\n    // Tighten up spacing\n    > .table {\n      margin-bottom: 0;\n\n      // Ensure the content doesn't wrap\n      > thead,\n      > tbody,\n      > tfoot {\n        > tr {\n          > th,\n          > td {\n            white-space: nowrap;\n          }\n        }\n      }\n    }\n\n    // Special overrides for the bordered tables\n    > .table-bordered {\n      border: 0;\n\n      // Nuke the appropriate borders so that the parent can handle them\n      > thead,\n      > tbody,\n      > tfoot {\n        > tr {\n          > th:first-child,\n          > td:first-child {\n            border-left: 0;\n          }\n          > th:last-child,\n          > td:last-child {\n            border-right: 0;\n          }\n        }\n      }\n\n      // Only nuke the last row's bottom-border in `tbody` and `tfoot` since\n      // chances are there will be only one `tr` in a `thead` and that would\n      // remove the border altogether.\n      > tbody,\n      > tfoot {\n        > tr:last-child {\n          > th,\n          > td {\n            border-bottom: 0;\n          }\n        }\n      }\n\n    }\n  }\n}\n","// Tables\n\n@mixin table-row-variant($state, $background) {\n  // Exact selectors below required to override `.table-striped` and prevent\n  // inheritance to nested tables.\n  .table > thead > tr,\n  .table > tbody > tr,\n  .table > tfoot > tr {\n    > td.#{$state},\n    > th.#{$state},\n    &.#{$state} > td,\n    &.#{$state} > th {\n      background-color: $background;\n    }\n  }\n\n  // Hover states for `.table-hover`\n  // Note: this is not available for cells or rows within `thead` or `tfoot`.\n  .table-hover > tbody > tr {\n    > td.#{$state}:hover,\n    > th.#{$state}:hover,\n    &.#{$state}:hover > td,\n    &:hover > .#{$state},\n    &.#{$state}:hover > th {\n      background-color: darken($background, 5%);\n    }\n  }\n}\n","//\n// Forms\n// --------------------------------------------------\n\n\n// Normalize non-controls\n//\n// Restyle and baseline non-control form elements.\n\nfieldset {\n  padding: 0;\n  margin: 0;\n  border: 0;\n  // Chrome and Firefox set a `min-width: min-content;` on fieldsets,\n  // so we reset that to ensure it behaves more like a standard block element.\n  // See https://github.com/twbs/bootstrap/issues/12359.\n  min-width: 0;\n}\n\nlegend {\n  display: block;\n  width: 100%;\n  padding: 0;\n  margin-bottom: $line-height-computed;\n  font-size: ($font-size-base * 1.5);\n  line-height: inherit;\n  color: $legend-color;\n  border: 0;\n  border-bottom: 1px solid $legend-border-color;\n}\n\nlabel {\n  display: inline-block;\n  max-width: 100%; // Force IE8 to wrap long content (see https://github.com/twbs/bootstrap/issues/13141)\n  margin-bottom: 5px;\n  font-weight: bold;\n}\n\n\n// Normalize form controls\n//\n// While most of our form styles require extra classes, some basic normalization\n// is required to ensure optimum display with or without those classes to better\n// address browser inconsistencies.\n\n// Override content-box in Normalize (* isn't specific enough)\ninput[type=\"search\"] {\n  @include box-sizing(border-box);\n}\n\n// Position radios and checkboxes better\ninput[type=\"radio\"],\ninput[type=\"checkbox\"] {\n  margin: 4px 0 0;\n  margin-top: 1px \\9; // IE8-9\n  line-height: normal;\n}\n\ninput[type=\"file\"] {\n  display: block;\n}\n\n// Make range inputs behave like textual form controls\ninput[type=\"range\"] {\n  display: block;\n  width: 100%;\n}\n\n// Make multiple select elements height not fixed\nselect[multiple],\nselect[size] {\n  height: auto;\n}\n\n// Focus for file, radio, and checkbox\ninput[type=\"file\"]:focus,\ninput[type=\"radio\"]:focus,\ninput[type=\"checkbox\"]:focus {\n  @include tab-focus;\n}\n\n// Adjust output element\noutput {\n  display: block;\n  padding-top: ($padding-base-vertical + 1);\n  font-size: $font-size-base;\n  line-height: $line-height-base;\n  color: $input-color;\n}\n\n\n// Common form controls\n//\n// Shared size and type resets for form controls. Apply `.form-control` to any\n// of the following form controls:\n//\n// select\n// textarea\n// input[type=\"text\"]\n// input[type=\"password\"]\n// input[type=\"datetime\"]\n// input[type=\"datetime-local\"]\n// input[type=\"date\"]\n// input[type=\"month\"]\n// input[type=\"time\"]\n// input[type=\"week\"]\n// input[type=\"number\"]\n// input[type=\"email\"]\n// input[type=\"url\"]\n// input[type=\"search\"]\n// input[type=\"tel\"]\n// input[type=\"color\"]\n\n.form-control {\n  display: block;\n  width: 100%;\n  height: $input-height-base; // Make inputs at least the height of their button counterpart (base line-height + padding + border)\n  padding: $padding-base-vertical $padding-base-horizontal;\n  font-size: $font-size-base;\n  line-height: $line-height-base;\n  color: $input-color;\n  background-color: $input-bg;\n  background-image: none; // Reset unusual Firefox-on-Android default style; see https://github.com/necolas/normalize.css/issues/214\n  border: 1px solid $input-border;\n  border-radius: $input-border-radius; // Note: This has no effect on s in CSS.\n  @include box-shadow(inset 0 1px 1px rgba(0,0,0,.075));\n  @include transition(border-color ease-in-out .15s, box-shadow ease-in-out .15s);\n\n  // Customize the `:focus` state to imitate native WebKit styles.\n  @include form-control-focus;\n\n  // Placeholder\n  @include placeholder;\n\n  // Unstyle the caret on ``\n// element gets special love because it's special, and that's a fact!\n// [converter] $parent hack\n@mixin input-size($parent, $input-height, $padding-vertical, $padding-horizontal, $font-size, $line-height, $border-radius) {\n  #{$parent} {\n    height: $input-height;\n    padding: $padding-vertical $padding-horizontal;\n    font-size: $font-size;\n    line-height: $line-height;\n    border-radius: $border-radius;\n  }\n\n  select#{$parent} {\n    height: $input-height;\n    line-height: $input-height;\n  }\n\n  textarea#{$parent},\n  select[multiple]#{$parent} {\n    height: auto;\n  }\n}\n","//\n// Buttons\n// --------------------------------------------------\n\n\n// Base styles\n// --------------------------------------------------\n\n// ------ custom-made for publications\n\n.btn-abstract {\n  display: inline-block;\n  border: 1px solid var(--global-text-color);\n  padding-left: 1rem;\n  padding-right: 1rem;\n  padding-top: 0.25rem;\n  padding-bottom: 0.25rem;\n  color: $gray-lighter;\n  &:hover {\n            color: var(--global-theme-color);\n            border-color: var(--global-theme-color);\n          }\n\n  margin-bottom: 0; // For input.btn\n  font-weight: bold;\n  // font-weight: $btn-font-weight;\n  text-align: center;\n  vertical-align: middle;\n  touch-action: manipulation;\n  cursor: pointer;\n  background-image: none; // Reset unusual Firefox-on-Android default style; see https://github.com/necolas/normalize.css/issues/214\n  white-space: nowrap;\n  background-color: #03888a;\n  @include button-size($padding-base-vertical*0.3, $padding-base-horizontal, $font-size-small, $line-height-base, $btn-border-radius-base);\n  @include user-select(none);\n\n  &.disabled,\n  &[disabled],\n  fieldset[disabled] & {\n    cursor: $cursor-disabled;\n    @include opacity(.65);\n    @include box-shadow(none);\n  }\n}\n\n.btn-video {\n  display: inline-block;\n  border: 1px solid var(--global-text-color);\n  padding-left: 1rem;\n  padding-right: 1rem;\n  padding-top: 0.25rem;\n  padding-bottom: 0.25rem;\n  color: $gray-lighter;\n  &:hover {\n            color: var(--global-theme-color);\n            border-color: var(--global-theme-color);\n          }\n\n  margin-bottom: 0; // For input.btn\n  font-weight: bold;\n  // font-weight: $btn-font-weight;\n  text-align: center;\n  vertical-align: middle;\n  touch-action: manipulation;\n  cursor: pointer;\n  background-image: none; // Reset unusual Firefox-on-Android default style; see https://github.com/necolas/normalize.css/issues/214\n  white-space: nowrap;\n  background-color: #0000CD;\n  @include button-size($padding-base-vertical*0.3, $padding-base-horizontal, $font-size-small, $line-height-base, $btn-border-radius-base);\n  @include user-select(none);\n\n  &.disabled,\n  &[disabled],\n  fieldset[disabled] & {\n    cursor: $cursor-disabled;\n    @include opacity(.65);\n    @include box-shadow(none);\n  }\n}\n\n.btn-pdf {\n  display: inline-block;\n  margin-bottom: 0; // For input.btn\n  font-weight: bold;\n  // font-weight: $btn-font-weight;\n  text-align: center;\n  vertical-align: middle;\n  touch-action: manipulation;\n  cursor: pointer;\n  background-image: none; // Reset unusual Firefox-on-Android default style; see https://github.com/necolas/normalize.css/issues/214\n  border: 0px solid transparent;\n  white-space: nowrap;\n  color: $gray-lighter;\n  background-color: $btn-warning-bg;\n  @include button-size($padding-base-vertical*0.3, $padding-base-horizontal, $font-size-small, $line-height-base, $btn-border-radius-base);\n  @include user-select(none);\n\n  &.disabled,\n  &[disabled],\n  fieldset[disabled] & {\n    cursor: $cursor-disabled;\n    @include opacity(.65);\n    @include box-shadow(none);\n  }\n}\n\n\n.btn-arxiv {\n  display: inline-block;\n  margin-bottom: 0; // For input.btn\n  font-weight: bold;\n  // font-weight: $btn-font-weight;\n  text-align: center;\n  vertical-align: middle;\n  touch-action: manipulation;\n  cursor: pointer;\n  background-image: none; // Reset unusual Firefox-on-Android default style; see https://github.com/necolas/normalize.css/issues/214\n  border: 0px solid transparent;\n  white-space: nowrap;\n  color: $gray-lighter;\n  background-color: $btn-info-bg;\n  @include button-size($padding-base-vertical*0.3, $padding-base-horizontal, $font-size-small, $line-height-base, $btn-border-radius-base);\n  @include user-select(none);\n\n  &.disabled,\n  &[disabled],\n  fieldset[disabled] & {\n    cursor: $cursor-disabled;\n    @include opacity(.65);\n    @include box-shadow(none);\n  }\n}\n\n.btn-doi {\n  display: inline-block;\n  margin-bottom: 0; // For input.btn\n  font-weight: bold;\n  // font-weight: $btn-font-weight;\n  text-align: center;\n  vertical-align: middle;\n  touch-action: manipulation;\n  cursor: pointer;\n  background-image: none; // Reset unusual Firefox-on-Android default style; see https://github.com/necolas/normalize.css/issues/214\n  border: 0px solid transparent;\n  white-space: nowrap;\n  color: $gray-lighter;\n  background-color: $btn-danger-bg;\n  @include button-size($padding-base-vertical*0.3, $padding-base-horizontal, $font-size-small, $line-height-base, $btn-border-radius-base);\n  @include user-select(none);\n\n  &.disabled,\n  &[disabled],\n  fieldset[disabled] & {\n    cursor: $cursor-disabled;\n    @include opacity(.65);\n    @include box-shadow(none);\n  }\n}\n\n.btn-bib {\n  display: inline-block;\n  margin-bottom: 0; // For input.btn\n  font-weight: bold;\n  // font-weight: $btn-font-weight;\n  text-align: center;\n  vertical-align: middle;\n  touch-action: manipulation;\n  cursor: pointer;\n  background-image: none; // Reset unusual Firefox-on-Android default style; see https://github.com/necolas/normalize.css/issues/214\n  border: 0px solid transparent;\n  white-space: nowrap;\n  color: $gray-lighter;\n  background-color: $btn-success-bg;\n  @include button-size($padding-base-vertical*0.3, $padding-base-horizontal, $font-size-small, $line-height-base, $btn-border-radius-base);\n  @include user-select(none);\n\n  &.disabled,\n  &[disabled],\n  fieldset[disabled] & {\n    cursor: $cursor-disabled;\n    @include opacity(.65);\n    @include box-shadow(none);\n  }\n}\n\n\n\n// ----------\n\n.btn {\n  display: inline-block;\n  margin-bottom: 0; // For input.btn\n  font-weight: $btn-font-weight;\n  text-align: center;\n  vertical-align: middle;\n  touch-action: manipulation;\n  cursor: pointer;\n  background-image: none; // Reset unusual Firefox-on-Android default style; see https://github.com/necolas/normalize.css/issues/214\n  border: 1px solid transparent;\n  white-space: nowrap;\n  @include button-size($padding-base-vertical, $padding-base-horizontal, $font-size-base, $line-height-base, $btn-border-radius-base);\n  @include user-select(none);\n\n  &,\n  &:active,\n  &.active {\n    &:focus,\n    &.focus {\n      @include tab-focus;\n    }\n  }\n\n  &:hover,\n  &:focus,\n  &.focus {\n    color: $btn-default-color;\n    text-decoration: none;\n  }\n\n  &:active,\n  &.active {\n    outline: 0;\n    background-image: none;\n    @include box-shadow(inset 0 3px 5px rgba(0,0,0,.125));\n  }\n\n  &.disabled,\n  &[disabled],\n  fieldset[disabled] & {\n    cursor: $cursor-disabled;\n    @include opacity(.65);\n    @include box-shadow(none);\n  }\n\n  // [converter] extracted a& to a.btn\n}\n\na.btn {\n  &.disabled,\n  fieldset[disabled] & {\n    pointer-events: none; // Future-proof disabling of clicks on `` elements\n  }\n}\n\n\n// Alternate buttons\n// --------------------------------------------------\n\n.btn-default {\n  @include button-variant($btn-default-color, $btn-default-bg, $btn-default-border);\n}\n.btn-primary {\n  @include button-variant($btn-primary-color, $btn-primary-bg, $btn-primary-border);\n}\n// Success appears as green\n.btn-success {\n  @include button-variant($btn-success-color, $btn-success-bg, $btn-success-border);\n}\n// Info appears as blue-green\n.btn-info {\n  @include button-variant($btn-info-color, $btn-info-bg, $btn-info-border);\n}\n// Warning appears as orange\n.btn-warning {\n  @include button-variant($btn-warning-color, $btn-warning-bg, $btn-warning-border);\n}\n// Danger and error appear as red\n.btn-danger {\n  @include button-variant($btn-danger-color, $btn-danger-bg, $btn-danger-border);\n}\n\n\n// Link buttons\n// -------------------------\n\n// Make a button look and behave like a link\n.btn-link {\n  color: $link-color;\n  font-weight: normal;\n  border-radius: 0;\n\n  &,\n  &:active,\n  &.active,\n  &[disabled],\n  fieldset[disabled] & {\n    background-color: transparent;\n    @include box-shadow(none);\n  }\n  &,\n  &:hover,\n  &:focus,\n  &:active {\n    border-color: transparent;\n  }\n  &:hover,\n  &:focus {\n    color: $link-hover-color;\n    text-decoration: $link-hover-decoration;\n    background-color: transparent;\n  }\n  &[disabled],\n  fieldset[disabled] & {\n    &:hover,\n    &:focus {\n      color: $btn-link-disabled-color;\n      text-decoration: none;\n    }\n  }\n}\n\n\n// Button Sizes\n// --------------------------------------------------\n\n.btn-lg {\n  // line-height: ensure even-numbered height of button next to large input\n  @include button-size($padding-large-vertical, $padding-large-horizontal, $font-size-large, $line-height-large, $btn-border-radius-large);\n}\n.btn-sm {\n  // line-height: ensure proper height of button next to small input\n  @include button-size($padding-small-vertical, $padding-small-horizontal, $font-size-small, $line-height-small, $btn-border-radius-small);\n}\n.btn-xs {\n  @include button-size($padding-xs-vertical, $padding-xs-horizontal, $font-size-small, $line-height-small, $btn-border-radius-small);\n}\n\n\n// Block button\n// --------------------------------------------------\n\n.btn-block {\n  display: block;\n  width: 100%;\n}\n\n// Vertically space out multiple block buttons\n.btn-block + .btn-block {\n  margin-top: 5px;\n}\n\n// Specificity overrides\ninput[type=\"submit\"],\ninput[type=\"reset\"],\ninput[type=\"button\"] {\n  &.btn-block {\n    width: 100%;\n  }\n}\n","// Button variants\n//\n// Easily pump out default styles, as well as :hover, :focus, :active,\n// and disabled options for all buttons\n\n@mixin button-variant($color, $background, $border) {\n  color: $color;\n  background-color: $background;\n  border-color: $border;\n\n  &:focus,\n  &.focus {\n    color: $color;\n    background-color: darken($background, 10%);\n        border-color: darken($border, 25%);\n  }\n  &:hover {\n    color: $color;\n    background-color: darken($background, 10%);\n        border-color: darken($border, 12%);\n  }\n  &:active,\n  &.active,\n  .open > &.dropdown-toggle {\n    color: $color;\n    background-color: darken($background, 10%);\n        border-color: darken($border, 12%);\n\n    &:hover,\n    &:focus,\n    &.focus {\n      color: $color;\n      background-color: darken($background, 17%);\n          border-color: darken($border, 25%);\n    }\n  }\n  &:active,\n  &.active,\n  .open > &.dropdown-toggle {\n    background-image: none;\n  }\n  &.disabled,\n  &[disabled],\n  fieldset[disabled] & {\n    &:hover,\n    &:focus,\n    &.focus {\n      background-color: $background;\n          border-color: $border;\n    }\n  }\n\n  .badge {\n    color: $background;\n    background-color: $color;\n  }\n}\n\n// Button sizes\n@mixin button-size($padding-vertical, $padding-horizontal, $font-size, $line-height, $border-radius) {\n  padding: $padding-vertical $padding-horizontal;\n  font-size: $font-size;\n  line-height: $line-height;\n  border-radius: $border-radius;\n}\n","// Opacity\n\n@mixin opacity($opacity) {\n  opacity: $opacity;\n  // IE8 filter\n  $opacity-ie: ($opacity * 100);\n  filter: alpha(opacity=$opacity-ie);\n}\n","//\n// Component animations\n// --------------------------------------------------\n\n// Heads up!\n//\n// We don't use the `.opacity()` mixin here since it causes a bug with text\n// fields in IE7-8. Source: https://github.com/twbs/bootstrap/pull/3552.\n\n.fade {\n  opacity: 0;\n  @include transition(opacity .15s linear);\n  &.in {\n    opacity: 1;\n  }\n}\n\n.collapse {\n  display: none;\n\n  &.in      { display: block; }\n  // [converter] extracted tr&.in to tr.collapse.in\n  // [converter] extracted tbody&.in to tbody.collapse.in\n}\n\ntr.collapse.in    { display: table-row; }\n\ntbody.collapse.in { display: table-row-group; }\n\n.collapsing {\n  position: relative;\n  height: 0;\n  overflow: hidden;\n  @include transition-property(height, visibility);\n  @include transition-duration(.35s);\n  @include transition-timing-function(ease);\n}\n","//\n// Dropdown menus\n// --------------------------------------------------\n\n\n// Dropdown arrow/caret\n.caret {\n  display: inline-block;\n  width: 0;\n  height: 0;\n  margin-left: 2px;\n  vertical-align: middle;\n  border-top:   $caret-width-base dashed;\n  border-top:   $caret-width-base solid \\9; // IE8\n  border-right: $caret-width-base solid transparent;\n  border-left:  $caret-width-base solid transparent;\n}\n\n// The dropdown wrapper (div)\n.dropup,\n.dropdown {\n  position: relative;\n}\n\n// Prevent the focus on the dropdown toggle when closing dropdowns\n.dropdown-toggle:focus {\n  outline: 0;\n}\n\n// The dropdown menu (ul)\n.dropdown-menu {\n  position: absolute;\n  top: 100%;\n  left: 0;\n  z-index: $zindex-dropdown;\n  display: none; // none by default, but block on \"open\" of the menu\n  float: left;\n  min-width: 160px;\n  padding: 5px 0;\n  margin: 2px 0 0; // override default ul\n  list-style: none;\n  font-size: $font-size-base;\n  text-align: left; // Ensures proper alignment if parent has it changed (e.g., modal footer)\n  background-color: $dropdown-bg;\n  border: 1px solid $dropdown-fallback-border; // IE8 fallback\n  border: 1px solid $dropdown-border;\n  border-radius: $border-radius-base;\n  @include box-shadow(0 6px 12px rgba(0,0,0,.175));\n  background-clip: padding-box;\n\n  // Aligns the dropdown menu to right\n  //\n  // Deprecated as of 3.1.0 in favor of `.dropdown-menu-[dir]`\n  &.pull-right {\n    right: 0;\n    left: auto;\n  }\n\n  // Dividers (basically an hr) within the dropdown\n  .divider {\n    @include nav-divider($dropdown-divider-bg);\n  }\n\n  // Links within the dropdown menu\n  > li > a {\n    display: block;\n    padding: 3px 20px;\n    clear: both;\n    font-weight: normal;\n    line-height: $line-height-base;\n    color: $dropdown-link-color;\n    white-space: nowrap; // prevent links from randomly breaking onto new lines\n  }\n}\n\n// Hover/Focus state\n.dropdown-menu > li > a {\n  &:hover,\n  &:focus {\n    text-decoration: none;\n    color: $dropdown-link-hover-color;\n    background-color: $dropdown-link-hover-bg;\n  }\n}\n\n// Active state\n.dropdown-menu > .active > a {\n  &,\n  &:hover,\n  &:focus {\n    color: $dropdown-link-active-color;\n    text-decoration: none;\n    outline: 0;\n    background-color: $dropdown-link-active-bg;\n  }\n}\n\n// Disabled state\n//\n// Gray out text and ensure the hover/focus state remains gray\n\n.dropdown-menu > .disabled > a {\n  &,\n  &:hover,\n  &:focus {\n    color: $dropdown-link-disabled-color;\n  }\n\n  // Nuke hover/focus effects\n  &:hover,\n  &:focus {\n    text-decoration: none;\n    background-color: transparent;\n    background-image: none; // Remove CSS gradient\n    @include reset-filter;\n    cursor: $cursor-disabled;\n  }\n}\n\n// Open state for the dropdown\n.open {\n  // Show the menu\n  > .dropdown-menu {\n    display: block;\n  }\n\n  // Remove the outline when :focus is triggered\n  > a {\n    outline: 0;\n  }\n}\n\n// Menu positioning\n//\n// Add extra class to `.dropdown-menu` to flip the alignment of the dropdown\n// menu with the parent.\n.dropdown-menu-right {\n  left: auto; // Reset the default from `.dropdown-menu`\n  right: 0;\n}\n// With v3, we enabled auto-flipping if you have a dropdown within a right\n// aligned nav component. To enable the undoing of that, we provide an override\n// to restore the default dropdown menu alignment.\n//\n// This is only for left-aligning a dropdown menu within a `.navbar-right` or\n// `.pull-right` nav component.\n.dropdown-menu-left {\n  left: 0;\n  right: auto;\n}\n\n// Dropdown section headers\n.dropdown-header {\n  display: block;\n  padding: 3px 20px;\n  font-size: $font-size-small;\n  line-height: $line-height-base;\n  color: $dropdown-header-color;\n  white-space: nowrap; // as with > li > a\n}\n\n// Backdrop to catch body clicks on mobile, etc.\n.dropdown-backdrop {\n  position: fixed;\n  left: 0;\n  right: 0;\n  bottom: 0;\n  top: 0;\n  z-index: ($zindex-dropdown - 10);\n}\n\n// Right aligned dropdowns\n.pull-right > .dropdown-menu {\n  right: 0;\n  left: auto;\n}\n\n// Allow for dropdowns to go bottom up (aka, dropup-menu)\n//\n// Just add .dropup after the standard .dropdown class and you're set, bro.\n// TODO: abstract this so that the navbar fixed styles are not placed here?\n\n.dropup,\n.navbar-fixed-bottom .dropdown {\n  // Reverse the caret\n  .caret {\n    border-top: 0;\n    border-bottom: $caret-width-base dashed;\n    border-bottom: $caret-width-base solid \\9; // IE8\n    content: \"\";\n  }\n  // Different positioning for bottom up menu\n  .dropdown-menu {\n    top: auto;\n    bottom: 100%;\n    margin-bottom: 2px;\n  }\n}\n\n\n// Component alignment\n//\n// Reiterate per navbar.less and the modified component alignment there.\n\n@media (min-width: $grid-float-breakpoint) {\n  .navbar-right {\n    .dropdown-menu {\n      right: 0; left: auto;\n    }\n    // Necessary for overrides of the default right aligned menu.\n    // Will remove come v4 in all likelihood.\n    .dropdown-menu-left {\n      left: 0; right: auto;\n    }\n  }\n}\n","// Horizontal dividers\n//\n// Dividers (basically an hr) within dropdowns and nav lists\n\n@mixin nav-divider($color: #e5e5e5) {\n  height: 1px;\n  margin: (($line-height-computed / 2) - 1) 0;\n  overflow: hidden;\n  background-color: $color;\n}\n","// Reset filters for IE\n//\n// When you need to remove a gradient background, do not forget to use this to reset\n// the IE filter for IE9 and below.\n\n@mixin reset-filter() {\n  filter: progid:DXImageTransform.Microsoft.gradient(enabled = false);\n}\n","//\n// Button groups\n// --------------------------------------------------\n\n// Make the div behave like a button\n.btn-group,\n.btn-group-vertical {\n  position: relative;\n  display: inline-block;\n  vertical-align: middle; // match .btn alignment given font-size hack above\n  > .btn {\n    position: relative;\n    float: left;\n    // Bring the \"active\" button to the front\n    &:hover,\n    &:focus,\n    &:active,\n    &.active {\n      z-index: 2;\n    }\n  }\n}\n\n// Prevent double borders when buttons are next to each other\n.btn-group {\n  .btn + .btn,\n  .btn + .btn-group,\n  .btn-group + .btn,\n  .btn-group + .btn-group {\n    margin-left: -1px;\n  }\n}\n\n// Optional: Group multiple button groups together for a toolbar\n.btn-toolbar {\n  margin-left: -5px; // Offset the first child's margin\n  @include clearfix;\n\n  .btn,\n  .btn-group,\n  .input-group {\n    float: left;\n  }\n  > .btn,\n  > .btn-group,\n  > .input-group {\n    margin-left: 5px;\n  }\n}\n\n.btn-group > .btn:not(:first-child):not(:last-child):not(.dropdown-toggle) {\n  border-radius: 0;\n}\n\n// Set corners individual because sometimes a single button can be in a .btn-group and we need :first-child and :last-child to both match\n.btn-group > .btn:first-child {\n  margin-left: 0;\n  &:not(:last-child):not(.dropdown-toggle) {\n    @include border-right-radius(0);\n  }\n}\n// Need .dropdown-toggle since :last-child doesn't apply, given that a .dropdown-menu is used immediately after it\n.btn-group > .btn:last-child:not(:first-child),\n.btn-group > .dropdown-toggle:not(:first-child) {\n  @include border-left-radius(0);\n}\n\n// Custom edits for including btn-groups within btn-groups (useful for including dropdown buttons within a btn-group)\n.btn-group > .btn-group {\n  float: left;\n}\n.btn-group > .btn-group:not(:first-child):not(:last-child) > .btn {\n  border-radius: 0;\n}\n.btn-group > .btn-group:first-child:not(:last-child) {\n  > .btn:last-child,\n  > .dropdown-toggle {\n    @include border-right-radius(0);\n  }\n}\n.btn-group > .btn-group:last-child:not(:first-child) > .btn:first-child {\n  @include border-left-radius(0);\n}\n\n// On active and open, don't show outline\n.btn-group .dropdown-toggle:active,\n.btn-group.open .dropdown-toggle {\n  outline: 0;\n}\n\n\n// Sizing\n//\n// Remix the default button sizing classes into new ones for easier manipulation.\n\n.btn-group-xs > .btn { @extend .btn-xs; }\n.btn-group-sm > .btn { @extend .btn-sm; }\n.btn-group-lg > .btn { @extend .btn-lg; }\n\n\n// Split button dropdowns\n// ----------------------\n\n// Give the line between buttons some depth\n.btn-group > .btn + .dropdown-toggle {\n  padding-left: 8px;\n  padding-right: 8px;\n}\n.btn-group > .btn-lg + .dropdown-toggle {\n  padding-left: 12px;\n  padding-right: 12px;\n}\n\n// The clickable button for toggling the menu\n// Remove the gradient and set the same inset shadow as the :active state\n.btn-group.open .dropdown-toggle {\n  @include box-shadow(inset 0 3px 5px rgba(0,0,0,.125));\n\n  // Show no shadow for `.btn-link` since it has no other button styles.\n  &.btn-link {\n    @include box-shadow(none);\n  }\n}\n\n\n// Reposition the caret\n.btn .caret {\n  margin-left: 0;\n}\n// Carets in other button sizes\n.btn-lg .caret {\n  border-width: $caret-width-large $caret-width-large 0;\n  border-bottom-width: 0;\n}\n// Upside down carets for .dropup\n.dropup .btn-lg .caret {\n  border-width: 0 $caret-width-large $caret-width-large;\n}\n\n\n// Vertical button groups\n// ----------------------\n\n.btn-group-vertical {\n  > .btn,\n  > .btn-group,\n  > .btn-group > .btn {\n    display: block;\n    float: none;\n    width: 100%;\n    max-width: 100%;\n  }\n\n  // Clear floats so dropdown menus can be properly placed\n  > .btn-group {\n    @include clearfix;\n    > .btn {\n      float: none;\n    }\n  }\n\n  > .btn + .btn,\n  > .btn + .btn-group,\n  > .btn-group + .btn,\n  > .btn-group + .btn-group {\n    margin-top: -1px;\n    margin-left: 0;\n  }\n}\n\n.btn-group-vertical > .btn {\n  &:not(:first-child):not(:last-child) {\n    border-radius: 0;\n  }\n  &:first-child:not(:last-child) {\n    @include border-top-radius($btn-border-radius-base);\n    @include border-bottom-radius(0);\n  }\n  &:last-child:not(:first-child) {\n    @include border-top-radius(0);\n    @include border-bottom-radius($btn-border-radius-base);\n  }\n}\n.btn-group-vertical > .btn-group:not(:first-child):not(:last-child) > .btn {\n  border-radius: 0;\n}\n.btn-group-vertical > .btn-group:first-child:not(:last-child) {\n  > .btn:last-child,\n  > .dropdown-toggle {\n    @include border-bottom-radius(0);\n  }\n}\n.btn-group-vertical > .btn-group:last-child:not(:first-child) > .btn:first-child {\n  @include border-top-radius(0);\n}\n\n\n// Justified button groups\n// ----------------------\n\n.btn-group-justified {\n  display: table;\n  width: 100%;\n  table-layout: fixed;\n  border-collapse: separate;\n  > .btn,\n  > .btn-group {\n    float: none;\n    display: table-cell;\n    width: 1%;\n  }\n  > .btn-group .btn {\n    width: 100%;\n  }\n\n  > .btn-group .dropdown-menu {\n    left: auto;\n  }\n}\n\n\n// Checkbox and radio options\n//\n// In order to support the browser's form validation feedback, powered by the\n// `required` attribute, we have to \"hide\" the inputs via `clip`. We cannot use\n// `display: none;` or `visibility: hidden;` as that also hides the popover.\n// Simply visually hiding the inputs via `opacity` would leave them clickable in\n// certain cases which is prevented by using `clip` and `pointer-events`.\n// This way, we ensure a DOM element is visible to position the popover from.\n//\n// See https://github.com/twbs/bootstrap/pull/12794 and\n// https://github.com/twbs/bootstrap/pull/14559 for more information.\n\n[data-toggle=\"buttons\"] {\n  > .btn,\n  > .btn-group > .btn {\n    input[type=\"radio\"],\n    input[type=\"checkbox\"] {\n      position: absolute;\n      clip: rect(0,0,0,0);\n      pointer-events: none;\n    }\n  }\n}\n","// Single side border-radius\n\n@mixin border-top-radius($radius) {\n  border-top-right-radius: $radius;\n   border-top-left-radius: $radius;\n}\n@mixin border-right-radius($radius) {\n  border-bottom-right-radius: $radius;\n     border-top-right-radius: $radius;\n}\n@mixin border-bottom-radius($radius) {\n  border-bottom-right-radius: $radius;\n   border-bottom-left-radius: $radius;\n}\n@mixin border-left-radius($radius) {\n  border-bottom-left-radius: $radius;\n     border-top-left-radius: $radius;\n}\n","//\n// Input groups\n// --------------------------------------------------\n\n// Base styles\n// -------------------------\n.input-group {\n  position: relative; // For dropdowns\n  display: table;\n  border-collapse: separate; // prevent input groups from inheriting border styles from table cells when placed within a table\n\n  // Undo padding and float of grid classes\n  &[class*=\"col-\"] {\n    float: none;\n    padding-left: 0;\n    padding-right: 0;\n  }\n\n  .form-control {\n    // Ensure that the input is always above the *appended* addon button for\n    // proper border colors.\n    position: relative;\n    z-index: 2;\n\n    // IE9 fubars the placeholder attribute in text inputs and the arrows on\n    // select elements in input groups. To fix it, we float the input. Details:\n    // https://github.com/twbs/bootstrap/issues/11561#issuecomment-28936855\n    float: left;\n\n    width: 100%;\n    margin-bottom: 0;\n\n    &:focus {\n      z-index: 3;\n    }\n  }\n}\n\n// Sizing options\n//\n// Remix the default form control sizing classes into new ones for easier\n// manipulation.\n\n.input-group-lg > .form-control,\n.input-group-lg > .input-group-addon,\n.input-group-lg > .input-group-btn > .btn {\n  @extend .input-lg;\n}\n.input-group-sm > .form-control,\n.input-group-sm > .input-group-addon,\n.input-group-sm > .input-group-btn > .btn {\n  @extend .input-sm;\n}\n\n\n// Display as table-cell\n// -------------------------\n.input-group-addon,\n.input-group-btn,\n.input-group .form-control {\n  display: table-cell;\n\n  &:not(:first-child):not(:last-child) {\n    border-radius: 0;\n  }\n}\n// Addon and addon wrapper for buttons\n.input-group-addon,\n.input-group-btn {\n  width: 1%;\n  white-space: nowrap;\n  vertical-align: middle; // Match the inputs\n}\n\n// Text input groups\n// -------------------------\n.input-group-addon {\n  padding: $padding-base-vertical $padding-base-horizontal;\n  font-size: $font-size-base;\n  font-weight: normal;\n  line-height: 1;\n  color: $input-color;\n  text-align: center;\n  background-color: $input-group-addon-bg;\n  border: 1px solid $input-group-addon-border-color;\n  border-radius: $input-border-radius;\n\n  // Sizing\n  &.input-sm {\n    padding: $padding-small-vertical $padding-small-horizontal;\n    font-size: $font-size-small;\n    border-radius: $input-border-radius-small;\n  }\n  &.input-lg {\n    padding: $padding-large-vertical $padding-large-horizontal;\n    font-size: $font-size-large;\n    border-radius: $input-border-radius-large;\n  }\n\n  // Nuke default margins from checkboxes and radios to vertically center within.\n  input[type=\"radio\"],\n  input[type=\"checkbox\"] {\n    margin-top: 0;\n  }\n}\n\n// Reset rounded corners\n.input-group .form-control:first-child,\n.input-group-addon:first-child,\n.input-group-btn:first-child > .btn,\n.input-group-btn:first-child > .btn-group > .btn,\n.input-group-btn:first-child > .dropdown-toggle,\n.input-group-btn:last-child > .btn:not(:last-child):not(.dropdown-toggle),\n.input-group-btn:last-child > .btn-group:not(:last-child) > .btn {\n  @include border-right-radius(0);\n}\n.input-group-addon:first-child {\n  border-right: 0;\n}\n.input-group .form-control:last-child,\n.input-group-addon:last-child,\n.input-group-btn:last-child > .btn,\n.input-group-btn:last-child > .btn-group > .btn,\n.input-group-btn:last-child > .dropdown-toggle,\n.input-group-btn:first-child > .btn:not(:first-child),\n.input-group-btn:first-child > .btn-group:not(:first-child) > .btn {\n  @include border-left-radius(0);\n}\n.input-group-addon:last-child {\n  border-left: 0;\n}\n\n// Button input groups\n// -------------------------\n.input-group-btn {\n  position: relative;\n  // Jankily prevent input button groups from wrapping with `white-space` and\n  // `font-size` in combination with `inline-block` on buttons.\n  font-size: 0;\n  white-space: nowrap;\n\n  // Negative margin for spacing, position for bringing hovered/focused/actived\n  // element above the siblings.\n  > .btn {\n    position: relative;\n    + .btn {\n      margin-left: -1px;\n    }\n    // Bring the \"active\" button to the front\n    &:hover,\n    &:focus,\n    &:active {\n      z-index: 2;\n    }\n  }\n\n  // Negative margin to only have a 1px border between the two\n  &:first-child {\n    > .btn,\n    > .btn-group {\n      margin-right: -1px;\n    }\n  }\n  &:last-child {\n    > .btn,\n    > .btn-group {\n      z-index: 2;\n      margin-left: -1px;\n    }\n  }\n}\n","//\n// Navs\n// --------------------------------------------------\n\n\n// Base class\n// --------------------------------------------------\n\n.nav {\n  margin-bottom: 0;\n  padding-left: 0; // Override default ul/ol\n  list-style: none;\n  @include clearfix;\n\n  > li {\n    position: relative;\n    display: block;\n\n    > a {\n      position: relative;\n      display: block;\n      padding: $nav-link-padding;\n      &:hover,\n      &:focus {\n        text-decoration: none;\n        background-color: $nav-link-hover-bg;\n      }\n    }\n\n    // Disabled state sets text to gray and nukes hover/tab effects\n    &.disabled > a {\n      color: $nav-disabled-link-color;\n\n      &:hover,\n      &:focus {\n        color: $nav-disabled-link-hover-color;\n        text-decoration: none;\n        background-color: transparent;\n        cursor: $cursor-disabled;\n      }\n    }\n  }\n\n  // Open dropdowns\n  .open > a {\n    &,\n    &:hover,\n    &:focus {\n      background-color: $nav-link-hover-bg;\n      border-color: $link-color;\n    }\n  }\n\n  // Nav dividers (deprecated with v3.0.1)\n  //\n  // This should have been removed in v3 with the dropping of `.nav-list`, but\n  // we missed it. We don't currently support this anywhere, but in the interest\n  // of maintaining backward compatibility in case you use it, it's deprecated.\n  .nav-divider {\n    @include nav-divider;\n  }\n\n  // Prevent IE8 from misplacing imgs\n  //\n  // See https://github.com/h5bp/html5-boilerplate/issues/984#issuecomment-3985989\n  > li > a > img {\n    max-width: none;\n  }\n}\n\n\n// Tabs\n// -------------------------\n\n// Give the tabs something to sit on\n.nav-tabs {\n  border-bottom: 1px solid $nav-tabs-border-color;\n  > li {\n    float: left;\n    // Make the list-items overlay the bottom border\n    margin-bottom: -1px;\n\n    // Actual tabs (as links)\n    > a {\n      margin-right: 2px;\n      line-height: $line-height-base;\n      border: 1px solid transparent;\n      border-radius: $border-radius-base $border-radius-base 0 0;\n      &:hover {\n        border-color: $nav-tabs-link-hover-border-color $nav-tabs-link-hover-border-color $nav-tabs-border-color;\n      }\n    }\n\n    // Active state, and its :hover to override normal :hover\n    &.active > a {\n      &,\n      &:hover,\n      &:focus {\n        color: $nav-tabs-active-link-hover-color;\n        background-color: $nav-tabs-active-link-hover-bg;\n        border: 1px solid $nav-tabs-active-link-hover-border-color;\n        border-bottom-color: transparent;\n        cursor: default;\n      }\n    }\n  }\n  // pulling this in mainly for less shorthand\n  &.nav-justified {\n    @extend .nav-justified;\n    @extend .nav-tabs-justified;\n  }\n}\n\n\n// Pills\n// -------------------------\n.nav-pills {\n  > li {\n    float: left;\n\n    // Links rendered as pills\n    > a {\n      border-radius: $nav-pills-border-radius;\n    }\n    + li {\n      margin-left: 2px;\n    }\n\n    // Active state\n    &.active > a {\n      &,\n      &:hover,\n      &:focus {\n        color: $nav-pills-active-link-hover-color;\n        background-color: $nav-pills-active-link-hover-bg;\n      }\n    }\n  }\n}\n\n\n// Stacked pills\n.nav-stacked {\n  > li {\n    float: none;\n    + li {\n      margin-top: 2px;\n      margin-left: 0; // no need for this gap between nav items\n    }\n  }\n}\n\n\n// Nav variations\n// --------------------------------------------------\n\n// Justified nav links\n// -------------------------\n\n.nav-justified {\n  width: 100%;\n\n  > li {\n    float: none;\n    > a {\n      text-align: center;\n      margin-bottom: 5px;\n    }\n  }\n\n  > .dropdown .dropdown-menu {\n    top: auto;\n    left: auto;\n  }\n\n  @media (min-width: $screen-sm-min) {\n    > li {\n      display: table-cell;\n      width: 1%;\n      > a {\n        margin-bottom: 0;\n      }\n    }\n  }\n}\n\n// Move borders to anchors instead of bottom of list\n//\n// Mixin for adding on top the shared `.nav-justified` styles for our tabs\n.nav-tabs-justified {\n  border-bottom: 0;\n\n  > li > a {\n    // Override margin from .nav-tabs\n    margin-right: 0;\n    border-radius: $border-radius-base;\n  }\n\n  > .active > a,\n  > .active > a:hover,\n  > .active > a:focus {\n    border: 1px solid $nav-tabs-justified-link-border-color;\n  }\n\n  @media (min-width: $screen-sm-min) {\n    > li > a {\n      border-bottom: 1px solid $nav-tabs-justified-link-border-color;\n      border-radius: $border-radius-base $border-radius-base 0 0;\n    }\n    > .active > a,\n    > .active > a:hover,\n    > .active > a:focus {\n      border-bottom-color: $nav-tabs-justified-active-link-border-color;\n    }\n  }\n}\n\n\n// Tabbable tabs\n// -------------------------\n\n// Hide tabbable panes to start, show them when `.active`\n.tab-content {\n  > .tab-pane {\n    display: none;\n  }\n  > .active {\n    display: block;\n  }\n}\n\n\n// Dropdowns\n// -------------------------\n\n// Specific dropdowns\n.nav-tabs .dropdown-menu {\n  // make dropdown border overlap tab border\n  margin-top: -1px;\n  // Remove the top rounded corners here since there is a hard edge above the menu\n  @include border-top-radius(0);\n}\n","//\n// Navbars\n// --------------------------------------------------\n\n\n// Wrapper and base class\n//\n// Provide a static navbar from which we expand to create full-width, fixed, and\n// other navbar variations.\n\n.navbar {\n  position: relative;\n  min-height: $navbar-height; // Ensure a navbar always shows (e.g., without a .navbar-brand in collapsed mode)\n  margin-bottom: $navbar-margin-bottom;\n  border: 1px solid transparent;\n\n  // Prevent floats from breaking the navbar\n  @include clearfix;\n\n  @media (min-width: $grid-float-breakpoint) {\n    border-radius: $navbar-border-radius;\n  }\n}\n\n\n// Navbar heading\n//\n// Groups `.navbar-brand` and `.navbar-toggle` into a single component for easy\n// styling of responsive aspects.\n\n.navbar-header {\n  @include clearfix;\n\n  @media (min-width: $grid-float-breakpoint) {\n    float: left;\n  }\n}\n\n\n// Navbar collapse (body)\n//\n// Group your navbar content into this for easy collapsing and expanding across\n// various device sizes. By default, this content is collapsed when <768px, but\n// will expand past that for a horizontal display.\n//\n// To start (on mobile devices) the navbar links, forms, and buttons are stacked\n// vertically and include a `max-height` to overflow in case you have too much\n// content for the user's viewport.\n\n.navbar-collapse {\n  overflow-x: visible;\n  padding-right: $navbar-padding-horizontal;\n  padding-left:  $navbar-padding-horizontal;\n  border-top: 1px solid transparent;\n  box-shadow: inset 0 1px 0 rgba(255,255,255,.1);\n  @include clearfix;\n  -webkit-overflow-scrolling: touch;\n\n  &.in {\n    overflow-y: auto;\n  }\n\n  @media (min-width: $grid-float-breakpoint) {\n    width: auto;\n    border-top: 0;\n    box-shadow: none;\n\n    &.collapse {\n      display: block !important;\n      height: auto !important;\n      padding-bottom: 0; // Override default setting\n      overflow: visible !important;\n    }\n\n    &.in {\n      overflow-y: visible;\n    }\n\n    // Undo the collapse side padding for navbars with containers to ensure\n    // alignment of right-aligned contents.\n    .navbar-fixed-top &,\n    .navbar-static-top &,\n    .navbar-fixed-bottom & {\n      padding-left: 0;\n      padding-right: 0;\n    }\n  }\n}\n\n.navbar-fixed-top,\n.navbar-fixed-bottom {\n  .navbar-collapse {\n    max-height: $navbar-collapse-max-height;\n\n    @media (max-device-width: $screen-xs-min) and (orientation: landscape) {\n      max-height: 200px;\n    }\n  }\n}\n\n\n// Both navbar header and collapse\n//\n// When a container is present, change the behavior of the header and collapse.\n\n.container,\n.container-fluid {\n  > .navbar-header,\n  > .navbar-collapse {\n    margin-right: -$navbar-padding-horizontal;\n    margin-left:  -$navbar-padding-horizontal;\n\n    @media (min-width: $grid-float-breakpoint) {\n      margin-right: 0;\n      margin-left:  0;\n    }\n  }\n}\n\n\n//\n// Navbar alignment options\n//\n// Display the navbar across the entirety of the page or fixed it to the top or\n// bottom of the page.\n\n// Static top (unfixed, but 100% wide) navbar\n.navbar-static-top {\n  z-index: $zindex-navbar;\n  border-width: 0 0 1px;\n\n  @media (min-width: $grid-float-breakpoint) {\n    border-radius: 0;\n  }\n}\n\n// Fix the top/bottom navbars when screen real estate supports it\n.navbar-fixed-top,\n.navbar-fixed-bottom {\n  position: fixed;\n  right: 0;\n  left: 0;\n  z-index: $zindex-navbar-fixed;\n\n  // Undo the rounded corners\n  @media (min-width: $grid-float-breakpoint) {\n    border-radius: 0;\n  }\n}\n.navbar-fixed-top {\n  top: 0;\n  border-width: 0 0 1px;\n}\n.navbar-fixed-bottom {\n  bottom: 0;\n  margin-bottom: 0; // override .navbar defaults\n  border-width: 1px 0 0;\n}\n\n\n// Brand/project name\n\n.navbar-brand {\n  float: left;\n  padding: $navbar-padding-vertical $navbar-padding-horizontal;\n  font-size: $font-size-large;\n  line-height: $line-height-computed;\n  height: $navbar-height;\n\n  &:hover,\n  &:focus {\n    text-decoration: none;\n  }\n\n  > img {\n    display: block;\n  }\n\n  @media (min-width: $grid-float-breakpoint) {\n    .navbar > .container &,\n    .navbar > .container-fluid & {\n      margin-left: -$navbar-padding-horizontal;\n    }\n  }\n}\n\n\n// Navbar toggle\n//\n// Custom button for toggling the `.navbar-collapse`, powered by the collapse\n// JavaScript plugin.\n\n.navbar-toggle {\n  position: relative;\n  float: right;\n  margin-right: $navbar-padding-horizontal;\n  padding: 9px 10px;\n  @include navbar-vertical-align(34px);\n  background-color: transparent;\n  background-image: none; // Reset unusual Firefox-on-Android default style; see https://github.com/necolas/normalize.css/issues/214\n  border: 1px solid transparent;\n  border-radius: $border-radius-base;\n\n  // We remove the `outline` here, but later compensate by attaching `:hover`\n  // styles to `:focus`.\n  &:focus {\n    outline: 0;\n  }\n\n  // Bars\n  .icon-bar {\n    display: block;\n    width: 22px;\n    height: 2px;\n    border-radius: 1px;\n  }\n  .icon-bar + .icon-bar {\n    margin-top: 4px;\n  }\n\n  @media (min-width: $grid-float-breakpoint) {\n    display: none;\n  }\n}\n\n\n// Navbar nav links\n//\n// Builds on top of the `.nav` components with its own modifier class to make\n// the nav the full height of the horizontal nav (above 768px).\n\n.navbar-nav {\n  margin: ($navbar-padding-vertical / 2) (-$navbar-padding-horizontal);\n\n  > li > a {\n    padding-top:    10px;\n    padding-bottom: 10px;\n    line-height: $line-height-computed;\n  }\n\n  @media (max-width: $grid-float-breakpoint-max) {\n    // Dropdowns get custom display when collapsed\n    .open .dropdown-menu {\n      position: static;\n      float: none;\n      width: auto;\n      margin-top: 0;\n      background-color: transparent;\n      border: 0;\n      box-shadow: none;\n      > li > a,\n      .dropdown-header {\n        padding: 5px 15px 5px 25px;\n      }\n      > li > a {\n        line-height: $line-height-computed;\n        &:hover,\n        &:focus {\n          background-image: none;\n        }\n      }\n    }\n  }\n\n  // Uncollapse the nav\n  @media (min-width: $grid-float-breakpoint) {\n    float: left;\n    margin: 0;\n\n    > li {\n      float: left;\n      > a {\n        padding-top:    $navbar-padding-vertical;\n        padding-bottom: $navbar-padding-vertical;\n      }\n    }\n  }\n}\n\n\n// Navbar form\n//\n// Extension of the `.form-inline` with some extra flavor for optimum display in\n// our navbars.\n\n.navbar-form {\n  margin-left: -$navbar-padding-horizontal;\n  margin-right: -$navbar-padding-horizontal;\n  padding: 10px $navbar-padding-horizontal;\n  border-top: 1px solid transparent;\n  border-bottom: 1px solid transparent;\n  $shadow: inset 0 1px 0 rgba(255,255,255,.1), 0 1px 0 rgba(255,255,255,.1);\n  @include box-shadow($shadow);\n\n  // Mixin behavior for optimum display\n  @include form-inline;\n\n  .form-group {\n    @media (max-width: $grid-float-breakpoint-max) {\n      margin-bottom: 5px;\n\n      &:last-child {\n        margin-bottom: 0;\n      }\n    }\n  }\n\n  // Vertically center in expanded, horizontal navbar\n  @include navbar-vertical-align($input-height-base);\n\n  // Undo 100% width for pull classes\n  @media (min-width: $grid-float-breakpoint) {\n    width: auto;\n    border: 0;\n    margin-left: 0;\n    margin-right: 0;\n    padding-top: 0;\n    padding-bottom: 0;\n    @include box-shadow(none);\n  }\n}\n\n\n// Dropdown menus\n\n// Menu position and menu carets\n.navbar-nav > li > .dropdown-menu {\n  margin-top: 0;\n  @include border-top-radius(0);\n}\n// Menu position and menu caret support for dropups via extra dropup class\n.navbar-fixed-bottom .navbar-nav > li > .dropdown-menu {\n  margin-bottom: 0;\n  @include border-top-radius($navbar-border-radius);\n  @include border-bottom-radius(0);\n}\n\n\n// Buttons in navbars\n//\n// Vertically center a button within a navbar (when *not* in a form).\n\n.navbar-btn {\n  @include navbar-vertical-align($input-height-base);\n\n  &.btn-sm {\n    @include navbar-vertical-align($input-height-small);\n  }\n  &.btn-xs {\n    @include navbar-vertical-align(22);\n  }\n}\n\n\n// Text in navbars\n//\n// Add a class to make any element properly align itself vertically within the navbars.\n\n.navbar-text {\n  @include navbar-vertical-align($line-height-computed);\n\n  @media (min-width: $grid-float-breakpoint) {\n    float: left;\n    margin-left: $navbar-padding-horizontal;\n    margin-right: $navbar-padding-horizontal;\n  }\n}\n\n\n// Component alignment\n//\n// Repurpose the pull utilities as their own navbar utilities to avoid specificity\n// issues with parents and chaining. Only do this when the navbar is uncollapsed\n// though so that navbar contents properly stack and align in mobile.\n//\n// Declared after the navbar components to ensure more specificity on the margins.\n\n@media (min-width: $grid-float-breakpoint) {\n  .navbar-left {\n    float: left !important;\n  }\n  .navbar-right {\n    float: right !important;\n  margin-right: -$navbar-padding-horizontal;\n\n    ~ .navbar-right {\n      margin-right: 0;\n    }\n  }\n}\n\n\n// Alternate navbars\n// --------------------------------------------------\n\n// Default navbar\n.navbar-default {\n  background-color: $navbar-default-bg;\n  border-color: $navbar-default-border;\n\n  .navbar-brand {\n    color: $navbar-default-brand-color;\n    &:hover,\n    &:focus {\n      color: $navbar-default-brand-hover-color;\n      background-color: $navbar-default-brand-hover-bg;\n    }\n  }\n\n  .navbar-text {\n    color: $navbar-default-color;\n  }\n\n  .navbar-nav {\n    > li > a {\n      color: $navbar-default-link-color;\n\n      &:hover,\n      &:focus {\n        color: $navbar-default-link-hover-color;\n        background-color: $navbar-default-link-hover-bg;\n      }\n    }\n    > .active > a {\n      &,\n      &:hover,\n      &:focus {\n        color: $navbar-default-link-active-color;\n        background-color: $navbar-default-link-active-bg;\n      }\n    }\n    > .disabled > a {\n      &,\n      &:hover,\n      &:focus {\n        color: $navbar-default-link-disabled-color;\n        background-color: $navbar-default-link-disabled-bg;\n      }\n    }\n  }\n\n  .navbar-toggle {\n    border-color: $navbar-default-toggle-border-color;\n    &:hover,\n    &:focus {\n      background-color: $navbar-default-toggle-hover-bg;\n    }\n    .icon-bar {\n      background-color: $navbar-default-toggle-icon-bar-bg;\n    }\n  }\n\n  .navbar-collapse,\n  .navbar-form {\n    border-color: $navbar-default-border;\n  }\n\n  // Dropdown menu items\n  .navbar-nav {\n    // Remove background color from open dropdown\n    > .open > a {\n      &,\n      &:hover,\n      &:focus {\n        background-color: $navbar-default-link-active-bg;\n        color: $navbar-default-link-active-color;\n      }\n    }\n\n    @media (max-width: $grid-float-breakpoint-max) {\n      // Dropdowns get custom display when collapsed\n      .open .dropdown-menu {\n        > li > a {\n          color: $navbar-default-link-color;\n          &:hover,\n          &:focus {\n            color: $navbar-default-link-hover-color;\n            background-color: $navbar-default-link-hover-bg;\n          }\n        }\n        > .active > a {\n          &,\n          &:hover,\n          &:focus {\n            color: $navbar-default-link-active-color;\n            background-color: $navbar-default-link-active-bg;\n          }\n        }\n        > .disabled > a {\n          &,\n          &:hover,\n          &:focus {\n            color: $navbar-default-link-disabled-color;\n            background-color: $navbar-default-link-disabled-bg;\n          }\n        }\n      }\n    }\n  }\n\n\n  // Links in navbars\n  //\n  // Add a class to ensure links outside the navbar nav are colored correctly.\n\n  .navbar-link {\n    color: $navbar-default-link-color;\n    &:hover {\n      color: $navbar-default-link-hover-color;\n    }\n  }\n\n  .btn-link {\n    color: $navbar-default-link-color;\n    &:hover,\n    &:focus {\n      color: $navbar-default-link-hover-color;\n    }\n    &[disabled],\n    fieldset[disabled] & {\n      &:hover,\n      &:focus {\n        color: $navbar-default-link-disabled-color;\n      }\n    }\n  }\n}\n\n// Inverse navbar\n\n.navbar-inverse {\n  background-color: $navbar-inverse-bg;\n  border-color: $navbar-inverse-border;\n\n  .navbar-brand {\n    color: $navbar-inverse-brand-color;\n    &:hover,\n    &:focus {\n      color: $navbar-inverse-brand-hover-color;\n      background-color: $navbar-inverse-brand-hover-bg;\n    }\n  }\n\n  .navbar-text {\n    color: $navbar-inverse-color;\n  }\n\n  .navbar-nav {\n    > li > a {\n      color: $navbar-inverse-link-color;\n\n      &:hover,\n      &:focus {\n        color: $navbar-inverse-link-hover-color;\n        background-color: $navbar-inverse-link-hover-bg;\n      }\n    }\n    > .active > a {\n      &,\n      &:hover,\n      &:focus {\n        color: $navbar-inverse-link-active-color;\n        background-color: $navbar-inverse-link-active-bg;\n      }\n    }\n    > .disabled > a {\n      &,\n      &:hover,\n      &:focus {\n        color: $navbar-inverse-link-disabled-color;\n        background-color: $navbar-inverse-link-disabled-bg;\n      }\n    }\n  }\n\n  // Darken the responsive nav toggle\n  .navbar-toggle {\n    border-color: $navbar-inverse-toggle-border-color;\n    &:hover,\n    &:focus {\n      background-color: $navbar-inverse-toggle-hover-bg;\n    }\n    .icon-bar {\n      background-color: $navbar-inverse-toggle-icon-bar-bg;\n    }\n  }\n\n  .navbar-collapse,\n  .navbar-form {\n    border-color: darken($navbar-inverse-bg, 7%);\n  }\n\n  // Dropdowns\n  .navbar-nav {\n    > .open > a {\n      &,\n      &:hover,\n      &:focus {\n        background-color: $navbar-inverse-link-active-bg;\n        color: $navbar-inverse-link-active-color;\n      }\n    }\n\n    @media (max-width: $grid-float-breakpoint-max) {\n      // Dropdowns get custom display\n      .open .dropdown-menu {\n        > .dropdown-header {\n          border-color: $navbar-inverse-border;\n        }\n        .divider {\n          background-color: $navbar-inverse-border;\n        }\n        > li > a {\n          color: $navbar-inverse-link-color;\n          &:hover,\n          &:focus {\n            color: $navbar-inverse-link-hover-color;\n            background-color: $navbar-inverse-link-hover-bg;\n          }\n        }\n        > .active > a {\n          &,\n          &:hover,\n          &:focus {\n            color: $navbar-inverse-link-active-color;\n            background-color: $navbar-inverse-link-active-bg;\n          }\n        }\n        > .disabled > a {\n          &,\n          &:hover,\n          &:focus {\n            color: $navbar-inverse-link-disabled-color;\n            background-color: $navbar-inverse-link-disabled-bg;\n          }\n        }\n      }\n    }\n  }\n\n  .navbar-link {\n    color: $navbar-inverse-link-color;\n    &:hover {\n      color: $navbar-inverse-link-hover-color;\n    }\n  }\n\n  .btn-link {\n    color: $navbar-inverse-link-color;\n    &:hover,\n    &:focus {\n      color: $navbar-inverse-link-hover-color;\n    }\n    &[disabled],\n    fieldset[disabled] & {\n      &:hover,\n      &:focus {\n        color: $navbar-inverse-link-disabled-color;\n      }\n    }\n  }\n}\n","// Navbar vertical align\n//\n// Vertically center elements in the navbar.\n// Example: an element has a height of 30px, so write out `.navbar-vertical-align(30px);` to calculate the appropriate top margin.\n\n@mixin navbar-vertical-align($element-height) {\n  margin-top: (($navbar-height - $element-height) / 2);\n  margin-bottom: (($navbar-height - $element-height) / 2);\n}\n","//\n// Breadcrumbs\n// --------------------------------------------------\n\n\n.breadcrumb {\n  padding: $breadcrumb-padding-vertical $breadcrumb-padding-horizontal;\n  margin-bottom: $line-height-computed;\n  list-style: none;\n  background-color: $breadcrumb-bg;\n  border-radius: $border-radius-base;\n\n  > li {\n    display: inline-block;\n\n    + li:before {\n      // [converter] Workaround for https://github.com/sass/libsass/issues/1115\n      $nbsp: \"\\00a0\";\n      content: \"#{$breadcrumb-separator}#{$nbsp}\"; // Unicode space added since inline-block means non-collapsing white-space\n      padding: 0 5px;\n      color: $breadcrumb-color;\n    }\n  }\n\n  > .active {\n    color: $breadcrumb-active-color;\n  }\n}\n","//\n// Pagination (multiple pages)\n// --------------------------------------------------\n.pagination {\n  display: inline-block;\n  padding-left: 0;\n  margin: $line-height-computed 0;\n  border-radius: $border-radius-base;\n\n  > li {\n    display: inline; // Remove list-style and block-level defaults\n    > a,\n    > span {\n      position: relative;\n      float: left; // Collapse white-space\n      padding: $padding-base-vertical $padding-base-horizontal;\n      line-height: $line-height-base;\n      text-decoration: none;\n      color: $pagination-color;\n      background-color: $pagination-bg;\n      border: 1px solid $pagination-border;\n      margin-left: -1px;\n    }\n    &:first-child {\n      > a,\n      > span {\n        margin-left: 0;\n        @include border-left-radius($border-radius-base);\n      }\n    }\n    &:last-child {\n      > a,\n      > span {\n        @include border-right-radius($border-radius-base);\n      }\n    }\n  }\n\n  > li > a,\n  > li > span {\n    &:hover,\n    &:focus {\n      z-index: 2;\n      color: $pagination-hover-color;\n      background-color: $pagination-hover-bg;\n      border-color: $pagination-hover-border;\n    }\n  }\n\n  > .active > a,\n  > .active > span {\n    &,\n    &:hover,\n    &:focus {\n      z-index: 3;\n      color: $pagination-active-color;\n      background-color: $pagination-active-bg;\n      border-color: $pagination-active-border;\n      cursor: default;\n    }\n  }\n\n  > .disabled {\n    > span,\n    > span:hover,\n    > span:focus,\n    > a,\n    > a:hover,\n    > a:focus {\n      color: $pagination-disabled-color;\n      background-color: $pagination-disabled-bg;\n      border-color: $pagination-disabled-border;\n      cursor: $cursor-disabled;\n    }\n  }\n}\n\n// Sizing\n// --------------------------------------------------\n\n// Large\n.pagination-lg {\n  @include pagination-size($padding-large-vertical, $padding-large-horizontal, $font-size-large, $line-height-large, $border-radius-large);\n}\n\n// Small\n.pagination-sm {\n  @include pagination-size($padding-small-vertical, $padding-small-horizontal, $font-size-small, $line-height-small, $border-radius-small);\n}\n","// Pagination\n\n@mixin pagination-size($padding-vertical, $padding-horizontal, $font-size, $line-height, $border-radius) {\n  > li {\n    > a,\n    > span {\n      padding: $padding-vertical $padding-horizontal;\n      font-size: $font-size;\n      line-height: $line-height;\n    }\n    &:first-child {\n      > a,\n      > span {\n        @include border-left-radius($border-radius);\n      }\n    }\n    &:last-child {\n      > a,\n      > span {\n        @include border-right-radius($border-radius);\n      }\n    }\n  }\n}\n","//\n// Pager pagination\n// --------------------------------------------------\n\n\n.pager {\n  padding-left: 0;\n  margin: $line-height-computed 0;\n  list-style: none;\n  text-align: center;\n  @include clearfix;\n  li {\n    display: inline;\n    > a,\n    > span {\n      display: inline-block;\n      padding: 5px 14px;\n      background-color: $pager-bg;\n      border: 1px solid $pager-border;\n      border-radius: $pager-border-radius;\n    }\n\n    > a:hover,\n    > a:focus {\n      text-decoration: none;\n      background-color: $pager-hover-bg;\n    }\n  }\n\n  .next {\n    > a,\n    > span {\n      float: right;\n    }\n  }\n\n  .previous {\n    > a,\n    > span {\n      float: left;\n    }\n  }\n\n  .disabled {\n    > a,\n    > a:hover,\n    > a:focus,\n    > span {\n      color: $pager-disabled-color;\n      background-color: $pager-bg;\n      cursor: $cursor-disabled;\n    }\n  }\n}\n","//\n// Labels\n// --------------------------------------------------\n\n.label {\n  display: inline;\n  padding: .2em .6em .3em;\n  font-size: 75%;\n  font-weight: bold;\n  line-height: 1;\n  color: $label-color;\n  text-align: center;\n  white-space: nowrap;\n  vertical-align: baseline;\n  border-radius: .25em;\n\n  // [converter] extracted a& to a.label\n\n  // Empty labels collapse automatically (not available in IE8)\n  &:empty {\n    display: none;\n  }\n\n  // Quick fix for labels in buttons\n  .btn & {\n    position: relative;\n    top: -1px;\n  }\n}\n\n// Add hover effects, but only for links\na.label {\n  &:hover,\n  &:focus {\n    color: $label-link-hover-color;\n    text-decoration: none;\n    cursor: pointer;\n  }\n}\n\n// Colors\n// Contextual variations (linked labels get darker on :hover)\n\n.label-default {\n  @include label-variant($label-default-bg);\n}\n\n.label-primary {\n  @include label-variant($label-primary-bg);\n}\n\n.label-success {\n  @include label-variant($label-success-bg);\n}\n\n.label-info {\n  @include label-variant($label-info-bg);\n}\n\n.label-warning {\n  @include label-variant($label-warning-bg);\n}\n\n.label-danger {\n  @include label-variant($label-danger-bg);\n}\n","// Labels\n\n@mixin label-variant($color) {\n  background-color: $color;\n\n  &[href] {\n    &:hover,\n    &:focus {\n      background-color: darken($color, 10%);\n    }\n  }\n}\n","//\n// Badges\n// --------------------------------------------------\n\n\n// Base class\n.badge {\n  display: inline-block;\n  min-width: 10px;\n  padding: 3px 7px;\n  font-size: $font-size-small;\n  font-weight: $badge-font-weight;\n  color: $badge-color;\n  line-height: $badge-line-height;\n  vertical-align: middle;\n  white-space: nowrap;\n  text-align: center;\n  background-color: $badge-bg;\n  border-radius: $badge-border-radius;\n\n  // Empty badges collapse automatically (not available in IE8)\n  &:empty {\n    display: none;\n  }\n\n  // Quick fix for badges in buttons\n  .btn & {\n    position: relative;\n    top: -1px;\n  }\n\n  .btn-xs &,\n  .btn-group-xs > .btn & {\n    top: 0;\n    padding: 1px 5px;\n  }\n\n  // [converter] extracted a& to a.badge\n\n  // Account for badges in navs\n  .list-group-item.active > &,\n  .nav-pills > .active > a > & {\n    color: $badge-active-color;\n    background-color: $badge-active-bg;\n  }\n\n  .list-group-item > & {\n    float: right;\n  }\n\n  .list-group-item > & + & {\n    margin-right: 5px;\n  }\n\n  .nav-pills > li > a > & {\n    margin-left: 3px;\n  }\n}\n\n// Hover state, but only for links\na.badge {\n  &:hover,\n  &:focus {\n    color: $badge-link-hover-color;\n    text-decoration: none;\n    cursor: pointer;\n  }\n}\n","//\n// Jumbotron\n// --------------------------------------------------\n\n\n.jumbotron {\n  padding-top:    $jumbotron-padding;\n  padding-bottom: $jumbotron-padding;\n  margin-bottom: $jumbotron-padding;\n  color: $jumbotron-color;\n  background-color: $jumbotron-bg;\n\n  h1,\n  .h1 {\n    color: $jumbotron-heading-color;\n  }\n\n  p {\n    margin-bottom: ($jumbotron-padding / 2);\n    font-size: $jumbotron-font-size;\n    font-weight: 200;\n  }\n\n  > hr {\n    border-top-color: darken($jumbotron-bg, 10%);\n  }\n\n  .container &,\n  .container-fluid & {\n    border-radius: $border-radius-large; // Only round corners at higher resolutions if contained in a container\n    padding-left:  ($grid-gutter-width / 2);\n    padding-right: ($grid-gutter-width / 2);\n  }\n\n  .container {\n    max-width: 100%;\n  }\n\n  @media screen and (min-width: $screen-sm-min) {\n    padding-top:    ($jumbotron-padding * 1.6);\n    padding-bottom: ($jumbotron-padding * 1.6);\n\n    .container &,\n    .container-fluid & {\n      padding-left:  ($jumbotron-padding * 2);\n      padding-right: ($jumbotron-padding * 2);\n    }\n\n    h1,\n    .h1 {\n      font-size: $jumbotron-heading-font-size;\n    }\n  }\n}\n","//\n// Thumbnails\n// --------------------------------------------------\n\n\n// Mixin and adjust the regular image class\n.thumbnail {\n  display: block;\n  padding: $thumbnail-padding;\n  margin-bottom: $line-height-computed;\n  line-height: $line-height-base;\n  background-color: $thumbnail-bg;\n  border: 1px solid $thumbnail-border;\n  border-radius: $thumbnail-border-radius;\n  @include transition(border .2s ease-in-out);\n\n  > img,\n  a > img {\n    @include img-responsive;\n    margin-left: auto;\n    margin-right: auto;\n  }\n\n  // [converter] extracted a&:hover, a&:focus, a&.active to a.thumbnail:hover, a.thumbnail:focus, a.thumbnail.active\n\n  // Image captions\n  .caption {\n    padding: $thumbnail-caption-padding;\n    color: $thumbnail-caption-color;\n  }\n}\n\n// Add a hover state for linked versions only\na.thumbnail:hover,\na.thumbnail:focus,\na.thumbnail.active {\n  border-color: $link-color;\n}\n","//\n// Alerts\n// --------------------------------------------------\n\n\n// Base styles\n// -------------------------\n\n.alert {\n  padding: $alert-padding;\n  margin-bottom: $line-height-computed;\n  border: 1px solid transparent;\n  border-radius: $alert-border-radius;\n\n  // Headings for larger alerts\n  h4 {\n    margin-top: 0;\n    // Specified for the h4 to prevent conflicts of changing $headings-color\n    color: inherit;\n  }\n\n  // Provide class for links that match alerts\n  .alert-link {\n    font-weight: $alert-link-font-weight;\n  }\n\n  // Improve alignment and spacing of inner content\n  > p,\n  > ul {\n    margin-bottom: 0;\n  }\n\n  > p + p {\n    margin-top: 5px;\n  }\n}\n\n// Dismissible alerts\n//\n// Expand the right padding and account for the close button's positioning.\n\n.alert-dismissable, // The misspelled .alert-dismissable was deprecated in 3.2.0.\n.alert-dismissible {\n  padding-right: ($alert-padding + 20);\n\n  // Adjust close link position\n  .close {\n    position: relative;\n    top: -2px;\n    right: -21px;\n    color: inherit;\n  }\n}\n\n// Alternate styles\n//\n// Generate contextual modifier classes for colorizing the alert.\n\n.alert-success {\n  @include alert-variant($alert-success-bg, $alert-success-border, $alert-success-text);\n}\n\n.alert-info {\n  @include alert-variant($alert-info-bg, $alert-info-border, $alert-info-text);\n}\n\n.alert-warning {\n  @include alert-variant($alert-warning-bg, $alert-warning-border, $alert-warning-text);\n}\n\n.alert-danger {\n  @include alert-variant($alert-danger-bg, $alert-danger-border, $alert-danger-text);\n}\n","// Alerts\n\n@mixin alert-variant($background, $border, $text-color) {\n  background-color: $background;\n  border-color: $border;\n  color: $text-color;\n\n  hr {\n    border-top-color: darken($border, 5%);\n  }\n  .alert-link {\n    color: darken($text-color, 10%);\n  }\n}\n","//\n// Progress bars\n// --------------------------------------------------\n\n\n// Bar animations\n// -------------------------\n\n// WebKit\n@-webkit-keyframes progress-bar-stripes {\n  from  { background-position: 40px 0; }\n  to    { background-position: 0 0; }\n}\n\n// Spec and IE10+\n@keyframes progress-bar-stripes {\n  from  { background-position: 40px 0; }\n  to    { background-position: 0 0; }\n}\n\n\n// Bar itself\n// -------------------------\n\n// Outer container\n.progress {\n  overflow: hidden;\n  height: $line-height-computed;\n  margin-bottom: $line-height-computed;\n  background-color: $progress-bg;\n  border-radius: $progress-border-radius;\n  @include box-shadow(inset 0 1px 2px rgba(0,0,0,.1));\n}\n\n// Bar of progress\n.progress-bar {\n  float: left;\n  width: 0%;\n  height: 100%;\n  font-size: $font-size-small;\n  line-height: $line-height-computed;\n  color: $progress-bar-color;\n  text-align: center;\n  background-color: $progress-bar-bg;\n  @include box-shadow(inset 0 -1px 0 rgba(0,0,0,.15));\n  @include transition(width .6s ease);\n}\n\n// Striped bars\n//\n// `.progress-striped .progress-bar` is deprecated as of v3.2.0 in favor of the\n// `.progress-bar-striped` class, which you just add to an existing\n// `.progress-bar`.\n.progress-striped .progress-bar,\n.progress-bar-striped {\n  @include gradient-striped;\n  background-size: 40px 40px;\n}\n\n// Call animation for the active one\n//\n// `.progress.active .progress-bar` is deprecated as of v3.2.0 in favor of the\n// `.progress-bar.active` approach.\n.progress.active .progress-bar,\n.progress-bar.active {\n  @include animation(progress-bar-stripes 2s linear infinite);\n}\n\n\n// Variations\n// -------------------------\n\n.progress-bar-success {\n  @include progress-bar-variant($progress-bar-success-bg);\n}\n\n.progress-bar-info {\n  @include progress-bar-variant($progress-bar-info-bg);\n}\n\n.progress-bar-warning {\n  @include progress-bar-variant($progress-bar-warning-bg);\n}\n\n.progress-bar-danger {\n  @include progress-bar-variant($progress-bar-danger-bg);\n}\n","// Gradients\n\n\n\n// Horizontal gradient, from left to right\n//\n// Creates two color stops, start and end, by specifying a color and position for each color stop.\n// Color stops are not available in IE9 and below.\n@mixin gradient-horizontal($start-color: #555, $end-color: #333, $start-percent: 0%, $end-percent: 100%) {\n  background-image: -webkit-linear-gradient(left, $start-color $start-percent, $end-color $end-percent); // Safari 5.1-6, Chrome 10+\n  background-image: -o-linear-gradient(left, $start-color $start-percent, $end-color $end-percent); // Opera 12\n  background-image: linear-gradient(to right, $start-color $start-percent, $end-color $end-percent); // Standard, IE10, Firefox 16+, Opera 12.10+, Safari 7+, Chrome 26+\n  background-repeat: repeat-x;\n  filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#{ie-hex-str($start-color)}', endColorstr='#{ie-hex-str($end-color)}', GradientType=1); // IE9 and down\n}\n\n// Vertical gradient, from top to bottom\n//\n// Creates two color stops, start and end, by specifying a color and position for each color stop.\n// Color stops are not available in IE9 and below.\n@mixin gradient-vertical($start-color: #555, $end-color: #333, $start-percent: 0%, $end-percent: 100%) {\n  background-image: -webkit-linear-gradient(top, $start-color $start-percent, $end-color $end-percent);  // Safari 5.1-6, Chrome 10+\n  background-image: -o-linear-gradient(top, $start-color $start-percent, $end-color $end-percent);  // Opera 12\n  background-image: linear-gradient(to bottom, $start-color $start-percent, $end-color $end-percent); // Standard, IE10, Firefox 16+, Opera 12.10+, Safari 7+, Chrome 26+\n  background-repeat: repeat-x;\n  filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#{ie-hex-str($start-color)}', endColorstr='#{ie-hex-str($end-color)}', GradientType=0); // IE9 and down\n}\n\n@mixin gradient-directional($start-color: #555, $end-color: #333, $deg: 45deg) {\n  background-repeat: repeat-x;\n  background-image: -webkit-linear-gradient($deg, $start-color, $end-color); // Safari 5.1-6, Chrome 10+\n  background-image: -o-linear-gradient($deg, $start-color, $end-color); // Opera 12\n  background-image: linear-gradient($deg, $start-color, $end-color); // Standard, IE10, Firefox 16+, Opera 12.10+, Safari 7+, Chrome 26+\n}\n@mixin gradient-horizontal-three-colors($start-color: #00b3ee, $mid-color: #7a43b6, $color-stop: 50%, $end-color: #c3325f) {\n  background-image: -webkit-linear-gradient(left, $start-color, $mid-color $color-stop, $end-color);\n  background-image: -o-linear-gradient(left, $start-color, $mid-color $color-stop, $end-color);\n  background-image: linear-gradient(to right, $start-color, $mid-color $color-stop, $end-color);\n  background-repeat: no-repeat;\n  filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#{ie-hex-str($start-color)}', endColorstr='#{ie-hex-str($end-color)}', GradientType=1); // IE9 and down, gets no color-stop at all for proper fallback\n}\n@mixin gradient-vertical-three-colors($start-color: #00b3ee, $mid-color: #7a43b6, $color-stop: 50%, $end-color: #c3325f) {\n  background-image: -webkit-linear-gradient($start-color, $mid-color $color-stop, $end-color);\n  background-image: -o-linear-gradient($start-color, $mid-color $color-stop, $end-color);\n  background-image: linear-gradient($start-color, $mid-color $color-stop, $end-color);\n  background-repeat: no-repeat;\n  filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#{ie-hex-str($start-color)}', endColorstr='#{ie-hex-str($end-color)}', GradientType=0); // IE9 and down, gets no color-stop at all for proper fallback\n}\n@mixin gradient-radial($inner-color: #555, $outer-color: #333) {\n  background-image: -webkit-radial-gradient(circle, $inner-color, $outer-color);\n  background-image: radial-gradient(circle, $inner-color, $outer-color);\n  background-repeat: no-repeat;\n}\n@mixin gradient-striped($color: rgba(255,255,255,.15), $angle: 45deg) {\n  background-image: -webkit-linear-gradient($angle, $color 25%, transparent 25%, transparent 50%, $color 50%, $color 75%, transparent 75%, transparent);\n  background-image: -o-linear-gradient($angle, $color 25%, transparent 25%, transparent 50%, $color 50%, $color 75%, transparent 75%, transparent);\n  background-image: linear-gradient($angle, $color 25%, transparent 25%, transparent 50%, $color 50%, $color 75%, transparent 75%, transparent);\n}\n","// Progress bars\n\n@mixin progress-bar-variant($color) {\n  background-color: $color;\n\n  // Deprecated parent class requirement as of v3.2.0\n  .progress-striped & {\n    @include gradient-striped;\n  }\n}\n",".media {\n  // Proper spacing between instances of .media\n  margin-top: 15px;\n\n  &:first-child {\n    margin-top: 0;\n  }\n}\n\n.media,\n.media-body {\n  zoom: 1;\n  overflow: hidden;\n}\n\n.media-body {\n  width: 10000px;\n}\n\n.media-object {\n  display: block;\n\n  // Fix collapse in webkit from max-width: 100% and display: table-cell.\n  &.img-thumbnail {\n    max-width: none;\n  }\n}\n\n.media-right,\n.media > .pull-right {\n  padding-left: 10px;\n}\n\n.media-left,\n.media > .pull-left {\n  padding-right: 10px;\n}\n\n.media-left,\n.media-right,\n.media-body {\n  display: table-cell;\n  vertical-align: top;\n}\n\n.media-middle {\n  vertical-align: middle;\n}\n\n.media-bottom {\n  vertical-align: bottom;\n}\n\n// Reset margins on headings for tighter default spacing\n.media-heading {\n  margin-top: 0;\n  margin-bottom: 5px;\n}\n\n// Media list variation\n//\n// Undo default ul/ol styles\n.media-list {\n  padding-left: 0;\n  list-style: none;\n}\n","//\n// List groups\n// --------------------------------------------------\n\n\n// Base class\n//\n// Easily usable on 
    ,
      , or
      .\n\n.list-group {\n // No need to set list-style: none; since .list-group-item is block level\n margin-bottom: 20px;\n padding-left: 0; // reset padding because ul and ol\n}\n\n\n// Individual list items\n//\n// Use on `li`s or `div`s within the `.list-group` parent.\n\n.list-group-item {\n position: relative;\n display: block;\n padding: 10px 15px;\n // Place the border on the list items and negative margin up for better styling\n margin-bottom: -1px;\n background-color: $list-group-bg;\n border: 1px solid $list-group-border;\n\n // Round the first and last items\n &:first-child {\n @include border-top-radius($list-group-border-radius);\n }\n &:last-child {\n margin-bottom: 0;\n @include border-bottom-radius($list-group-border-radius);\n }\n}\n\n\n// Interactive list items\n//\n// Use anchor or button elements instead of `li`s or `div`s to create interactive items.\n// Includes an extra `.active` modifier class for showing selected items.\n\na.list-group-item,\nbutton.list-group-item {\n color: $list-group-link-color;\n\n .list-group-item-heading {\n color: $list-group-link-heading-color;\n }\n\n // Hover state\n &:hover,\n &:focus {\n text-decoration: none;\n color: $list-group-link-hover-color;\n background-color: $list-group-hover-bg;\n }\n}\n\nbutton.list-group-item {\n width: 100%;\n text-align: left;\n}\n\n.list-group-item {\n // Disabled state\n &.disabled,\n &.disabled:hover,\n &.disabled:focus {\n background-color: $list-group-disabled-bg;\n color: $list-group-disabled-color;\n cursor: $cursor-disabled;\n\n // Force color to inherit for custom content\n .list-group-item-heading {\n color: inherit;\n }\n .list-group-item-text {\n color: $list-group-disabled-text-color;\n }\n }\n\n // Active class on item itself, not parent\n &.active,\n &.active:hover,\n &.active:focus {\n z-index: 2; // Place active items above their siblings for proper border styling\n color: $list-group-active-color;\n background-color: $list-group-active-bg;\n border-color: $list-group-active-border;\n\n // Force color to inherit for custom content\n .list-group-item-heading,\n .list-group-item-heading > small,\n .list-group-item-heading > .small {\n color: inherit;\n }\n .list-group-item-text {\n color: $list-group-active-text-color;\n }\n }\n}\n\n\n// Contextual variants\n//\n// Add modifier classes to change text and background color on individual items.\n// Organizationally, this must come after the `:hover` states.\n\n@include list-group-item-variant(success, $state-success-bg, $state-success-text);\n@include list-group-item-variant(info, $state-info-bg, $state-info-text);\n@include list-group-item-variant(warning, $state-warning-bg, $state-warning-text);\n@include list-group-item-variant(danger, $state-danger-bg, $state-danger-text);\n\n\n// Custom content options\n//\n// Extra classes for creating well-formatted content within `.list-group-item`s.\n\n.list-group-item-heading {\n margin-top: 0;\n margin-bottom: 5px;\n}\n.list-group-item-text {\n margin-bottom: 0;\n line-height: 1.3;\n}\n","// List Groups\n\n@mixin list-group-item-variant($state, $background, $color) {\n .list-group-item-#{$state} {\n color: $color;\n background-color: $background;\n\n // [converter] extracted a&, button& to a.list-group-item-#{$state}, button.list-group-item-#{$state}\n }\n\n a.list-group-item-#{$state},\n button.list-group-item-#{$state} {\n color: $color;\n\n .list-group-item-heading {\n color: inherit;\n }\n\n &:hover,\n &:focus {\n color: $color;\n background-color: darken($background, 5%);\n }\n &.active,\n &.active:hover,\n &.active:focus {\n color: #fff;\n background-color: $color;\n border-color: $color;\n }\n }\n}\n","//\n// Panels\n// --------------------------------------------------\n\n\n// Base class\n.panel {\n margin-bottom: $line-height-computed;\n background-color: $panel-bg;\n border: 1px solid transparent;\n border-radius: $panel-border-radius;\n @include box-shadow(0 1px 1px rgba(0,0,0,.05));\n}\n\n// Panel contents\n.panel-body {\n padding: $panel-body-padding;\n @include clearfix;\n}\n\n// Optional heading\n.panel-heading {\n padding: $panel-heading-padding;\n border-bottom: 1px solid transparent;\n @include border-top-radius(($panel-border-radius - 1));\n\n > .dropdown .dropdown-toggle {\n color: inherit;\n }\n}\n\n// Within heading, strip any `h*` tag of its default margins for spacing.\n.panel-title {\n margin-top: 0;\n margin-bottom: 0;\n font-size: ceil(($font-size-base * 1.125));\n color: inherit;\n\n > a,\n > small,\n > .small,\n > small > a,\n > .small > a {\n color: inherit;\n }\n}\n\n// Optional footer (stays gray in every modifier class)\n.panel-footer {\n padding: $panel-footer-padding;\n background-color: $panel-footer-bg;\n border-top: 1px solid $panel-inner-border;\n @include border-bottom-radius(($panel-border-radius - 1));\n}\n\n\n// List groups in panels\n//\n// By default, space out list group content from panel headings to account for\n// any kind of custom content between the two.\n\n.panel {\n > .list-group,\n > .panel-collapse > .list-group {\n margin-bottom: 0;\n\n .list-group-item {\n border-width: 1px 0;\n border-radius: 0;\n }\n\n // Add border top radius for first one\n &:first-child {\n .list-group-item:first-child {\n border-top: 0;\n @include border-top-radius(($panel-border-radius - 1));\n }\n }\n\n // Add border bottom radius for last one\n &:last-child {\n .list-group-item:last-child {\n border-bottom: 0;\n @include border-bottom-radius(($panel-border-radius - 1));\n }\n }\n }\n > .panel-heading + .panel-collapse > .list-group {\n .list-group-item:first-child {\n @include border-top-radius(0);\n }\n }\n}\n// Collapse space between when there's no additional content.\n.panel-heading + .list-group {\n .list-group-item:first-child {\n border-top-width: 0;\n }\n}\n.list-group + .panel-footer {\n border-top-width: 0;\n}\n\n// Tables in panels\n//\n// Place a non-bordered `.table` within a panel (not within a `.panel-body`) and\n// watch it go full width.\n\n.panel {\n > .table,\n > .table-responsive > .table,\n > .panel-collapse > .table {\n margin-bottom: 0;\n\n caption {\n padding-left: $panel-body-padding;\n padding-right: $panel-body-padding;\n }\n }\n // Add border top radius for first one\n > .table:first-child,\n > .table-responsive:first-child > .table:first-child {\n @include border-top-radius(($panel-border-radius - 1));\n\n > thead:first-child,\n > tbody:first-child {\n > tr:first-child {\n border-top-left-radius: ($panel-border-radius - 1);\n border-top-right-radius: ($panel-border-radius - 1);\n\n td:first-child,\n th:first-child {\n border-top-left-radius: ($panel-border-radius - 1);\n }\n td:last-child,\n th:last-child {\n border-top-right-radius: ($panel-border-radius - 1);\n }\n }\n }\n }\n // Add border bottom radius for last one\n > .table:last-child,\n > .table-responsive:last-child > .table:last-child {\n @include border-bottom-radius(($panel-border-radius - 1));\n\n > tbody:last-child,\n > tfoot:last-child {\n > tr:last-child {\n border-bottom-left-radius: ($panel-border-radius - 1);\n border-bottom-right-radius: ($panel-border-radius - 1);\n\n td:first-child,\n th:first-child {\n border-bottom-left-radius: ($panel-border-radius - 1);\n }\n td:last-child,\n th:last-child {\n border-bottom-right-radius: ($panel-border-radius - 1);\n }\n }\n }\n }\n > .panel-body + .table,\n > .panel-body + .table-responsive,\n > .table + .panel-body,\n > .table-responsive + .panel-body {\n border-top: 1px solid $table-border-color;\n }\n > .table > tbody:first-child > tr:first-child th,\n > .table > tbody:first-child > tr:first-child td {\n border-top: 0;\n }\n > .table-bordered,\n > .table-responsive > .table-bordered {\n border: 0;\n > thead,\n > tbody,\n > tfoot {\n > tr {\n > th:first-child,\n > td:first-child {\n border-left: 0;\n }\n > th:last-child,\n > td:last-child {\n border-right: 0;\n }\n }\n }\n > thead,\n > tbody {\n > tr:first-child {\n > td,\n > th {\n border-bottom: 0;\n }\n }\n }\n > tbody,\n > tfoot {\n > tr:last-child {\n > td,\n > th {\n border-bottom: 0;\n }\n }\n }\n }\n > .table-responsive {\n border: 0;\n margin-bottom: 0;\n }\n}\n\n\n// Collapsible panels (aka, accordion)\n//\n// Wrap a series of panels in `.panel-group` to turn them into an accordion with\n// the help of our collapse JavaScript plugin.\n\n.panel-group {\n margin-bottom: $line-height-computed;\n\n // Tighten up margin so it's only between panels\n .panel {\n margin-bottom: 0;\n border-radius: $panel-border-radius;\n\n + .panel {\n margin-top: 5px;\n }\n }\n\n .panel-heading {\n border-bottom: 0;\n\n + .panel-collapse > .panel-body,\n + .panel-collapse > .list-group {\n border-top: 1px solid $panel-inner-border;\n }\n }\n\n .panel-footer {\n border-top: 0;\n + .panel-collapse .panel-body {\n border-bottom: 1px solid $panel-inner-border;\n }\n }\n}\n\n\n// Contextual variations\n.panel-default {\n @include panel-variant($panel-default-border, $panel-default-text, $panel-default-heading-bg, $panel-default-border);\n}\n.panel-primary {\n @include panel-variant($panel-primary-border, $panel-primary-text, $panel-primary-heading-bg, $panel-primary-border);\n}\n.panel-success {\n @include panel-variant($panel-success-border, $panel-success-text, $panel-success-heading-bg, $panel-success-border);\n}\n.panel-info {\n @include panel-variant($panel-info-border, $panel-info-text, $panel-info-heading-bg, $panel-info-border);\n}\n.panel-warning {\n @include panel-variant($panel-warning-border, $panel-warning-text, $panel-warning-heading-bg, $panel-warning-border);\n}\n.panel-danger {\n @include panel-variant($panel-danger-border, $panel-danger-text, $panel-danger-heading-bg, $panel-danger-border);\n}\n","// Panels\n\n@mixin panel-variant($border, $heading-text-color, $heading-bg-color, $heading-border) {\n border-color: $border;\n\n & > .panel-heading {\n color: $heading-text-color;\n background-color: $heading-bg-color;\n border-color: $heading-border;\n\n + .panel-collapse > .panel-body {\n border-top-color: $border;\n }\n .badge {\n color: $heading-bg-color;\n background-color: $heading-text-color;\n }\n }\n & > .panel-footer {\n + .panel-collapse > .panel-body {\n border-bottom-color: $border;\n }\n }\n}\n","// Embeds responsive\n//\n// Credit: Nicolas Gallagher and SUIT CSS.\n\n.embed-responsive {\n position: relative;\n display: block;\n height: 0;\n padding: 0;\n overflow: hidden;\n\n .embed-responsive-item,\n iframe,\n embed,\n object,\n video {\n position: absolute;\n top: 0;\n left: 0;\n bottom: 0;\n height: 100%;\n width: 100%;\n border: 0;\n }\n}\n\n// Modifier class for 16:9 aspect ratio\n.embed-responsive-16by9 {\n padding-bottom: 56.25%;\n}\n\n// Modifier class for 4:3 aspect ratio\n.embed-responsive-4by3 {\n padding-bottom: 75%;\n}\n","//\n// Wells\n// --------------------------------------------------\n\n// Customized\n.well-abstract {\n padding-left: 20px;\n padding-right: 20px;\n padding-top: 12px;\n padding-bottom: 4px;\n border-radius: 7px;\n min-height: 1px;\n // margin-bottom: 10px;\n margin-top: 15px;\n background-color: $gray-lighter;\n border: 2px solid $well-border;\n @include box-shadow(inset 0 1px 1px rgba(0,0,0,.05));\n blockquote {\n border-color: #ddd;\n border-color: rgba(0,0,0,.15);\n }\n}\n\n\n.well-bib {\n padding-left: 20px;\n padding-right: 20px;\n padding-top: 6px;\n padding-bottom: 2px;\n border-radius: 3px;\n min-height: 1px;\n // margin-bottom: 10px;\n margin-top: 4px;\n font-size: ($font-size-base - 5);\n background-color: $gray-lighter;\n border: 2px solid $well-border;\n @include box-shadow(inset 0 1px 1px rgba(0,0,0,.05));\n blockquote {\n border-color: #ddd;\n border-color: rgba(0,0,0,.15);\n }\n}\n\n// Base class\n.well {\n min-height: 20px;\n padding: 19px;\n margin-bottom: 20px;\n background-color: $well-bg;\n border: 1px solid $well-border;\n border-radius: $border-radius-base;\n @include box-shadow(inset 0 1px 1px rgba(0,0,0,.05));\n blockquote {\n border-color: #ddd;\n border-color: rgba(0,0,0,.15);\n }\n}\n\n// Sizes\n.well-lg {\n padding: 24px;\n border-radius: $border-radius-large;\n}\n.well-sm {\n padding: 9px;\n border-radius: $border-radius-small;\n}\n","//\n// Close icons\n// --------------------------------------------------\n\n\n.close {\n float: right;\n font-size: ($font-size-base * 1.5);\n font-weight: $close-font-weight;\n line-height: 1;\n color: $close-color;\n text-shadow: $close-text-shadow;\n @include opacity(.2);\n\n &:hover,\n &:focus {\n color: $close-color;\n text-decoration: none;\n cursor: pointer;\n @include opacity(.5);\n }\n\n // [converter] extracted button& to button.close\n}\n\n// Additional properties for button version\n// iOS requires the button element instead of an anchor tag.\n// If you want the anchor version, it requires `href=\"#\"`.\n// See https://developer.mozilla.org/en-US/docs/Web/Events/click#Safari_Mobile\nbutton.close {\n padding: 0;\n cursor: pointer;\n background: transparent;\n border: 0;\n -webkit-appearance: none;\n}\n","//\n// Modals\n// --------------------------------------------------\n\n// .modal-open - body class for killing the scroll\n// .modal - container to scroll within\n// .modal-dialog - positioning shell for the actual modal\n// .modal-content - actual modal w/ bg and corners and shit\n\n// Kill the scroll on the body\n.modal-open {\n overflow: hidden;\n}\n\n// Container that the modal scrolls within\n.modal {\n display: none;\n overflow: hidden;\n position: fixed;\n top: 0;\n right: 0;\n bottom: 0;\n left: 0;\n z-index: $zindex-modal;\n -webkit-overflow-scrolling: touch;\n\n // Prevent Chrome on Windows from adding a focus outline. For details, see\n // https://github.com/twbs/bootstrap/pull/10951.\n outline: 0;\n\n // When fading in the modal, animate it to slide down\n &.fade .modal-dialog {\n @include translate(0, -25%);\n @include transition-transform(0.3s ease-out);\n }\n &.in .modal-dialog { @include translate(0, 0) }\n}\n.modal-open .modal {\n overflow-x: hidden;\n overflow-y: auto;\n}\n\n// Shell div to position the modal with bottom padding\n.modal-dialog {\n position: relative;\n width: auto;\n margin: 10px;\n}\n\n// Actual modal\n.modal-content {\n position: relative;\n background-color: $modal-content-bg;\n border: 1px solid $modal-content-fallback-border-color; //old browsers fallback (ie8 etc)\n border: 1px solid $modal-content-border-color;\n border-radius: $border-radius-large;\n @include box-shadow(0 3px 9px rgba(0,0,0,.5));\n background-clip: padding-box;\n // Remove focus outline from opened modal\n outline: 0;\n}\n\n// Modal background\n.modal-backdrop {\n position: fixed;\n top: 0;\n right: 0;\n bottom: 0;\n left: 0;\n z-index: $zindex-modal-background;\n background-color: $modal-backdrop-bg;\n // Fade for backdrop\n &.fade { @include opacity(0); }\n &.in { @include opacity($modal-backdrop-opacity); }\n}\n\n// Modal header\n// Top section of the modal w/ title and dismiss\n.modal-header {\n padding: $modal-title-padding;\n border-bottom: 1px solid $modal-header-border-color;\n @include clearfix;\n}\n// Close icon\n.modal-header .close {\n margin-top: -2px;\n}\n\n// Title text within header\n.modal-title {\n margin: 0;\n line-height: $modal-title-line-height;\n}\n\n// Modal body\n// Where all modal content resides (sibling of .modal-header and .modal-footer)\n.modal-body {\n position: relative;\n padding: $modal-inner-padding;\n}\n\n// Footer (for actions)\n.modal-footer {\n padding: $modal-inner-padding;\n text-align: right; // right align buttons\n border-top: 1px solid $modal-footer-border-color;\n @include clearfix; // clear it in case folks use .pull-* classes on buttons\n\n // Properly space out buttons\n .btn + .btn {\n margin-left: 5px;\n margin-bottom: 0; // account for input[type=\"submit\"] which gets the bottom margin like all other inputs\n }\n // but override that for button groups\n .btn-group .btn + .btn {\n margin-left: -1px;\n }\n // and override it for block buttons as well\n .btn-block + .btn-block {\n margin-left: 0;\n }\n}\n\n// Measure scrollbar width for padding body during modal show/hide\n.modal-scrollbar-measure {\n position: absolute;\n top: -9999px;\n width: 50px;\n height: 50px;\n overflow: scroll;\n}\n\n// Scale up the modal\n@media (min-width: $screen-sm-min) {\n // Automatically set modal's width for larger viewports\n .modal-dialog {\n width: $modal-md;\n margin: 30px auto;\n }\n .modal-content {\n @include box-shadow(0 5px 15px rgba(0,0,0,.5));\n }\n\n // Modal sizes\n .modal-sm { width: $modal-sm; }\n}\n\n@media (min-width: $screen-md-min) {\n .modal-lg { width: $modal-lg; }\n}\n","//\n// Tooltips\n// --------------------------------------------------\n\n\n// Base class\n.tooltip {\n position: absolute;\n z-index: $zindex-tooltip;\n display: block;\n // Our parent element can be arbitrary since tooltips are by default inserted as a sibling of their target element.\n // So reset our font and text properties to avoid inheriting weird values.\n @include reset-text;\n font-size: $font-size-small;\n\n @include opacity(0);\n\n &.in { @include opacity($tooltip-opacity); }\n &.top { margin-top: -3px; padding: $tooltip-arrow-width 0; }\n &.right { margin-left: 3px; padding: 0 $tooltip-arrow-width; }\n &.bottom { margin-top: 3px; padding: $tooltip-arrow-width 0; }\n &.left { margin-left: -3px; padding: 0 $tooltip-arrow-width; }\n}\n\n// Wrapper for the tooltip content\n.tooltip-inner {\n max-width: $tooltip-max-width;\n padding: 3px 8px;\n color: $tooltip-color;\n text-align: center;\n background-color: $tooltip-bg;\n border-radius: $border-radius-base;\n}\n\n// Arrows\n.tooltip-arrow {\n position: absolute;\n width: 0;\n height: 0;\n border-color: transparent;\n border-style: solid;\n}\n// Note: Deprecated .top-left, .top-right, .bottom-left, and .bottom-right as of v3.3.1\n.tooltip {\n &.top .tooltip-arrow {\n bottom: 0;\n left: 50%;\n margin-left: -$tooltip-arrow-width;\n border-width: $tooltip-arrow-width $tooltip-arrow-width 0;\n border-top-color: $tooltip-arrow-color;\n }\n &.top-left .tooltip-arrow {\n bottom: 0;\n right: $tooltip-arrow-width;\n margin-bottom: -$tooltip-arrow-width;\n border-width: $tooltip-arrow-width $tooltip-arrow-width 0;\n border-top-color: $tooltip-arrow-color;\n }\n &.top-right .tooltip-arrow {\n bottom: 0;\n left: $tooltip-arrow-width;\n margin-bottom: -$tooltip-arrow-width;\n border-width: $tooltip-arrow-width $tooltip-arrow-width 0;\n border-top-color: $tooltip-arrow-color;\n }\n &.right .tooltip-arrow {\n top: 50%;\n left: 0;\n margin-top: -$tooltip-arrow-width;\n border-width: $tooltip-arrow-width $tooltip-arrow-width $tooltip-arrow-width 0;\n border-right-color: $tooltip-arrow-color;\n }\n &.left .tooltip-arrow {\n top: 50%;\n right: 0;\n margin-top: -$tooltip-arrow-width;\n border-width: $tooltip-arrow-width 0 $tooltip-arrow-width $tooltip-arrow-width;\n border-left-color: $tooltip-arrow-color;\n }\n &.bottom .tooltip-arrow {\n top: 0;\n left: 50%;\n margin-left: -$tooltip-arrow-width;\n border-width: 0 $tooltip-arrow-width $tooltip-arrow-width;\n border-bottom-color: $tooltip-arrow-color;\n }\n &.bottom-left .tooltip-arrow {\n top: 0;\n right: $tooltip-arrow-width;\n margin-top: -$tooltip-arrow-width;\n border-width: 0 $tooltip-arrow-width $tooltip-arrow-width;\n border-bottom-color: $tooltip-arrow-color;\n }\n &.bottom-right .tooltip-arrow {\n top: 0;\n left: $tooltip-arrow-width;\n margin-top: -$tooltip-arrow-width;\n border-width: 0 $tooltip-arrow-width $tooltip-arrow-width;\n border-bottom-color: $tooltip-arrow-color;\n }\n}\n","@mixin reset-text() {\n font-family: $font-family-base;\n // We deliberately do NOT reset font-size.\n font-style: normal;\n font-weight: normal;\n letter-spacing: normal;\n line-break: auto;\n line-height: $line-height-base;\n text-align: left; // Fallback for where `start` is not supported\n text-align: start;\n text-decoration: none;\n text-shadow: none;\n text-transform: none;\n white-space: normal;\n word-break: normal;\n word-spacing: normal;\n word-wrap: normal;\n}\n","//\n// Popovers\n// --------------------------------------------------\n\n\n.popover {\n position: absolute;\n top: 0;\n left: 0;\n z-index: $zindex-popover;\n display: none;\n max-width: $popover-max-width;\n padding: 1px;\n // Our parent element can be arbitrary since popovers are by default inserted as a sibling of their target element.\n // So reset our font and text properties to avoid inheriting weird values.\n @include reset-text;\n font-size: $font-size-base;\n\n background-color: $popover-bg;\n background-clip: padding-box;\n border: 1px solid $popover-fallback-border-color;\n border: 1px solid $popover-border-color;\n border-radius: $border-radius-large;\n @include box-shadow(0 5px 10px rgba(0,0,0,.2));\n\n // Offset the popover to account for the popover arrow\n &.top { margin-top: -$popover-arrow-width; }\n &.right { margin-left: $popover-arrow-width; }\n &.bottom { margin-top: $popover-arrow-width; }\n &.left { margin-left: -$popover-arrow-width; }\n}\n\n.popover-title {\n margin: 0; // reset heading margin\n padding: 8px 14px;\n font-size: $font-size-base;\n background-color: $popover-title-bg;\n border-bottom: 1px solid darken($popover-title-bg, 5%);\n border-radius: ($border-radius-large - 1) ($border-radius-large - 1) 0 0;\n}\n\n.popover-content {\n padding: 9px 14px;\n}\n\n// Arrows\n//\n// .arrow is outer, .arrow:after is inner\n\n.popover > .arrow {\n &,\n &:after {\n position: absolute;\n display: block;\n width: 0;\n height: 0;\n border-color: transparent;\n border-style: solid;\n }\n}\n.popover > .arrow {\n border-width: $popover-arrow-outer-width;\n}\n.popover > .arrow:after {\n border-width: $popover-arrow-width;\n content: \"\";\n}\n\n.popover {\n &.top > .arrow {\n left: 50%;\n margin-left: -$popover-arrow-outer-width;\n border-bottom-width: 0;\n border-top-color: $popover-arrow-outer-fallback-color; // IE8 fallback\n border-top-color: $popover-arrow-outer-color;\n bottom: -$popover-arrow-outer-width;\n &:after {\n content: \" \";\n bottom: 1px;\n margin-left: -$popover-arrow-width;\n border-bottom-width: 0;\n border-top-color: $popover-arrow-color;\n }\n }\n &.right > .arrow {\n top: 50%;\n left: -$popover-arrow-outer-width;\n margin-top: -$popover-arrow-outer-width;\n border-left-width: 0;\n border-right-color: $popover-arrow-outer-fallback-color; // IE8 fallback\n border-right-color: $popover-arrow-outer-color;\n &:after {\n content: \" \";\n left: 1px;\n bottom: -$popover-arrow-width;\n border-left-width: 0;\n border-right-color: $popover-arrow-color;\n }\n }\n &.bottom > .arrow {\n left: 50%;\n margin-left: -$popover-arrow-outer-width;\n border-top-width: 0;\n border-bottom-color: $popover-arrow-outer-fallback-color; // IE8 fallback\n border-bottom-color: $popover-arrow-outer-color;\n top: -$popover-arrow-outer-width;\n &:after {\n content: \" \";\n top: 1px;\n margin-left: -$popover-arrow-width;\n border-top-width: 0;\n border-bottom-color: $popover-arrow-color;\n }\n }\n\n &.left > .arrow {\n top: 50%;\n right: -$popover-arrow-outer-width;\n margin-top: -$popover-arrow-outer-width;\n border-right-width: 0;\n border-left-color: $popover-arrow-outer-fallback-color; // IE8 fallback\n border-left-color: $popover-arrow-outer-color;\n &:after {\n content: \" \";\n right: 1px;\n border-right-width: 0;\n border-left-color: $popover-arrow-color;\n bottom: -$popover-arrow-width;\n }\n }\n}\n","//\n// Carousel\n// --------------------------------------------------\n\n\n// Wrapper for the slide container and indicators\n.carousel {\n position: relative;\n}\n\n.carousel-inner {\n position: relative;\n overflow: hidden;\n width: 100%;\n\n > .item {\n display: none;\n position: relative;\n @include transition(.6s ease-in-out left);\n\n // Account for jankitude on images\n > img,\n > a > img {\n @include img-responsive;\n line-height: 1;\n }\n\n // WebKit CSS3 transforms for supported devices\n @media all and (transform-3d), (-webkit-transform-3d) {\n @include transition-transform(0.6s ease-in-out);\n @include backface-visibility(hidden);\n @include perspective(1000px);\n\n &.next,\n &.active.right {\n @include translate3d(100%, 0, 0);\n left: 0;\n }\n &.prev,\n &.active.left {\n @include translate3d(-100%, 0, 0);\n left: 0;\n }\n &.next.left,\n &.prev.right,\n &.active {\n @include translate3d(0, 0, 0);\n left: 0;\n }\n }\n }\n\n > .active,\n > .next,\n > .prev {\n display: block;\n }\n\n > .active {\n left: 0;\n }\n\n > .next,\n > .prev {\n position: absolute;\n top: 0;\n width: 100%;\n }\n\n > .next {\n left: 100%;\n }\n > .prev {\n left: -100%;\n }\n > .next.left,\n > .prev.right {\n left: 0;\n }\n\n > .active.left {\n left: -100%;\n }\n > .active.right {\n left: 100%;\n }\n\n}\n\n// Left/right controls for nav\n// ---------------------------\n\n.carousel-control {\n position: absolute;\n top: 0;\n left: 0;\n bottom: 0;\n width: $carousel-control-width;\n @include opacity($carousel-control-opacity);\n font-size: $carousel-control-font-size;\n color: $carousel-control-color;\n text-align: center;\n text-shadow: $carousel-text-shadow;\n background-color: rgba(0, 0, 0, 0); // Fix IE9 click-thru bug\n // We can't have this transition here because WebKit cancels the carousel\n // animation if you trip this while in the middle of another animation.\n\n // Set gradients for backgrounds\n &.left {\n @include gradient-horizontal($start-color: rgba(0,0,0,.0001), $end-color: rgba(0,0,0,.0001));\n }\n &.right {\n left: auto;\n right: 0;\n @include gradient-horizontal($start-color: rgba(0,0,0,.0001), $end-color: rgba(0,0,0,.0001));\n }\n\n // Hover/focus state\n &:hover,\n &:focus {\n outline: 0;\n color: $carousel-control-color;\n text-decoration: none;\n @include opacity(.9);\n }\n\n // Toggles\n .icon-prev,\n .icon-next,\n .glyphicon-chevron-left,\n .glyphicon-chevron-right {\n position: absolute;\n top: 50%;\n margin-top: -10px;\n z-index: 5;\n display: inline-block;\n }\n .icon-prev,\n .glyphicon-chevron-left {\n left: 50%;\n margin-left: -10px;\n }\n .icon-next,\n .glyphicon-chevron-right {\n right: 50%;\n margin-right: -10px;\n }\n .icon-prev,\n .icon-next {\n width: 20px;\n height: 20px;\n line-height: 1;\n font-family: serif;\n }\n\n\n .icon-prev {\n &:before {\n content: '\\2039';// SINGLE LEFT-POINTING ANGLE QUOTATION MARK (U+2039)\n }\n }\n .icon-next {\n &:before {\n content: '\\203a';// SINGLE RIGHT-POINTING ANGLE QUOTATION MARK (U+203A)\n }\n }\n}\n\n// Optional indicator pips\n//\n// Add an unordered list with the following class and add a list item for each\n// slide your carousel holds.\n\n.carousel-indicators {\n position: absolute;\n bottom: 10px;\n left: 50%;\n z-index: 15;\n width: 60%;\n margin-left: -30%;\n padding-left: 0;\n list-style: none;\n text-align: center;\n\n li {\n display: inline-block;\n width: 10px;\n height: 10px;\n margin: 1px;\n text-indent: -999px;\n border: 1px solid $carousel-indicator-border-color;\n border-radius: 10px;\n cursor: pointer;\n\n // IE8-9 hack for event handling\n //\n // Internet Explorer 8-9 does not support clicks on elements without a set\n // `background-color`. We cannot use `filter` since that's not viewed as a\n // background color by the browser. Thus, a hack is needed.\n // See https://developer.mozilla.org/en-US/docs/Web/Events/click#Internet_Explorer\n //\n // For IE8, we set solid black as it doesn't support `rgba()`. For IE9, we\n // set alpha transparency for the best results possible.\n background-color: #000 \\9; // IE8\n background-color: rgba(0,0,0,0); // IE9\n }\n .active {\n margin: 0;\n width: 12px;\n height: 12px;\n background-color: $carousel-indicator-active-bg;\n }\n}\n\n// Optional captions\n// -----------------------------\n// Hidden by default for smaller viewports\n.carousel-caption {\n position: absolute;\n left: 15%;\n right: 15%;\n bottom: 20px;\n z-index: 10;\n padding-top: 20px;\n padding-bottom: 20px;\n color: $carousel-caption-color;\n text-align: center;\n text-shadow: $carousel-text-shadow;\n & .btn {\n text-shadow: none; // No shadow for button elements in carousel-caption\n }\n}\n\n\n// Scale up controls for tablets and up\n@media screen and (min-width: $screen-sm-min) {\n\n // Scale up the controls a smidge\n .carousel-control {\n .glyphicon-chevron-left,\n .glyphicon-chevron-right,\n .icon-prev,\n .icon-next {\n width: ($carousel-control-font-size * 1.5);\n height: ($carousel-control-font-size * 1.5);\n margin-top: ($carousel-control-font-size / -2);\n font-size: ($carousel-control-font-size * 1.5);\n }\n .glyphicon-chevron-left,\n .icon-prev {\n margin-left: ($carousel-control-font-size / -2);\n }\n .glyphicon-chevron-right,\n .icon-next {\n margin-right: ($carousel-control-font-size / -2);\n }\n }\n\n // Show and left align the captions\n .carousel-caption {\n left: 20%;\n right: 20%;\n padding-bottom: 30px;\n }\n\n // Move up the indicators\n .carousel-indicators {\n bottom: 20px;\n }\n}\n","//\n// Utility classes\n// --------------------------------------------------\n\n\n// Floats\n// -------------------------\n\n.clearfix {\n @include clearfix;\n}\n.center-block {\n @include center-block;\n}\n.pull-right {\n float: right !important;\n}\n.pull-left {\n float: left !important;\n}\n\n\n// Toggling content\n// -------------------------\n\n// Note: Deprecated .hide in favor of .hidden or .sr-only (as appropriate) in v3.0.1\n.hide {\n display: none !important;\n}\n.show {\n display: block !important;\n}\n.invisible {\n visibility: hidden;\n}\n.text-hide {\n @include text-hide;\n}\n\n\n// Hide from screenreaders and browsers\n//\n// Credit: HTML5 Boilerplate\n\n.hidden {\n display: none !important;\n}\n\n\n// For Affix plugin\n// -------------------------\n\n.affix {\n position: fixed;\n}\n","// Center-align a block level element\n\n@mixin center-block() {\n display: block;\n margin-left: auto;\n margin-right: auto;\n}\n","// CSS image replacement\n//\n// Heads up! v3 launched with only `.hide-text()`, but per our pattern for\n// mixins being reused as classes with the same name, this doesn't hold up. As\n// of v3.0.1 we have added `.text-hide()` and deprecated `.hide-text()`.\n//\n// Source: https://github.com/h5bp/html5-boilerplate/commit/aa0396eae757\n\n// Deprecated as of v3.0.1 (has been removed in v4)\n@mixin hide-text() {\n font: 0/0 a;\n color: transparent;\n text-shadow: none;\n background-color: transparent;\n border: 0;\n}\n\n// New mixin to use as of v3.0.1\n@mixin text-hide() {\n @include hide-text;\n}\n","//\n// Responsive: Utility classes\n// --------------------------------------------------\n\n\n// IE10 in Windows (Phone) 8\n//\n// Support for responsive views via media queries is kind of borked in IE10, for\n// Surface/desktop in split view and for Windows Phone 8. This particular fix\n// must be accompanied by a snippet of JavaScript to sniff the user agent and\n// apply some conditional CSS to *only* the Surface/desktop Windows 8. Look at\n// our Getting Started page for more information on this bug.\n//\n// For more information, see the following:\n//\n// Issue: https://github.com/twbs/bootstrap/issues/10497\n// Docs: http://getbootstrap.com/getting-started/#support-ie10-width\n// Source: http://timkadlec.com/2013/01/windows-phone-8-and-device-width/\n// Source: http://timkadlec.com/2012/10/ie10-snap-mode-and-responsive-design/\n\n@at-root {\n @-ms-viewport {\n width: device-width;\n }\n}\n\n\n// Visibility utilities\n// Note: Deprecated .visible-xs, .visible-sm, .visible-md, and .visible-lg as of v3.2.0\n\n@include responsive-invisibility('.visible-xs');\n@include responsive-invisibility('.visible-sm');\n@include responsive-invisibility('.visible-md');\n@include responsive-invisibility('.visible-lg');\n\n.visible-xs-block,\n.visible-xs-inline,\n.visible-xs-inline-block,\n.visible-sm-block,\n.visible-sm-inline,\n.visible-sm-inline-block,\n.visible-md-block,\n.visible-md-inline,\n.visible-md-inline-block,\n.visible-lg-block,\n.visible-lg-inline,\n.visible-lg-inline-block {\n display: none !important;\n}\n\n@media (max-width: $screen-xs-max) {\n @include responsive-visibility('.visible-xs');\n}\n.visible-xs-block {\n @media (max-width: $screen-xs-max) {\n display: block !important;\n }\n}\n.visible-xs-inline {\n @media (max-width: $screen-xs-max) {\n display: inline !important;\n }\n}\n.visible-xs-inline-block {\n @media (max-width: $screen-xs-max) {\n display: inline-block !important;\n }\n}\n\n@media (min-width: $screen-sm-min) and (max-width: $screen-sm-max) {\n @include responsive-visibility('.visible-sm');\n}\n.visible-sm-block {\n @media (min-width: $screen-sm-min) and (max-width: $screen-sm-max) {\n display: block !important;\n }\n}\n.visible-sm-inline {\n @media (min-width: $screen-sm-min) and (max-width: $screen-sm-max) {\n display: inline !important;\n }\n}\n.visible-sm-inline-block {\n @media (min-width: $screen-sm-min) and (max-width: $screen-sm-max) {\n display: inline-block !important;\n }\n}\n\n@media (min-width: $screen-md-min) and (max-width: $screen-md-max) {\n @include responsive-visibility('.visible-md');\n}\n.visible-md-block {\n @media (min-width: $screen-md-min) and (max-width: $screen-md-max) {\n display: block !important;\n }\n}\n.visible-md-inline {\n @media (min-width: $screen-md-min) and (max-width: $screen-md-max) {\n display: inline !important;\n }\n}\n.visible-md-inline-block {\n @media (min-width: $screen-md-min) and (max-width: $screen-md-max) {\n display: inline-block !important;\n }\n}\n\n@media (min-width: $screen-lg-min) {\n @include responsive-visibility('.visible-lg');\n}\n.visible-lg-block {\n @media (min-width: $screen-lg-min) {\n display: block !important;\n }\n}\n.visible-lg-inline {\n @media (min-width: $screen-lg-min) {\n display: inline !important;\n }\n}\n.visible-lg-inline-block {\n @media (min-width: $screen-lg-min) {\n display: inline-block !important;\n }\n}\n\n@media (max-width: $screen-xs-max) {\n @include responsive-invisibility('.hidden-xs');\n}\n\n@media (min-width: $screen-sm-min) and (max-width: $screen-sm-max) {\n @include responsive-invisibility('.hidden-sm');\n}\n\n@media (min-width: $screen-md-min) and (max-width: $screen-md-max) {\n @include responsive-invisibility('.hidden-md');\n}\n\n@media (min-width: $screen-lg-min) {\n @include responsive-invisibility('.hidden-lg');\n}\n\n\n// Print utilities\n//\n// Media queries are placed on the inside to be mixin-friendly.\n\n// Note: Deprecated .visible-print as of v3.2.0\n\n@include responsive-invisibility('.visible-print');\n\n@media print {\n @include responsive-visibility('.visible-print');\n}\n.visible-print-block {\n display: none !important;\n\n @media print {\n display: block !important;\n }\n}\n.visible-print-inline {\n display: none !important;\n\n @media print {\n display: inline !important;\n }\n}\n.visible-print-inline-block {\n display: none !important;\n\n @media print {\n display: inline-block !important;\n }\n}\n\n@media print {\n @include responsive-invisibility('.hidden-print');\n}\n","// Responsive utilities\n\n//\n// More easily include all the states for responsive-utilities.less.\n// [converter] $parent hack\n@mixin responsive-visibility($parent) {\n #{$parent} {\n display: block !important;\n }\n table#{$parent} { display: table !important; }\n tr#{$parent} { display: table-row !important; }\n th#{$parent},\n td#{$parent} { display: table-cell !important; }\n}\n\n// [converter] $parent hack\n@mixin responsive-invisibility($parent) {\n #{$parent} {\n display: none !important;\n }\n}\n","/*******************************************************************************\n * Variables used throughout the theme.\n * To adjust anything, simply edit the variables below and rebuild the theme.\n ******************************************************************************/\n\n\n// Colors\n$red-color: #FF3636 !default;\n$red-color-dark: #B71C1C !default;\n$orange-color: #F29105 !default;\n$blue-color: #0076df !default;\n$blue-color-dark: #00369f !default;\n$cyan-color: #2698BA !default;\n$light-cyan-color: lighten($cyan-color, 25%);\n$green-color: #00ab37 !default;\n$green-color-lime: #B7D12A !default;\n$green-color-dark: #009f06 !default;\n$green-color-light: #ddffdd !default;\n$green-color-bright: #11D68B !default;\n$purple-color: #B509AC !default;\n$light-purple-color: lighten($purple-color, 25%);\n$pink-color: #f92080 !default;\n$pink-color-light: #ffdddd !default;\n$yellow-color: #efcc00 !default;\n\n$grey-color: #828282 !default;\n$grey-color-light: lighten($grey-color, 40%);\n$grey-color-dark: #1C1C1D;\n$grey-900: #212529;\n\n$white-color: #ffffff !default;\n$black-color: #000000 !default;\n\n\n// Theme colors\n\n$code-bg-color-light: rgba($purple-color, 0.05);\n$code-bg-color-dark: #2c3237 !default;","/*******************************************************************************\n * Styles for the base elements of the theme.\n ******************************************************************************/\n\n// Typography\n\nblockquote {\n background: var(--global-bg-color);\n border-left: 2px solid var(--global-theme-color);\n margin: 1.5em 10px;\n padding: 0.5em 10px;\n font-size: 1.2rem;\n}\n\n// Math\n\n.equation {\n margin-bottom: 1rem;\n text-align: center;\n}\n\n// Caption\n\n.caption {\n font-size: 0.875rem;\n margin-top: 0.75rem;\n margin-bottom: 1.5rem;\n text-align: center;\n}\n\n\n// Citation\n\n.citation, .citation-number {\n color: var(--global-theme-color);\n}\n\n\n\n// Publications\n.citation strong {\n display: block;\n}\n.publications {\n margin-top: 2rem;\n h1 {\n color: var(--global-theme-color);\n font-size: 2rem;\n text-align: center;\n margin-top: 1em;\n margin-bottom: 1em;\n }\n h2 {\n margin-bottom: 1rem;\n span {\n font-size: 1.5rem;\n }\n }\n h2.year {\n color: var(--global-divider-color);\n border-top: 1px solid var(--global-divider-color);\n padding-top: 1rem;\n margin-top: 2rem;\n margin-bottom: -2rem;\n text-align: right;\n }\n ol.bibliography {\n list-style: none;\n padding: 0;\n margin-top: 0;\n\n li {\n margin-bottom: 1rem;\n .abbr {\n height: 2rem;\n margin-bottom: 0.5rem;\n abbr {\n display: inline-block;\n background-color: var(--global-theme-color);\n padding-left: 1rem;\n padding-right: 1rem;\n a {\n color: white;\n &:hover {\n text-decoration: none;\n }\n }\n }\n .award {\n color: var(--global-theme-color) !important;\n border: 1px solid var(--global-theme-color);\n }\n }\n .title {\n font-weight: bolder;\n }\n .author {\n a {\n border-bottom: 1px dashed var(--global-theme-color);\n &:hover {\n border-bottom-style: solid;\n text-decoration: none;\n }\n }\n > em {\n border-bottom: 1px solid;\n font-style: normal;\n }\n }\n\n p {\n line-height: 1.4em;\n margin: 10px;\n }\n pre {\n font-size: 1em;\n line-height: 1.4em;\n padding: 10px;\n }\n \n\n }\n }\n}\n\n// Transitioning Themes\nhtml.transition,\nhtml.transition *,\nhtml.transition *:before,\nhtml.transition *:after {\n transition: all 750ms !important;\n transition-delay: 0 !important;\n}","/*******************************************************************************\n * Themes\n ******************************************************************************/\n \n:root {\n --global-bg-color: #{$white-color};\n --global-code-bg-color: #{$code-bg-color-light};\n --global-text-color: #{$black-color};\n --global-text-color-light: #{$grey-color};\n --global-theme-color: #{$purple-color};\n --global-hover-color: #{$purple-color};\n --global-footer-bg-color: #{$grey-color-dark};\n --global-footer-text-color: #{$grey-color-light};\n --global-footer-link-color: #{$white-color};\n --global-distill-app-color: #{$grey-color};\n --global-divider-color: rgba(0,0,0,.1);\n --global-card-bg-color: #{$white-color};\n\n .fa-sun {\n display : none;\n }\n .fa-moon {\n padding-left: 10px;\n padding-top: 12px;\n display : block;\n }\n\n .repo-img-light {\n display: block;\n }\n .repo-img-dark {\n display: none;\n }\n}\n\nhtml[data-theme='dark'] {\n --global-bg-color: #{$grey-color-dark};\n --global-code-bg-color: #{$code-bg-color-dark};\n --global-text-color: #{$grey-color-light};\n --global-text-color-light: #{$grey-color-light};\n --global-theme-color: #{$cyan-color};\n --global-hover-color: #{$cyan-color};\n --global-footer-bg-color: #{$grey-color-light};\n --global-footer-text-color: #{$grey-color-dark};\n --global-footer-link-color: #{$black-color};\n --global-distill-app-color: #{$grey-color-light};\n --global-divider-color: #424246;\n --global-card-bg-color: #{$grey-900};\n\n .fa-sun {\n padding-left: 10px;\n padding-top: 12px;\n display : block;\n }\n .fa-moon {\n display : none;\n }\n\n .repo-img-light {\n display: none;\n }\n .repo-img-dark {\n display: block;\n }\n}","@import \n\t\"bootstrap\",\n\t\"variables\",\n\t\"publications\",\n\t\"themes\";\n\nimg { margin-bottom: 24px; \n margin-top: 17px; \n border-radius:2%;\n}\n\n\nbody {\n\tpadding-top: 70px;\n}\n\nfigcaption {\n text-align: right;\n margin-top: -20px;\n margin-bottom: 20px;\n}\n\n\n\n/* Top navigation bar */\n\n\np.byline {\n\ttext-align: center;\n\tfont-size: 18px;\n\tline-height: 36px;\n\tmargin-top: -24px;\n\tmargin-bottom: 48px;\n}\n\n\npubtit {\n\tfont-weight: bold;\n}\n\nfirstp {\n}\n\n.container-fluid {\n margin-right: auto;\n margin-left: auto;\n max-width: 1000px; /* or 950px */\n}\n\n/* Home, News */\n#newsid p {\n\ttext-align: left;\n}\n\n#homeidtmp h1 {\n\ttext-align: center;\n}\n\n#newsid img {\n\tmargin-top: 6px;\n\tmargin-bottom: 6px;\n}\n\n/* Team & Publications */\n#gridid img { margin: 16px 22px 6px 0; border-radius:10%; box-shadow: 2px 2px 5px #888888 }\n#grid2id img { margin: 16px 22px 6px 0; border-radius:3%; box-shadow: 2px 2px 5px #888888 }\n#homeid img { margin: 0 0 0 0; border-radius:5%; box-shadow: 0px 0px 0px #888888 }\n#picid img { margin: 6px 3px 60px 6px; border-radius:1%; box-shadow: 2px 2px 5px #888888 }\n#gridid .row { margin-bottom: 24px; }\n#grid2id .row { margin-bottom: 24px; }\n\n\n\n/* Grid overrides */\n.col-sm-1, .col-sm-2, .col-sm-3, .col-sm-5, .col-sm-6,\n.col-sm-7, .col-sm-8, .col-sm-9, .col-sm-10, .col-sm-11, .col-sm-12 {\n\tpadding-left: 16px;\n\tpadding-right: 16px;\n}\n\n/* Grid overrides */\n.col-sm-4 {\n\tpadding-left: 26px;\n\tpadding-right: 26px;\n}\n\n.vcenter {\n display: inline-block;\n vertical-align: middle;\n float: none;\n}\n\n/* Carusel */\n\n.carousel {\n border-radius: 3px 3px 3px 3px;\n margin-bottom: 20px;\n margin-top: 20px;\n margin-left: 30px;\n margin-right: 30px;\n}\n\n\n.carousel .item {\n height: 400px;\n}\n\n.item img {\n position: absolute;\n top: 0;\n left: 0;\n min-height: 400px;\n}\n\n\n/* Jekyll-embed-video*/\n.embed-container {\n position: relative;\n padding-bottom: 56.25%;\n height: 0;\n overflow: hidden;\n max-width: 90%;\n display: block;\n margin-left: auto;\n margin-right: auto;\n}\n\n.embed-container iframe, .embed-container object, .embed-container embed {\n position: absolute;\n top: 0;\n left: 0;\n width: 90%;\n height: 90%;\n display: block;\n margin-left: auto;\n margin-right: auto;\n}\n"],"file":"main.css"} \ No newline at end of file diff --git a/css/main.scss b/css/main.scss deleted file mode 100644 index d47cdc5a..00000000 --- a/css/main.scss +++ /dev/null @@ -1,140 +0,0 @@ ---- ---- - -@import - "bootstrap", - "variables", - "publications", - "themes"; - -img { margin-bottom: 24px; - margin-top: 17px; - border-radius:2%; -} - - -body { - padding-top: 70px; -} - -figcaption { - text-align: right; - margin-top: -20px; - margin-bottom: 20px; -} - - - -/* Top navigation bar */ - - -p.byline { - text-align: center; - font-size: 18px; - line-height: 36px; - margin-top: -24px; - margin-bottom: 48px; -} - - -pubtit { - font-weight: bold; -} - -firstp { -} - -.container-fluid { - margin-right: auto; - margin-left: auto; - max-width: 1000px; /* or 950px */ -} - -/* Home, News */ -#newsid p { - text-align: left; -} - -#homeidtmp h1 { - text-align: center; -} - -#newsid img { - margin-top: 6px; - margin-bottom: 6px; -} - -/* Team & Publications */ -#gridid img { margin: 16px 22px 6px 0; border-radius:10%; box-shadow: 2px 2px 5px #888888 } -#grid2id img { margin: 16px 22px 6px 0; border-radius:3%; box-shadow: 2px 2px 5px #888888 } -#homeid img { margin: 0 0 0 0; border-radius:5%; box-shadow: 0px 0px 0px #888888 } -#picid img { margin: 6px 3px 60px 6px; border-radius:1%; box-shadow: 2px 2px 5px #888888 } -#gridid .row { margin-bottom: 24px; } -#grid2id .row { margin-bottom: 24px; } - - - -/* Grid overrides */ -.col-sm-1, .col-sm-2, .col-sm-3, .col-sm-5, .col-sm-6, -.col-sm-7, .col-sm-8, .col-sm-9, .col-sm-10, .col-sm-11, .col-sm-12 { - padding-left: 16px; - padding-right: 16px; -} - -/* Grid overrides */ -.col-sm-4 { - padding-left: 26px; - padding-right: 26px; -} - -.vcenter { - display: inline-block; - vertical-align: middle; - float: none; -} - -/* Carusel */ - -.carousel { - border-radius: 3px 3px 3px 3px; - margin-bottom: 20px; - margin-top: 20px; - margin-left: 30px; - margin-right: 30px; -} - - -.carousel .item { - height: 400px; -} - -.item img { - position: absolute; - top: 0; - left: 0; - min-height: 400px; -} - - -/* Jekyll-embed-video*/ -.embed-container { - position: relative; - padding-bottom: 56.25%; - height: 0; - overflow: hidden; - max-width: 90%; - display: block; - margin-left: auto; - margin-right: auto; -} - -.embed-container iframe, .embed-container object, .embed-container embed { - position: absolute; - top: 0; - left: 0; - width: 90%; - height: 90%; - display: block; - margin-left: auto; - margin-right: auto; -} diff --git a/funding/index.html b/funding/index.html new file mode 100644 index 00000000..601a9909 --- /dev/null +++ b/funding/index.html @@ -0,0 +1,374 @@ + + + + + + + + Secure Learning and Control Lab - Funding + + + + + + + + + + + + + + + + + + +
      +
      +
      +

      Our Funding

      +

      We are grateful to the following organizations that generously fund our activities:

      + + +
      + +
      +

      + +
      + +
      +

      + +
      + +
      +

      + +
      + +
      +

      +
      +
      + +
      + +
      +

      +
      + +
      +

      +
      + +
      +

      +
      + +
      + +

      Their funding supports our work in research, education, and outreach, not the least through our scientific projects.

      + +

      Ongoing projects

      + +
      +
      + +

      Prob4Sec - Probabilistic Methods for Secure Learning and Control (2023-2027)

      + +

      Call: VR Project Grant in Information and Cyber Security, funded by the Swedish Research Council (Vetenskapsrådet)

      + +

      Awarded to: André Teixeira (PI) and Per Mattsson

      + +

      USLC Members: 1 PhD student

      + +

      +
      +
      +

      Prob4Sec aims to develop theory and probabilistic methods for securing cyber-physical systems (CPSs) possessing learning and control capabilities: digital devices that learn from data they collect, and automatically decide how to best interact with the physical world over time. Intelligent CPSs are pervasive in our society. Users rely and trust that these devices will operate in a safe and secure manner. The consequences of incorrect behaviors in CPSs can be dire, threatening the users well being. Securing these systems is of utmost importance. Probabilistic methods are a natural way to deal with the uncertainty of physical systems and unintentional failures. Mathematical and statistical tools enable us to take a small number of samples and still be able to draw general conclusions. However, attacks are not only probabilistic but can have strategic behaviors, tailored to causing harm while avoiding detection. Hence, it is critical to develop systematic approaches that integrate the probabilistic and the strategic aspects of attacks in security analysis. Prob4Sec combines knowledge from security, statistical methods, and AI and control engineering to develop new methods for designing secure CPSs with learning and control functionalities. These methods will be instrumental in preventing future threats to all who benefit from this technology. Prob4Sec will provide further tools based on which trust in new technologies can be built and communicated, from developers to end users.

      +
      +
      +
      +
      + +
      +
      + +

      Learning for decision and control in a population of dynamical systems (2024-2027)

      + +

      Call: VR Starting grant within natural and engineering sciences, funded by the Swedish Research Council (Vetenskapsrådet)

      + +

      Awarded to: Per Mattsson (PI)

      + +

      USLC Members: 1 PhD student

      + +

      +
      +
      +

      In real-world applications there are often many individual systems with similar dynamics - a population of systems. For example batteries in different cars, different batches in the process industry or different patients in medicine. By taking a population view we can study how the dynamical systems in the population can learn from each other, both when it comes to estimating models and designing controllers, and how to detect systems with anomalous behavior that may need maintenance or replacement. The aim of this project is to develop methods and analysis to tackle these problems in a coherent way. To realize this we have identified three subprojects. In the first we will develop and analyze estimation methods for populations of systems that can also handle anomalous systems. In the second we will study how these models can be used for population-wide monitoring and anomaly detection. In the third we will develop methods for robust data-driven control, where individual systems learn from each other. We already have established collaborations with experts in industry that can provide us with relevant applications and data for evaluation of the developed methods. By considering populations, instead of single systems as traditionally done in control theory, and taking on these three problems in a coherent way we believe that this project will open up new research directions in, and make significant contributions to, data-driven modeling, fault detection and control.

      +
      +
      +
      +
      + +
      +
      + +

      ADVOLCANO - Adverse Voltage Controllers’ Interactions in Active Distribution Networks (2023-2026)

      + +

      Call: Program ‘The Electrical System of the Future’, funded by the Swedish Energy Agency

      + +

      Awarded to: Stefan Stanković (PI, RISE), Xiaofeng Xong (KTH), Henrik Sandberg (KTH), André Teixeira

      + +

      USLC Members: 1 PhD student

      + +

      +
      +
      +

      To meet the climate and safety challenges of today and the future, new technology is used that changes the dynamics of the electric power system, but which often also leads to unpredictable system behavior. To support voltage regulation in local distribution systems, but also to assist with voltage regulation in the overhead power transmission system, inverter-based generation is often used. However, these can lead to harmful interactions between voltage regulators that can compromise system security. This project analyzes these interactions. The project focus is on modeling and characterizing the interactions between voltage contorllers, as well as developing methods for analyzing them. Based on the analysis, in the project we will propose solutions on how to implement new voltage regulation strategies in active distribution networks while avoiding risks of harmful interactions. The project thus contributes to improved resilience and future secure electricity supply.

      +
      +
      +
      +
      + +
      +
      + +

      Validating a System Development Kit for edge federated learning (2023-2025)

      + +

      Call: ‘Advanced and innovative digitalisation’, funded by the Sweden’s Innovation Agency (Vinnova)

      + +

      Awarded to: Andreas Hellander (PI, Scaleout), Salman Toor (Scaleout), André Teixeira

      + +

      USLC Members: Usama Zafar, 1 Postdoc

      + +

      +
      +
      +

      The project´s primary aim is to increase our understanding of scalability and cyber security in federated machine learning specifically for cloud edge applications. We will also further develop and validate a system development kit for federated machine learning, FEDn, for large-scale applications in fleet intelligence.

      +
      +
      +
      +
      + +
      +
      + +

      Secure Federated Machine Learning at Scale (2022-2026)

      + +

      Call: ‘Joint Strategic Research Activities - Graduate School in Cybersecurity’, funded by the Dept. of Information Technology, Uppsala University

      + +

      Awarded to: Salman Toor (PI), André Teixeira

      + +

      USLC Members: Usama Zafar

      + +

      +
      +
      +

      The overall aims of the project are to mitigate the risk of attacks by providing security and enhanced privacy for a scalable federated training environment. In particular, the project addresses concerns related to security and privacy in federated machine learning against model poisoning and information leakage attacks. The envisioned approach is centered around developing new theories and methodologies to achieve two main aims: secure aggregation of local models under poisoning attacks, and private distributed aggregation of local models.

      +
      +
      +
      +
      + +
      +
      + +

      Data-driven Vulnerability Analysis for Critical Infrastructures (2022-2026)

      + +

      Call: ‘Graduate School in Data-Intensive Science’, funded by the eSSENCE-SciLifeLab

      + +

      Awarded to: Salman Toor (PI), André Teixeira

      + +

      USLC Members: Zhenlu Sun

      + +

      +
      +
      +

      In the last two decades, solutions to address software vulnerabilities have evolved significantly. With predictive schemes, vulnerability analysis has shifted from being reactive to being proactive in terms of early identification of possible risks. A comprehensive vulnerability analysis requires data from application execution patterns, network logs, infrastructure logs, and traces from the source code. Efficient collection, availability and analysis of the log files is a non-trivial task as this data grows rapidly with the execution pattern of the applications. The other sources include infrastructure settings and, most importantly, the information available in public vulnerability databases. All these massive data sources form the basis to call vulnerability analysis a big data challenge. A comprehensive data-driven vulnerability analysis framework will be required to ensure reliable, efficient and uninterrupted mission critical services based on software applications. This project takes a data-intensive approach to analyse and diagnose the presence of cybersecurity vulnerabilities in software applications supporting services within critical computing infrastructures. Our approach consists of combining above-mentioned different data sources with attack modeling frameworks and use explainable machine learning techniques to analyze and diagnose security vulnerabilities in software and network configurations.

      +
      +
      +
      +
      + +
      +
      + +

      ReSiSt - Resilience, Safety, and Security in Tree-structured Civil Networks (2021-2024)

      + +

      Call: VR Project Grant in Societal Security, funded by the Swedish Research Council (Vetenskapsrådet)

      + +

      Awarded to: André Teixeira (PI), Alexander Medvedev, Per Mattsson, Stefan Engblom

      + +

      USLC Members: Mohamed Abdalmoaty, Alain Govaert

      + +

      +
      +
      +

      Civil infrastructure networks (CIN) critically support modern society by distributing resources and protecting communities from hazards. Distributed control and monitoring of CIN to meet network demand under the network efficiency and cost constraints also poses physical security and cyber-security challenges. The resilience of civil infrastructure to disruptive events is the overarching topic of the present project. The project goal is to devise a coherent system theoretical platform for resilience analysis of CIN as well as resilience informed control of those. More specifically, a CIN is modeled as a cyber-physical system (CPS) whose physical layer is a transportation network equipped with actuator and sensor nodes interlaced with a computer network that implements control and monitoring of the physical layer. The scope is limited to the consideration of CPS with a tree-structured physical layer and covers a broad class of pipeline systems, i.e. networked systems transporting single or multi phase fluids. Failures, breakdowns, natural hazards, and cyberattacks are considered potential disruptive events. The project will be conducted along three main threads Mathematical modeling of CIM as CPS Model based assessment of resilience via operational indices Resilience informed control of CIM. The feasibility and efficacy of the developed mathematical models and algorithms will be evaluated with respect to urban water and wastewater networks.

      +
      +
      +
      +
      + +
      +
      + +

      Secure and Resilient Control Systems (2020-2025)

      + +

      Call: SSF Future Research Leaders 7, funded by the Swedish Foundation for Strategic Research (SSF)

      + +

      Awarded to: André Teixeira (PI)

      + +

      USLC Members: Sribalaji Anand, Anh Tung Nguyen, Daniel Arnstöm, Ruslan Seifullaev

      + +

      +
      +
      +

      Reports of cyber-attacks on digitally controlled systems supporting modern societies, such as Stuxnet, have shown their devastating consequences to safety and human lives, and shed light on the attackers modus operandi first learn the system, then tamper the visible information so the attack is undetected, and meanwhile have significant impact on the physical system. It is of the utmost importance to be able to detect and mitigate such malicious cyber-attacks. Unfortunately, existing methods in control engineering consider impact on the physical system and detectability separately, and thus fail to accurately tackle cyber attacks that strategically mix high impact with low detectability. On the other hand, approaches from secure control assume adversaries with perfect knowledge, resulting in overly pessimistic, unrealistic conclusions. The project will produce approaches to analyze and mitigate cyber-attacks on control systems, through the following actions 1) to construct novel sensitivity metrics that jointly consider the impact and detectability of attacks under uncertainty; 2) to design optimal anomaly detectors, controllers, and security measure deployment that minimize the novel sensitivity metrics, and thus increase security; 3) to experimentally validate the developed scientific approaches in testbeds and numerical benchmarks. The developed science and tools will induce a paradigm change in robust control and fault detection, and allow for more effective handling of anomalies.

      +
      +
      +
      +
      + +
      +
      + +

      ADSec - Analysis and Design of Secure and Resilient Control Systems (2019-2023)

      + +

      Call: VR Starting Grant, funded by the Swedish Research Council (Vetenskapsrådet)

      + +

      Awarded to: André Teixeira (PI)

      + +

      USLC Members: Sribalaji Anand, Fatih Emre Tosun

      + +

      +
      +
      +

      Reports on cyber-attacks, such as Stuxnet, have shown their devastating consequences on digitally controlled systems supporting modern societies. It is therefore of the utmost importance for control systems to be able to early detect and mitigate malicious cyber-attacks, which aim at having a significant impact on the system while remaining undetected. Unfortunately, existing techniques in control theory consider impact and detectability separately, and thus fail to accurately tackle malicious cyber-attacks. The aim of this project is to develop novel security metrics that jointly consider the impact and detectability of attacks, and that support the analysis and design of anomaly detectors and controllers for improved security and resilience.

      +
      +
      +
      +
      + +
      +
      + +

      LifeSec - Don’t Hack my Body (2018-2023)

      + +

      Call: SSF Cyber Security Framework Program, funded by the Swedish Foundation for Strategic Research (SSF)

      + +

      Awarded to: Thiemo Voigt (UU, PI), Robin Augustin (UU), Anders Ahlén (UU), Subhrakanti Dey (UU)

      + +

      USLC Members: André Teixeira, Fatih Emre Tosun

      + +

      +
      +
      +

      Implanted devices must be effectively secured to avoid life-threatening scenarios where attackers control implanted devices such as pacemakers or insuline pumps, or install malware inside a human body. This project devises a security architecture for networked implanted medical devices that also enables a secure connection of the in-body network to the Internet. Our architecture ensures confidentiality, integrity and availability of the implanted devices considering also patients’ privacy.

      +
      +
      +
      +
      + +

      … see all Projects

      + +
      + +
      +
      + + + + + + + + + + diff --git a/index.html b/index.html new file mode 100644 index 00000000..2011cec5 --- /dev/null +++ b/index.html @@ -0,0 +1,217 @@ + + + + + + + + Phong Lam - Home + + + + + + + + + + + + + + + + + + +
      +
      +
      +
      + ... +
      +

      Welcome our website!

      + +

      Vision

      +

      Our vision is to develop methodologies for designing intelligent autonomous decision-making systems that are secure and resilient against malicious adversaries and natural failures.

      + + + +

      Research

      +

      Our research incorporates elements from cybersecurity, control theory, optimization and machine learning, reinforcement learning, game-theory and networked / distributed systems. You can find an overview of some of our research themes at our Research page.

      + +

      Scientific environment

      +

      We are a dynamic research group at the Department of Information Technology, Uppsala University, Sweden. We exchange ideas and work with our colleagues from the several of the Department’s research areas, namely Cybersecurity, AI, Data Science, and Control Systems. We also have ongoing collaborations with our neighboring Department of Electrical Engineering. We are driving local research initiatives related to cybersecurity, through the Graduate School in Cybersecurity and the Cybersecurity Arena.

      + +

      We are looking for driven new PhD students, Postdocs, and Master students to join the team (more info) !

      + +

      Our support

      +

      We are grateful for the early-career funding from Uppsala University, the Knut and Alice Wallenberg Foundation (Wallenberg Academy Fellow), the Swedish Research Council (Starting Grant), and the Swedish Foundation for Strategic Research (Future Research Leaders Grant).

      + +
      + +
      +

      + +
      + +
      +

      + +
      + +
      +

      + +
      + +
      +

      + +
      + +
      + +

      See our funding and ongoing projects at our Funding page.

      + + +
      +
      + +
      +

      News

      + + +

      08 March 2024

      One recent paper has been accepted to the IFAC SafeProcess 2024, Ferarra, Italy . The paper addresses the design of a full-state observer to maximize the transient detectability of static sensor errors, possibly caused through bias injection attacks. See the details at Publications.

      +

      + +

      29 February 2024

      Our two recent papers have been accepted to the European Control Conference 2024, Stockholm . They investigate problems in security of safety filters and detection of delay attacks. See their details at Publications.

      +

      + +

      02 February 2024

      We have 1 PhD position in Automatic Control focusing on probabilistic methods for secure control, deadline on March 08, 2024. See the job ad for how to apply!

      +

      + +

      30 Janurary 2024

      Welcome Jingwei Dong as a new PostDoc to our group!

      +

      + +

      08 Janurary 2024

      Our article '’Quickest detection of bias injection attacks on the glucose sensor in the artificial pancreas under meal disturbances’’ was published on Journal of Process Control. The article studies the problem of detecting bias injection attacks on the glucose sensor in the artificial pancreas under sporadic meal uncertainties.

      +

      + + +

      ... see all News

      + +
      + +
      + +
      +
      + + + + + + + + + + diff --git a/openings.html b/openings.html new file mode 100644 index 00000000..2b08ad1f --- /dev/null +++ b/openings.html @@ -0,0 +1,157 @@ + + + + + + + + Secure Learning and Control Lab - Vacancies + + + + + + + + + + + + + + + + + + +
      +
      +
      +

      Open positions

      + +

      At the moment, we have the following positions open:

      + + +

      We are always looking for new group members with passion, talent, and grit!

      + +

      You will have the chance to work on basic and applied research at the intersection of cybersecurity, control theory, and machine learning.

      + +

      You will take an acive role in determining the important and interesting research questions to tackle, creating novel scientific methodologies and tailoring them for specific practical applications, developing new adversary models and defense mechanisms, and evaluating the proposed methods on experimental setups.

      + +

      Note: Sometimes we do not have funding for additional PhD and postdoc positions. In those periods, we can only welcome you if you have a fellowship. We would be happy to support you after you apply to our group. Take a look at the VR International Postdoc grant or the Marie Curie Postdoc fellowship.

      + +

      Past open positions

      + +

      You find some of the past job openings here:

      + + +

      Applications for PhD and Postdoc positions

      +

      Applications for fully-funded PhD or Postdoc positions can only be done for a specific advertisement and through the official application portal. All positions at Uppsala University are advertised at the university website.

      + +

      Other types of PhD and Postdoc positions may also be possible, for instance through the applicant’s own fellowship or scholarship. If you are interested in working with us as a PhD student or postdoc, please send an email. State briefly why you are interested and attach a CV, including information about the grades you had as an undergraduate.

      + +

      Master and Bachelor projects for Uppsala University students

      +

      If you are a Master or Bachelor student at Uppsala University looking for a degree project, contact me (or any group member) per email or drop by my office.

      + +

      At the moment, we have several proposals for MSc thesis projects at our group, candidates are interviewed continuously until early December 2023. See the list and details for how to apply!

      + +

      Master students from elsewhere

      +

      If you are interested in pursuing a Master degree at Uppsala University, see the University’s website. We may take external master students for a degree project or a short stay on their own funding, if we get exceptional applicants (this usually means very good grades and a personal recommendation).

      + +
      +

      +
      + +
      + +
      +
      + + + + + + + + + + diff --git a/publications/index.html b/publications/index.html new file mode 100644 index 00000000..9b5a16bc --- /dev/null +++ b/publications/index.html @@ -0,0 +1,6584 @@ + + + + + + + + Secure Learning and Control Lab - Publications + + + + + + + + + + + + + + + + + + +
      +
      +
      + + +

      Publications

      + +

      (See also the personal webpage of our group members)

      + +

      Group highlights

      + +

      (For a full list of publications, see below, and see also the personal webpage of our group members)

      + +
      + +
      +
      + Security Allocation in Networked Control Systems +

      +

      This thesis develops a framework for evaluating and improving the security of networked control systems in the face of cyber attacks. The considered security problem involves two strategic agents, namely a malicious adversary and a defender, pursuing their specific and conflicting goals. The defender aims to efficiently allocate defense resources with the purpose of detecting malicious activities. Meanwhile, the malicious adversary simultaneously conducts cyber attacks and remains stealthy to the defender. We tackle the security problem by proposing a game-theoretic framework and characterizing its main components the payoff function, the action space, and the available information for each agent. Especially, the payoff function is characterized based on the output-to-output gain security metric that fully explores the worst-case attack impact. Then, we investigate the properties of the game and how to efficiently compute its equilibrium. Given the combinatorial nature of the defender actions, one important challenge is to alleviate the computational burden. To overcome this challenge, the thesis contributes several system- and graph-theoretic conditions that enable the defender to shrink the action space, efficiently allocating the defense resources. The effectiveness of the proposed framework is validated through numerical examples.

      +

      Anh Tung Nguyen

      +

      Licentiate Thesis, Uppsala University, (2023)

      +

      +

      +
      +
      + +
      +
      + Safety, Security and Privacy for Cyber-Physical Systems +

      +

      This book presents an in-depth overview of recent work related to the safety, security, and privacy of cyber-physical systems (CPSs). It brings together contributions from leading researchers in networked control systems and closely related fields to discuss overarching aspects of safety, security, and privacy; characterization of attacks; and solutions to detecting and mitigating such attacks.
      The book begins by providing an insightful taxonomy of problems, challenges and techniques related to safety, security, and privacy for CPSs. It then moves through a thorough discussion of various control-based solutions to these challenges, including cooperative fault-tolerant and resilient control and estimation, detection of attacks and security metrics, watermarking and encrypted control, privacy and a novel defense approach based on deception. The book concludes by discussing risk management and cyber-insurance challenges in CPSs, and by presenting the future outlook for this area of research as a whole.
      Its wide-ranging collection of varied works in the emerging fields of security and privacy in networked control systems makes this book a benefit to both academic researchers and advanced practitioners interested in implementing diverse applications in the fields of IoT, cooperative autonomous vehicles and the smart cities of the future.

      +

      Riccardo M. G. Ferrari and André M. H. Teixeira (Eds)

      +

      Lecture Notes in Control and Information Sciences (LNCIS, volume 486), Springer International Publishing, (2021)

      +

      +

      +
      +
      + +
      + +

       

      + +

      List of Publications

      + +

      Under Review

      +
      + +
      1. + + + +
        + + +
        + “Accelerating Fair Federated Learning: Adaptive Federated Adam”.
        + L. Ju, T. Zhang, S. Toor, and A. Hellander.
        + (Submitted, 2023)
        + +
        + + + + + + ABS + + + + + + + + + + + + BIB + + + + + + +
        +
        + Federated learning is a distributed and privacy-preserving approach to train a statistical model collaboratively from decentralized data of different parties. However, when datasets of participants are not independent and identically distributed (non-IID), models trained by naive federated algorithms may be biased towards certain participants, and model performance across participants is non-uniform. This is known as the fairness problem in federated learning. In this paper, we formulate fairness-controlled federated learning as a dynamical multi-objective optimization problem to ensure fair performance across all participants. To solve the problem efficiently, we study the convergence and bias of Adam as the server optimizer in federated learning, and propose Adaptive Federated Adam (AdaFedAdam) to accelerate fair federated learning with alleviated bias. We validated the effectiveness, Pareto optimality and robustness of AdaFedAdam in numerical experiments and show that AdaFedAdam outperforms existing algorithms, providing better convergence and fairness properties of the federated scheme. +
        +
        + + + +
        +
        +
        @inproceedings{Ju2023,
        +  address = {},
        +  author = {Ju, L. and Zhang, T. and Toor, S. and Hellander, A.},
        +  booktitle = {(Submitted, 2023)},
        +  title = {Accelerating Fair Federated Learning: Adaptive Federated Adam},
        +  published = {0},
        +  tag = {10003}
        +}
        +
        +
        + + + + + + + +
        + +
      2. +
      3. + + + +
        + + +
        + “Security Allocation in Networked Control Systems under Stealthy Attacks”.
        + A. T. Nguyen, A. M. H. Teixeira, and A. Medvedev.
        + IEEE Trans. Control of Network Systems (Submitted)
        + +
        + + + + + + ABS + + + + + + + + + + + + BIB + + + + + + +
        +
        + This paper considers the problem of security allocation in a networked control system under stealthy attacks in which the system is comprised of interconnected subsystems represented by vertices. A malicious adversary selects a single vertex on which to conduct a stealthy data injection attack to maximally disrupt the local performance while remaining undetected. On the other hand, a defender selects several vertices on which to allocate defense resources against the adversary. First, the objectives of the adversary and the defender with uncertain targets are formulated in probabilistic ways, resulting in an expected worst-case impact of stealthy attacks. Next, we provide a graph-theoretic necessary and sufficient condition under which the cost for the defender and the expected worst-case impact of stealthy attacks are bounded. This condition enables the defender to restrict the admissible actions to a subset of available vertex sets. Then, we cast the problem of security allocation in a Stackelberg game-theoretic framework. Finally, the contribution of this paper is highlighted by utilizing the proposed admissible actions of the defender in the context of large-scale networks. A numerical example of a 50-vertex networked control system is presented to validate the obtained results. +
        +
        + + + +
        +
        +
        @article{Tung_TCNS2024,
        +  author = {Nguyen, A. T. and Teixeira, A. M. H. and Medvedev, A.},
        +  journal = {IEEE Trans. Control of Network Systems (Submitted)},
        +  number = {},
        +  pages = {},
        +  title = {Security Allocation in Networked Control Systems under Stealthy Attacks},
        +  volume = {},
        +  year = {},
        +  published = {0},
        +  tag = {10005}
        +}
        +
        +
        + + + + + + + +
        + +
      4. +
      5. + + + +
        + + +
        + “Data-Driven Identification of Attack-free Sensors in Networked Control Systems”.
        + S. C. Anand, M. S. Chong, and A. M. H. Teixeira.
        + Submitted to L4DC 2024
        + +
        + + + + + + + + + + + + + + + + BIB + + + + + + + + +
        +
        +
        @inproceedings{Anand_L4DC2024,
        +  author = {Anand, S. C. and Chong, M. S. and Teixeira, A. M. H.},
        +  booktitle = {Submitted to L4DC 2024},
        +  title = {Data-Driven Identification of Attack-free Sensors in Networked Control Systems},
        +  year = {},
        +  published = {0},
        +  tag = {}
        +}
        +
        +
        + + + + + + + +
        + +
      + +
      + +

      Published

      +
      +

      2024

      +
      1. + + + +
        + + +
        + “Stealthy Deactivation of Safety Filters”.
        + D. Arnström and A. M. H. Teixeira.
        + European Control Conference (Accepted), 2024
        + +
        + + + + + + ABS + + + + + + + + + + + + BIB + + + + + + +
        +
        + Safety filters ensure that only safe control actions are executed. We propose a simple and stealthy false-data injection attack for deactivating such safety filters; in particular, we focus on deactivating safety filters that are based on controlbarrier functions. The attack injects false sensor measurements to bias state estimates to the interior of a safety region, which makes the safety filter accept unsafe control actions. To detect such attacks, we also propose a detector that detects biases manufactured by the proposed attack policy, which complements conventional detectors when safety filters are used. The proposed attack policy and detector are illustrated on a double integrator example. +
        +
        + + + +
        +
        +
        @inproceedings{Arnstrom_ECC2024,
        +  author = {Arnstr\"{o}m, D. and Teixeira, A. M. H.},
        +  booktitle = {European Control Conference (Accepted)},
        +  title = {Stealthy Deactivation of Safety Filters},
        +  year = {2024},
        +  published = {1}
        +}
        +
        +
        + + + + + + + +
        + +
      2. +
      3. + + + +
        + + +
        + “Delay Attack and Detection in Feedback Linearized Control Systems”.
        + T. Wigren and A. M. H. Teixeira.
        + European Control Conference (Accepted), 2024
        + +
        + + + + + + ABS + + + + + + + + + + + + BIB + + + + + + +
        +
        + Delay injection attacks on nonlinear control systems have many consequences. Nonlinear instability mechanisms, for example finite escape time dynamics, can be triggered which is why rapid attack detection needs research. The paper therefore considers delay attacks on feedback linearized systems and shows how a recursive identification algorithm for nonlinear systems with delay may be used for detection of delay injection in the feedback path. The attack methodology is illustrated using a simulated feedback linearized automotive cruise controller where the attack is disguised, but anyway rapidly detected. +
        +
        + + + +
        +
        +
        @inproceedings{Wigren_ECC2024,
        +  author = {Wigren, T. and Teixeira, A. M. H.},
        +  booktitle = {European Control Conference (Accepted)},
        +  title = {Delay Attack and Detection in Feedback Linearized Control Systems},
        +  year = {2024},
        +  published = {1},
        +  tag = {10004}
        +}
        +
        +
        + + + + + + + +
        + +
      4. +
      5. + + + +
        + + +
        + “Kullback-Leibler Divergence-Based Detector Design Against Bias Injection Attacks in an Artificial Pancreas System”.
        + F. E. Tosun, A. M. H. Teixeira, A. Ahlén, and S. Dey.
        + 12th IFAC Symposium on Fault Detection, Supervision and Safety for Technical Processes (Accepted), 2024
        + +
        + + + + + + ABS + + + + + + + + + + + + BIB + + + + + + +
        +
        + This paper considers constant bias injection attacks on the glucose sensor deployed in an artificial pancreas system that has an integrator. The main challenge with such apparently simple attacks is that, if the system is linear and has an integrator, they are only detectable for a limited duration. More formally, they are steady-state stealthy attacks. To address this issue, we propose a residual generation method to increase the detectability of these attacks based on the Kullback–Leibler divergence metric. Illustrative examples with numerical simulations are provided to demonstrate the effectiveness of the proposed method. +
        +
        + + + +
        +
        +
        @inproceedings{Tosun_SP024,
        +  author = {Tosun, F. E. and Teixeira, A. M. H. and Ahlén, A. and Dey, S.},
        +  booktitle = {12th IFAC Symposium on Fault Detection, Supervision and Safety for Technical Processes (Accepted)},
        +  title = {Kullback-Leibler Divergence-Based Detector Design Against Bias Injection Attacks in an Artificial Pancreas System},
        +  year = {2024},
        +  published = {1},
        +  tag = {10002}
        +}
        +
        +
        + + + + + + + +
        + +
      6. +
      7. + + + +
        + + +
        + “Quickest Detection of Bias Injection Attacks on the Glucose Sensor in the Artificial Pancreas Under Meal Disturbances”.
        + F. E. Tosun, A. M. H. Teixeira, M. Abdalmoaty, A. Ahlén, and S. Dey.
        + Journal of Process Control, vol. 153, no. 103162, 2024
        + +
        + + + + + + ABS + + + + + + + + + + + + BIB + + + + + + +
        +
        + Modern glucose sensors deployed in closed-loop insulin delivery systems, so-called artificial pancreas use wireless communication channels. While this allows a flexible system design, it also introduces vulnerability to cyberattacks. Timely detection and mitigation of attacks are imperative for device safety. However, large unknown meal disturbances are a crucial challenge in determining whether the sensor has been compromised or the sensor glucose trajectories are normal. We address this issue from a control-theoretic security perspective. In particular, a time-varying Kalman filter is employed to handle the sporadic meal intakes. The filter prediction error is then statistically evaluated to detect anomalies if present. We compare two state-of-the-art online anomaly detection algorithms, namely the χ^2 and CUSUM tests. We establish a robust optimal detection rule for unknown bias injections. Even if the optimality holds only for the restrictive case of constant bias injections, we show that the proposed model-based anomaly detection scheme is also effective for generic non-stealthy sensor deception attacks through numerical simulations +
        +
        + + + +
        +
        +
        @article{Tosun_JPC2024,
        +  author = {Tosun, F. E. and Teixeira, A. M. H. and Abdalmoaty, M. and Ahl\'{e}n, A. and Dey, S.},
        +  journal = {Journal of Process Control},
        +  volume = {153},
        +  number = {103162},
        +  title = {Quickest Detection of Bias Injection Attacks on the Glucose Sensor in the Artificial Pancreas Under Meal Disturbances},
        +  year = {2024},
        +  doi = {10.1016/j.jprocont.2024.103162},
        +  published = {1},
        +  tag = {10002}
        +}
        +
        +
        + + + + + + + +
        + +
      + +

      2023

      +
      1. + + + +
        + + +
        + “Security Allocation in Networked Control Systems”.
        + A. T. Nguyen.
        + Licentiate thesis, Uppsala University, Uppsala, Sweden, 2023
        + +
        + + + + + + ABS + + + + + + + + + + + + BIB + + + + + + +
        +
        + Sustained use of critical infrastructure, such as electrical power and water distribution networks, requires efficient management and control. Facilitated by the advancements in computational devices and non-proprietary communication technology, such as the Internet, the efficient operation of critical infrastructure relies on network decomposition into interconnected subsystems, thus forming networked control systems. However, the use of public and pervasive communication channels leaves these systems vulnerable to cyber attacks. Consequently, the critical infrastructure is put at risk of suffering operation disruption and even physical damage that would inflict financial costs as well as pose a hazard to human health. Therefore, security is crucial to the sustained efficient operation of critical infrastructure. + + This thesis develops a framework for evaluating and improving the security of networked control systems in the face of cyber attacks. The considered security problem involves two strategic agents, namely a malicious adversary and a defender, pursuing their specific and conflicting goals. The defender aims to efficiently allocate defense resources with the purpose of detecting malicious activities. Meanwhile, the malicious adversary simultaneously conducts cyber attacks and remains stealthy to the defender. We tackle the security problem by proposing a game-theoretic framework and characterizing its main components: the payoff function, the action space, and the available information for each agent. Especially, the payoff function is characterized based on the output-to-output gain security metric that fully explores the worst-case attack impact. Then, we investigate the properties of the game and how to efficiently compute its equilibrium. Given the combinatorial nature of the defender’s actions, one important challenge is to alleviate the computational burden. To overcome this challenge, the thesis contributes several system- and graph-theoretic conditions that enable the defender to shrink the action space, efficiently allocating the defense resources. The effectiveness of the proposed framework is validated through numerical examples. +
        +
        + + + +
        +
        +
        @phdthesis{Nguyen_Lic2023,
        +  author = {Nguyen, Anh Tung},
        +  title = {Security Allocation in Networked Control Systems},
        +  school = {Uppsala University},
        +  year = {2023},
        +  address = {Uppsala, Sweden},
        +  month = oct,
        +  type = {Licentiate thesis},
        +  tag = {10005}
        +}
        +
        +
        + + + + + + + +
        + +
      2. +
      3. + + + +
        + + +
        + “Privacy preserving average consensus through network augmentation”.
        + G. Ramos, A. P. Aguiar, S. Kar, and S. Pequito.
        + IEEE Trans. Automatic Control (Accepted), 2023
        + +
        + + + + + + + + + + + + + + + + BIB + + + + + + + + +
        +
        +
        @article{Ramos_TAC2024,
        +  author = {Ramos, G. and Aguiar, A. P. and Kar, Soummya and Pequito, S.},
        +  journal = {IEEE Trans. Automatic Control (Accepted)},
        +  title = {Privacy preserving average consensus through network augmentation},
        +  year = {2023},
        +  published = {1},
        +  tag = {10006}
        +}
        +
        +
        + + + + + + + +
        + +
      4. +
      5. + + + +
        + + +
        + “Designing communication networks for discrete-time consensus for performance and privacy guarantees”.
        + G. Ramos and S. Pequito.
        + Systems & Control Letters, vol. 180, p. 105608, 2023
        + +
        + + + + + + ABS + + + + + + + + + + + + BIB + + + + + + +
        +
        + Discrete-time consensus plays a key role in multi-agent systems and distributed protocols. Unfortunately, due to the self-loop dynamics of the agents (an agent’s current state depends only on its own immediately previous state, i.e., one time-step in the past), they often lack privacy guarantees. Therefore, in this paper, we propose a novel design that consists of a network augmentation, where each agent uses the previous iteration values and the newly received ones to increase the privacy guarantees. To formally evaluate the privacy of a network of agents, we define the concept of privacy index, which intuitively measures the minimum number of agents that should work in coalition to recover all the initial states. Moreover, we aim to explore if there is a trade-off between privacy and accuracy (rate of convergence) or if we can increase both. We unveil that, with the proposed method, we can design networks with higher privacy index and faster convergence rates. Remarkably, we further ensure that the network always reaches consensus even when the original network does not. Finally, we illustrate the proposed method with examples and present networks that lead to higher privacy levels and, in the majority of the cases, to faster consensus rates. +
        +
        + + + +
        +
        +
        @article{Ramos_CSL2024,
        +  author = {Ramos, G. and Pequito, S.},
        +  journal = {Systems & Control Letters},
        +  volume = {180},
        +  pages = {105608},
        +  year = {2023},
        +  title = {Designing communication networks for discrete-time consensus for performance and privacy guarantees},
        +  doi = {10.1016/j.sysconle.2023.105608},
        +  published = {1},
        +  tag = {10006}
        +}
        +
        +
        + + + + + + + +
        + +
      6. +
      7. + + + +
        + + +
        + “Risk Assessment of Stealthy Attacks on Uncertain Control Systems”.
        + S. C. Anand, A. M. H. Teixeira, and A. Ahlén.
        + IEEE Trans. Automatic Control (Accepted), 2023
        + +
        + + + + + + ABS + + + + + + + + + + + + BIB + + + + + + +
        +
        + In this article, we address the problem of risk assessment of stealthy attacks on uncertain control systems. Considering data injection attacks that aim at maximizing impact while remaining undetected, we use the recently proposed output-to-output gain to characterize the risk associated with the impact of attacks under a limited system knowledge attacker. The risk is formulated using a well-established risk metric, namely the maximum expected loss. Under this setups, the risk assessment problem corresponds to an untractable infinite non-convex optimization problem. To address this limitation, we adopt the framework of scenario-based optimization to approximate the infinite non-convex optimization problem by a sampled non-convex optimization problem. Then, based on the framework of dissipative system theory and S-procedure, the sampled non-convex risk assessment problem is formulated as an equivalent convex semi-definite program. Additionally, we derive the necessary and sufficient conditions for the risk to be bounded. Finally, we illustrate the results through numerical simulation of a hydro-turbine power system. +
        +
        + + + +
        +
        +
        @article{Anand_TAC2024,
        +  author = {Anand, S. C. and Teixeira, A. M. H. and Ahl\'{e}n, A.},
        +  journal = {IEEE Trans. Automatic Control (Accepted)},
        +  number = {},
        +  pages = {},
        +  title = {Risk Assessment of Stealthy Attacks on Uncertain Control Systems},
        +  volume = {},
        +  year = {2023},
        +  doi = {10.1109/TAC.2023.3318194},
        +  published = {1},
        +  tag = {10001}
        +}
        +
        +
        + + + + + + + +
        + +
      8. +
      9. + + + +
        + + +
        + “Risk-based Security Measure Allocation Against Actuator Attacks”.
        + S. C. Anand and A. M. H. Teixeira.
        + IEEE Open Journal of Control Systems, vol. 2, pp. 297–309, 2023
        + +
        + + + + + + ABS + + + + + + + + + + + + BIB + + + + + + +
        +
        + This article considers the problem of risk-optimal allocation of security measures when the actuators of an uncertain control system are under attack. We consider an adversary injecting false data into the actuator channels. The attack impact is characterized by the maximum performance loss caused by a stealthy adversary with bounded energy. Since the impact is a random variable, due to system uncertainty, we use Conditional Value-at-Risk (CVaR) to characterize the risk associated with the attack. We then consider the problem of allocating the security measures which minimize the risk. We assume that there are only a limited number of security measures available. Under this constraint, we observe that the allocation problem is a mixed-integer optimization problem. Thus we use relaxation techniques to approximate the security allocation problem into a Semi-Definite Program (SDP). We also compare our allocation method (i) across different risk measures: the worst-case measure, the average (nominal) measure, and (ii) across different search algorithms: the exhaustive and the greedy search algorithms. We depict the efficacy of our approach through numerical examples. +
        +
        + + + +
        +
        +
        @article{Anand_IEEEOJCSys2023,
        +  author = {Anand, S. C. and Teixeira, A. M. H.},
        +  journal = {IEEE Open Journal of Control Systems},
        +  number = {},
        +  pages = {297--309},
        +  title = {Risk-based Security Measure Allocation Against Actuator Attacks},
        +  volume = {2},
        +  year = {2023},
        +  doi = {10.1109/OJCSYS.2023.3305831},
        +  published = {1},
        +  tag = {10001}
        +}
        +
        +
        + + + + + + + +
        + +
      10. +
      11. + + + +
        + + +
        + “On the trade-offs between accuracy, privacy, and resilience in average consensus algorithms”.
        + G. Ramos, A. M. H. Teixeira, and S. Pequito.
        + Accepted to IEEE Conference on Decisions and Control (CDC), 2023
        + +
        + + + + + + + + + + + + + + + + BIB + + + + + + + + +
        +
        +
        @inproceedings{Ramos_CDC2023,
        +  author = {Ramos, G. and Teixeira, A. M. H. and Pequito, S.},
        +  booktitle = {Accepted to IEEE Conference on Decisions and Control (CDC)},
        +  title = {On the trade-offs between accuracy, privacy, and resilience in average consensus algorithms},
        +  year = {2023},
        +  published = {1},
        +  tag = {10005},
        +  taga = {10006}
        +}
        +
        +
        + + + + + + + +
        + +
      12. +
      13. + + + +
        + + +
        + “Robust Sequential Detection of Non-stealthy Sensor Deception Attacks in an Artificial Pancreas System”.
        + F. E. Tosun and A. M. H. Teixeira.
        + Accepted to IEEE Conference on Decisions and Control (CDC), 2023
        + +
        + + + + + + + + + + + + + + + + BIB + + + + + + + + +
        +
        +
        @inproceedings{Tosun_CDC2023,
        +  address = {},
        +  author = {Tosun, F. E. and Teixeira, A. M. H.},
        +  booktitle = {Accepted to IEEE Conference on Decisions and Control (CDC)},
        +  title = {Robust Sequential Detection of Non-stealthy Sensor Deception Attacks in an Artificial Pancreas System},
        +  year = {2023},
        +  published = {1},
        +  tag = {10002}
        +}
        +
        +
        + + + + + + + +
        + +
      14. +
      15. + + + +
        + + +
        + “Secure State Estimation with Asynchronous Measurements against Malicious Measurement-data and Time-stamp Manipulation”.
        + Z. Li, A. T. Nguyen, A. M. H. Teixeira, Y. Mo, and K. H. Johansson.
        + Accepted to IEEE Conference on Decisions and Control (CDC), 2023
        + +
        + + + + + + ABS + + + + + + + + + + + + BIB + + + + + + +
        +
        + This paper proposes a secure state estimation scheme with non-periodic asynchronous measurements for linear continuous-time systems under false data attacks on the measurement transmit channel. After sampling the output of the system, a sensor transmits the measurement information in a triple composed of sensor index, time-stamp, and measurement value to the fusion center via vulnerable communication channels. The malicious attacker can corrupt a subset of the sensors through (i) manipulating the time-stamp and measurement value; (ii) blocking transmitted measurement triples; or (iii) injecting fake measurement triples. To deal with such attacks, we propose the design of local estimators based on observability space decomposition, where each local estimator updates the local state and sends it to the fusion center after sampling a measurement. Whenever there is a local update, the fusion center combines all the local states and generates a secure state estimate by adopting the median operator. We prove that local estimators of benign sensors are unbiased with stable covariance. Moreover, the fused central estimation error has bounded expectation and covariance against at most p corrupted sensors as long as the system is 2p-sparse observable. The efficacy of the proposed scheme is demonstrated through an application on a benchmark example of the IEEE 14-bus system. +
        +
        + + + +
        +
        +
        @inproceedings{Li_CDC2023,
        +  address = {},
        +  author = {Li, Z. and Nguyen, A. T. and Teixeira, A. M. H. and Mo, Y. and Johansson, K. H.},
        +  booktitle = {Accepted to IEEE Conference on Decisions and Control (CDC)},
        +  title = {Secure State Estimation with Asynchronous Measurements against Malicious  Measurement-data and Time-stamp Manipulation},
        +  year = {2023},
        +  published = {1},
        +  tag = {10005}
        +}
        +
        +
        + + + + + + + +
        + +
      16. +
      17. + + + +
        + + +
        + “Feedback Path Delay Attacks and Detection”.
        + T. Wigren and A. M. H. Teixeira.
        + Accepted to IEEE Conference on Decisions and Control (CDC), 2023
        + +
        + + + + + + + + + + + + + + + + BIB + + + + + + + + +
        +
        +
        @inproceedings{Wigren_CDC2023,
        +  address = {},
        +  author = {Wigren, T. and Teixeira, A. M. H.},
        +  booktitle = {Accepted to IEEE Conference on Decisions and Control (CDC)},
        +  title = {Feedback Path Delay Attacks and Detection},
        +  year = {2023},
        +  published = {1},
        +  tag = {10004}
        +}
        +
        +
        + + + + + + + +
        + +
      18. +
      19. + + + +
        + + +
        + “Quickest Detection of Deception Attacks on Cyber-Physical Systems with a Parsimonious Watermarking Policy”.
        + A. Naha, A. M. H. Teixeira, A. Ahlén, and S. Dey.
        + Automatica, vol. 155, p. 111147, 2023
        + +
        + + + + + + ABS + + + + + + + + + + + + BIB + + + + + + +
        +
        + The addition of a physical watermarking signal to the control input increases the detection probability of data deception attacks at the expense of increased control cost. In this paper, we propose a parsimonious policy to reduce the average number of watermarking events when the attack is not present, which in turn reduces the control cost. We model the system as a stochastic optimal control problem and apply the dynamic programming to minimize the average detection delay (ADD) for fixed upper bounds on false alarm rate (FAR) and increased control cost. The optimal solution results in a two threshold policy on the posterior probability of attack, which is derived from the Shiryaev statistics for sequential change detection assuming the change point is a random variable with a geometric distribution. We derive approximate expressions of ADD and FAR applying the non-linear renewal theory. The relationship between the average number of watermarking added before the attack and the increase in control cost is also derived. We design the optimal watermarking that maximizes the Kullback-Leibler divergence for a fixed increase in the control cost. Simulation studies are performed to illustrate and validate the theoretical results. +
        +
        + + + +
        +
        +
        @article{Naha_AUTOMATICA2023,
        +  author = {Naha, A. and Teixeira, A. M. H. and Ahl\'{e}n, A. and Dey, S.},
        +  journal = {Automatica},
        +  number = {},
        +  pages = {111147},
        +  title = {Quickest Detection of Deception Attacks on Cyber-Physical Systems with a Parsimonious Watermarking Policy},
        +  volume = {155},
        +  year = {2023},
        +  doi = {10.1016/j.automatica.2023.111147},
        +}
        +
        +
        + + + + + + + +
        + +
      20. +
      21. + + + +
        + + +
        + “Probability Elicitation for Bayesian Networks to Distinguish between Intentional Attacks and Accidental Technical Failures”.
        + S. Chockalingam, W. Pieters, A. M. H. Teixeira, and P. van Gelder.
        + Journal of Information Security and Applications, vol. 75, p. 103497, 2023
        + +
        + + + + + + ABS + + + + + + + + + + + + BIB + + + + + + +
        +
        + Both intentional attacks and accidental technical failures can lead to abnormal behaviour in components of industrial control systems. In our previous work, we developed a framework for constructing Bayesian Network (BN) models to enable operators to distinguish between those two classes, including knowledge elicitation to construct the directed acyclic graph of BN models. In this paper, we add a systematic method for knowledge elicitation to construct the Conditional Probability Tables (CPTs) of BN models, thereby completing a holistic framework to distinguish between attacks and technical failures. In order to elicit reliable probabilities from experts, we need to reduce the workload of experts in probability elicitation by reducing the number of conditional probabilities to elicit and facilitating individual probability entry. We utilise DeMorgan models to reduce the number of conditional probabilities to elicit as they are suitable for modelling opposing influences i.e., combinations of influences that promote and inhibit the child event. To facilitate individual probability entry, we use probability scales with numerical and verbal anchors. We demonstrate the proposed approach using an example from the water management domain. +
        +
        + + + +
        +
        +
        @article{Chockalingam_JISA2023,
        +  author = {Chockalingam, S. and Pieters, W. and Teixeira, A. M. H. and van Gelder, P.},
        +  journal = {Journal of Information Security and Applications},
        +  number = {},
        +  title = {Probability Elicitation for Bayesian Networks to Distinguish between Intentional Attacks and Accidental Technical Failures},
        +  year = {2023},
        +  doi = {10.1016/j.jisa.2023.103497},
        +  volume = {75},
        +  pages = {103497},
        +  issn = {2214-2126}
        +}
        +
        +
        + + + + + + + +
        + +
      22. +
      23. + + + +
        + + +
        + “Quickest Physical Watermarking-Based Detection of Measurement Replacement Attacks in Networked Control Systems”.
        + A. Naha, A. M. H. Teixeira, A. Ahlén, and S. Dey.
        + European Journal of Control, vol. 71, p. 100804, 2023
        + +
        + + + + + + ABS + + + + + + + + + + + + BIB + + + + + + +
        +
        + In this paper, we propose and analyze an attack detection scheme for securing the physical layer of a networked control system (NCS) with a wireless sensor network against attacks where the adversary replaces the true observations with stationary false data. An independent and identically distributed watermarking signal is added to the optimal linear quadratic Gaussian (LQG) control inputs, and a cumulative sum (CUSUM) test is carried out using the joint distribution of the innovation signal and the watermarking signal for quickest attack detection. We derive the expressions of the supremum of the average detection delay (SADD) for a multi-input and multi-output (MIMO) system under the optimal and sub-optimal CUSUM tests. The SADD is asymptotically inversely proportional to the expected KullbackLeibler divergence (KLD) under certain conditions. The expressions for the MIMO case are simplified for multi-input and single-output systems and explored further to distil design insights. We provide insights into the design of an optimal watermarking signal to maximize KLD for a given fixed increase in LQG control cost when there is no attack. Furthermore, we investigate how the attacker and the control system designer can accomplish their respective objectives by changing the relative power of the attack signal and the watermarking signal. Simulations and numerical studies are carried out to validate the theoretical results. +
        +
        + + + +
        +
        +
        @article{Naha_EJC2023,
        +  author = {Naha, A. and Teixeira, A. M. H. and Ahl\'{e}n, A. and Dey, S.},
        +  journal = {European Journal of Control},
        +  number = {},
        +  pages = {100804},
        +  title = {Quickest Physical Watermarking-Based Detection of Measurement Replacement Attacks in Networked Control Systems},
        +  volume = {71},
        +  year = {2023},
        +  doi = {10.1016/j.ejcon.2023.100804}
        +}
        +
        +
        + + + + + + + +
        + +
      24. +
      25. + + + +
        + + +
        + “Privacy and Security in Network Controlled Systems via Dynamic Masking”.
        + M. Abdalmoaty, S. C. Anand, and A. M. H. Teixeira.
        + IFAC World Congress, 2023
        + +
        + + + + + + ABS + + + + + + + + + VID + + + + + BIB + + + + + + +
        +
        + In this paper, we propose a new architecture to enhance the privacy and security of networked control systems against malicious adversaries. We consider an adversary which first learns the system dynamics (privacy) using system identification techniques, and then performs a data injection attack (security). In particular, we consider an adversary conducting zero-dynamics attacks (ZDA) which maximizes the performance cost of the system whilst staying undetected. However, using the proposed architecture, we show that it is possible to (i) introduce significant bias in the system estimates of the adversary: thus providing privacy of the system parameters, and (ii) efficiently detect attacks when the adversary performs a ZDA using the identified system: thus providing security. Through numerical simulations, we illustrate the efficacy of the proposed architecture. +
        +
        + + + +
        +
        +
        @inproceedings{AbdalmoatyIFAC2023,
        +  address = {},
        +  author = {Abdalmoaty, M. and Anand, S. C. and Teixeira, A. M. H.},
        +  booktitle = {IFAC World Congress},
        +  title = {Privacy and Security in Network Controlled Systems via Dynamic Masking},
        +  year = {2023},
        +  video = {https://youtu.be/uuz5ppriWLk},
        +  tag = {10006}
        +}
        +
        +
        + + + + + + + +
        + +
      26. +
      27. + + + +
        + + +
        + “Optimal Detector Placement in Networked Control Systems under Cyber-attacks with Applications to Power Networks”.
        + A. T. Nguyen, S. C. Anand, A. M. H. Teixeira, and A. Medvedev.
        + IFAC World Congress, 2023
        + +
        + + + + + + ABS + + + + + + + + + + + + BIB + + + + + + +
        +
        + This paper proposes a game-theoretic method to address the problem of optimal detector placement in a networked control system under cyber-attacks. The networked control system is composed of interconnected agents where each agent is regulated by its local controller over unprotected communication, which leaves the system vulnerable to malicious cyber-attacks. To guarantee a given local performance, the defender optimally selects a single agent on which to place a detector at its local controller with the purpose of detecting cyber-attacks. On the other hand, an adversary optimally chooses a single agent on which to conduct a cyber-attack on its input with the aim of maximally worsening the local performance while remaining stealthy to the defender. First, we present a necessary and sufficient condition to ensure that the maximal attack impact on the local performance is bounded, which restricts the possible actions of the defender to a subset of available agents. Then, by considering the maximal attack impact on the local performance as a game payoff, we cast the problem of finding optimal actions of the defender and the adversary as a zero-sum game. Finally, with the possible action sets of the defender and the adversary, an algorithm is devoted to determining the Nash equilibria of the zero-sum game that yield the optimal detector placement. The proposed method is illustrated on an IEEE benchmark for power systems. +
        +
        + + + +
        +
        +
        @inproceedings{NguyenIFAC2023,
        +  address = {},
        +  author = {Nguyen, A. T. and Anand, S. C. and Teixeira, A. M. H. and Medvedev, A.},
        +  booktitle = {IFAC World Congress},
        +  title = {Optimal Detector Placement in Networked Control Systems under Cyber-attacks with Applications to Power Networks},
        +  tag = {10005},
        +  year = {2023},
        +}
        +
        +
        + + + + + + + +
        + +
      28. +
      29. + + + +
        + + +
        + “On-line Identification of Delay Attacks in Networked Servo Control”.
        + T. Wigren and A. M. H. Teixeira.
        + IFAC World Congress, 2023
        + +
        + + + + + + ABS + + + + + + + + + + + + BIB + + + + + + +
        +
        + The paper discusses attacks on networked control loops by increased delay, and shows how existing round trip jitter may disguise such attacks. The attackers objective need not be de-stabilization, the paper argues that making settling time requirements fail can be sufficient. To defend against such attacks, the paper proposes the use of joint recursive prediction error identification of the round trip delay and the networked closed loop dynamics. The proposed identification algorithm allows general defense, since it is designed for delayed nonlinear dynamics in state space form. Simulations show that the method is able to detect a delay attack on a printed circuit board component mounting servo loop, long before the attack reaches full effect. +
        +
        + + + +
        +
        +
        @inproceedings{WigrenIFAC2023,
        +  address = {},
        +  author = {Wigren, T. and Teixeira, A. M. H.},
        +  booktitle = {IFAC World Congress},
        +  title = {On-line Identification of Delay Attacks in Networked Servo Control},
        +  year = {2023},
        +  tag = {10004}
        +}
        +
        +
        + + + + + + + +
        + +
      30. +
      31. + + + +
        + + +
        + “An Online Kullback-Leibler Divergence-Based Stealthy Attack against Cyber-Physical Systems”.
        + Q. Zhang, K. Liu, A. M. H. Teixeira, Y. Li, S. Chai, and Y. Xia.
        + IEEE Trans. Automatic Control, vol. 68, no. 6, pp. 3672–3679, 2023
        + +
        + + + + + + ABS + + + + + + + + + + + + BIB + + + + + + +
        +
        + This article investigates the design of online stealthy attacks with the aim of moving the system’s state to a desired target. Different from the design of offline attacks, which is only based on the system’s model, to design the online attack, the attacker also estimates the system’s state with the intercepted data at each instant and computes the optimal attack accordingly. To ensure stealthiness, the Kullback-Leibler divergence between the innovations with and without attacks at each instant should be smaller than a threshold. We show that the attacker should solve a convex optimization problem at each instant to compute the mean and covariance of the attack. The feasibility of the attack policy is also discussed. Furthermore, for the strictly stealthy case with zero threshold, the analytic expression of the unique optimal attack is given. Finally, a numerical example of the longitudinal flight control system is adopted to illustrate the effectiveness of the proposed attack. +
        +
        + + + +
        +
        +
        @article{Zhang_TAC2023,
        +  author = {Zhang, Q. and Liu, K. and Teixeira, A. M. H. and Li, Y. and Chai, S. and Xia, Y.},
        +  journal = {IEEE Trans. Automatic Control},
        +  number = {6},
        +  pages = {3672--3679},
        +  title = {An Online Kullback-Leibler Divergence-Based Stealthy Attack against Cyber-Physical Systems},
        +  volume = {68},
        +  year = {2023},
        +  doi = {10.1109/TAC.2022.3192201}
        +}
        +
        +
        + + + + + + + +
        + +
      32. +
      33. + + + +
        + + +
        + “Sequential detection of Replay attacks”.
        + A. Naha, A. M. H. Teixeira, A. Ahlén, and S. Dey.
        + IEEE Trans. Automatic Control, vol. 68, no. 3, pp. 1941–1948, 2023
        + +
        + + + + + + ABS + + + + + + + + + + + + BIB + + + + + + +
        +
        + One of the most studied forms of attacks on the cyber-physical systems is the replay attack. The statistical similarities of the replayed signal and the true observations make the replay attack difficult to detect. In this paper, we address the problem of replay attack detection by adding watermarking to the control inputs and then perform resilient detection using cumulative sum (CUSUM) test on the joint statistics of the innovation signal and the watermarking signal, whereas existing work considers only the marginal distribution of the innovation signal. We derive the expression of the Kullback-Liebler divergence (KLD) between the two joint distributions before and after the replay attack, which is, asymptotically, inversely proportional to the detection delay. We perform a structural analysis of the derived KLD expression and suggest a technique to improve the KLD for the systems with relative degree greater than one. A scheme to find the optimal watermarking signal variance for a fixed increase in the control cost to maximize the KLD under the CUSUM test is presented. We provide various numerical simulation results to support our theory. The proposed method is also compared with a state-ofthe-art method based on the Neyman-Pearson detector, illustrating +the smaller detection delay of the proposed sequential detector. +
        +
        + + + +
        +
        +
        @article{NahaTAC2022,
        +  author = {Naha, A. and Teixeira, A. M. H. and Ahl\'{e}n, A. and Dey, S.},
        +  journal = {IEEE Trans. Automatic Control},
        +  number = {3},
        +  pages = {1941--1948},
        +  title = {Sequential detection of Replay attacks},
        +  volume = {68},
        +  year = {2023},
        +  doi = {10.1109/TAC.2022.3174004}
        +}
        +
        +
        + + + + + + + +
        + +
      + +

      2022

      +
      1. + + + +
        + + +
        + “A Zero-Sum Game Framework for Optimal Sensor Placement in Uncertain Networked Control Systems under Cyber-Attacks”.
        + A. T. Nguyen, S. C. Anand, and A. M. H. Teixeira.
        + IEEE Conference on Decision and Control (CDC), 2022
        + +
        + + + + + + ABS + + + + + + + + + + + + BIB + + + + + + +
        +
        + This paper proposes a game-theoretic approach to address the problem of optimal sensor placement against an adversary in uncertain networked control systems. The problem is formulated as a zero-sum game with two players, namely a malicious adversary and a detector. Given a protected performance vertex, we consider a detector, with uncertain system knowledge, that selects another vertex on which to place a sensor and monitors its output with the aim of detecting the presence of the adversary. On the other hand, the adversary, also with uncertain system knowledge, chooses a single vertex and conducts a cyber-attack on its input. The purpose of the adversary is to drive the attack vertex as to maximally disrupt the protected performance vertex while remaining undetected by the detector. As our first contribution, the game payoff of the above-defined zero-sum game is formulated in terms of the Value-at-Risk of the adversary’s impact. However, this game payoff corresponds to an intractable optimization problem. To tackle the problem, we adopt the scenario approach to approximately compute the game payoff. Then, the optimal monitor selection is determined by analyzing the equilibrium of the zero-sum game. The proposed approach is illustrated via a numerical example of a 10-vertex networked control system. +
        +
        + + + +
        +
        +
        @inproceedings{NguyenCDC2022,
        +  address = {},
        +  author = {Nguyen, A. T. and Anand, S. C. and Teixeira, A. M. H.},
        +  booktitle = {IEEE Conference on Decision and Control (CDC)},
        +  title = {A Zero-Sum Game Framework for Optimal Sensor Placement in Uncertain Networked Control Systems under Cyber-Attacks},
        +  year = {2022},
        +  doi = {10.1109/CDC51059.2022.9992468},
        +  tag = {10005}
        +}
        +
        +
        + + + + + + + +
        + +
      2. +
      3. + + + +
        + + +
        + “Structural analyses of a parsimonious watermarking policy
        +for data deception attack detection in networked control systems”
        .
        + A. Naha, A. M. H. Teixeira, A. Ahlén, and S. Dey.
        + IEEE Conference on Decisions and Control (CDC), 2022
        + +
        + + + + + + ABS + + + + + + + + + + + + BIB + + + + + + +
        +
        + In this paper, we perform structural analyses of a parsimonious watermarking policy, which minimizes the average detection delay (ADD) to detect data deception attacks on networked control systems (NCS) for a fixed upper bound on the false alarm rate (FAR). The addition of physical watermarking to the control input of a NCS increases the probability of attack detections with an increase in the control cost. Therefore, we formulate the problem of data deception attack detection for NCS with the facility to add physical watermarking as a stochastic optimal control problem. Then we solve the problem by applying dynamic programming value iterations and find a parsimonious watermarking policy that decides to add watermarking and detects attacks based on the estimated posterior probability of attack. We analyze the optimal policy structure and find that it can be a one, two or three threshold policy depending on a few parameter values. Simulation studies show that the optimal policy for a practical range of parameter values is a two-threshold policy on the posterior probability of attack. Derivation of a threshold-based policy from the structural analysis of the value iteration method reduces the computational complexity during the runtime implementation and offers better structural insights. Furthermore, such an analysis provides a guideline for selecting the parameter values to meet the design requirements. +
        +
        + + + +
        +
        +
        @inproceedings{NahaCDC2022,
        +  address = {},
        +  author = {Naha, A. and Teixeira, A. M. H. and Ahl\'{e}n, A. and Dey, S.},
        +  booktitle = {IEEE Conference on Decisions and Control (CDC)},
        +  title = {Structural analyses of a parsimonious watermarking policy
        +  for data deception attack detection in networked control systems},
        +  year = {2022},
        +  doi = {10.1109/CDC51059.2022.9993201}
        +}
        +
        +
        + + + + + + + +
        + +
      4. +
      5. + + + +
        + + +
        + “Risk assessment and optimal allocation of security measures under stealthy false data injection attacks”.
        + S. C. Anand, A. M. H. Teixeira, and A. Ahlén.
        + IEEE Conference on Control Technology and Applications (CCTA), 2022
        + +
        + + + + + + ABS + + + + + + + + + + + + BIB + + + + + + +
        +
        + This paper firstly addresses the problem of risk assessment under false data injection attacks on uncertain control systems. We consider an adversary with complete system knowledge, injecting stealthy false data into an uncertain control system. We then use the Value-at-Risk to characterize the risk associated with the attack impact caused by the adversary. The worst-case attack impact is characterized by the recently proposed output-to-output gain. We observe that the risk assessment problem corresponds to an infinite non-convex robust optimization problem. To this end, we use dissipative system theory and the scenario approach to approximate the risk-assessment problem into a convex problem and also provide probabilistic certificates on approximation. Secondly, we con-sider the problem of security measure allocation. We consider an operator with a constraint on the security budget. Under this constraint, we propose an algorithm to optimally allocate the security measures using the calculated risk such that the resulting Value-at-risk is minimized. Finally, we illustrate the results through a numerical example. The numerical example also illustrates that the security allocation using the Value-at-risk, and the impact on the nominal system may have different outcomes: thereby depicting the benefit of using risk metrics. +
        +
        + + + +
        +
        +
        @inproceedings{AnandCCTA2022,
        +  address = {},
        +  author = {Anand, S. C. and Teixeira, A. M. H. and Ahl\'{e}n, A.},
        +  booktitle = {IEEE Conference on Control Technology and Applications (CCTA)},
        +  title = {Risk assessment and optimal allocation of security measures under stealthy false data injection attacks},
        +  year = {2022},
        +  tag = {10001},
        +  doi = {10.1109/CCTA49430.2022.9966025},
        +}
        +
        +
        + + + + + + + +
        + +
      6. +
      7. + + + +
        + + +
        + “A Single-Adversary-Single-Detector Zero-Sum Game in Networked Control Systems”.
        + A. T. Nguyen, A. M. H. Teixeira, and A. Medvedev.
        + IFAC Conference on Networked Systems (NecSys), 2022
        + +
        + + + + + + ABS + + + + + + + + + + + + BIB + + + + + + +
        +
        + This paper proposes a game-theoretic approach to address the problem of optimal sensor placement for detecting cyber-attacks in networked control systems. The problem is formulated as a zero-sum game with two players, namely a malicious adversary and a detector. Given a protected target vertex, the detector places a sensor at a single vertex to monitor the system and detect the presence of the adversary. On the other hand, the adversary selects a single vertex through which to conduct a cyber-attack that maximally disrupts the target vertex while remaining undetected by the detector. As our first contribution, for a given pair of attack and monitor vertices and a known target vertex, the game payoff function is defined as the output-to-output gain of the respective system. Then, the paper characterizes the set of feasible actions by the detector that ensures bounded values of the game payoff. Finally, an algebraic sufficient condition is proposed to examine whether a given vertex belongs to the set of feasible monitor vertices. The optimal sensor placement is then determined by computing the mixed-strategy Nash equilibrium of the zero-sum game through linear programming. The approach is illustrated via a numerical example of a 10-vertex networked control system with a given target vertex. +
        +
        + + + +
        +
        +
        @inproceedings{NguyenNecsys2022,
        +  address = {},
        +  author = {Nguyen, A. T. and Teixeira, A. M. H. and Medvedev, A.},
        +  booktitle = {IFAC Conference on Networked Systems (NecSys)},
        +  title = {A Single-Adversary-Single-Detector Zero-Sum Game in Networked Control Systems},
        +  year = {2022},
        +  doi = {10.1016/j.ifacol.2022.07.234},
        +  tag = {10005},
        +}
        +
        +
        + + + + + + + +
        + +
      8. +
      9. + + + +
        + + +
        + “Detection of Bias Injection Attacks on the Glucose Sensor in the Artificial Pancreas Under Meal Disturbances”.
        + F. E. Tosun, A. M. H. Teixeira, A. Ahlén, and S. Dey.
        + American Control Conference, Atlanta, Georgia, USA, 2022
        + +
        + + + + + + ABS + + + + + + + + + + + + BIB + + + + + + +
        +
        + The artificial pancreas is an emerging concept of closed-loop insulin delivery that aims to tightly regulate the blood glucose levels in patients with type 1 diabetes. This paper considers bias injection attacks on the glucose sensor deployed in an artificial pancreas. Modern glucose sensors transmit measurements through wireless communication that are vulnerable to cyber-attacks, which must be timely detected and mitigated. To this end, we propose a model-based anomaly detection scheme using a Kalman filter and a χ 2 test. One key challenge is to distinguish cyber-attacks from large unknown disturbances arising from meal intake. This challenge is addressed by an online meal estimator, and a novel time-varying detection threshold. More precisely, we show that the ordinary least squares is the optimal unbiased estimator of the meal size under certain modelling assumptions. Moreover, we derive a novel time-varying threshold for the χ 2 detector to avoid false alarms during meal ingestion. The results are validated by means of numerical simulations. +
        +
        + + + +
        +
        +
        @inproceedings{Tosun_ACC2022,
        +  address = {Atlanta, Georgia, USA},
        +  author = {Tosun, F. E. and Teixeira, A. M. H. and Ahl\'{e}n, A. and Dey, S.},
        +  booktitle = {American Control Conference},
        +  title = {Detection of Bias Injection Attacks on the Glucose Sensor in the Artificial Pancreas Under Meal Disturbances},
        +  year = {2022},
        +  doi = {10.23919/ACC53348.2022.9867556},
        +  tag = {10002},
        +}
        +
        +
        + + + + + + + +
        + +
      10. +
      11. + + + +
        + + +
        + “Sequential Detection of Replay Attacks with a Parsimonious Watermarking Policy”.
        + A. Naha, A. M. H. Teixeira, A. Ahlén, and S. Dey.
        + American Control Conference, Atlanta, Georgia, USA, 2022
        + +
        + + + + + + ABS + + + + + + + + + + + + BIB + + + + + + +
        +
        + In this paper, we have proposed a technique for Bayesian sequential detection of replay attacks on networked control systems with a constraint on the average number of watermarking (ANW) events used during normal system operations. Such a constraint limits the increase in the control cost due to watermarking. To determine the optimal sequence regarding the addition or otherwise of watermarking signals, first, we formulate an infinite horizon stochastic optimal control problem with a termination state. Then applying the value iteration approach, we find an optional policy that minimizes the average detection delay (ADD) for fixed upper bounds on the false alarm rate (FAR) and ANW. The optimal policy turns out to be a two thresholds policy on the posterior probability of attack. We derive approximate expressions of ADD and FAR as functions of the two derived thresholds and a few other parameters. A simulation study on a single-input single-output system illustrates that the proposed method improves the control cost considerably at the expense of small increases in ADD. We also perform simulation studies to validate the derived theoretical results. +
        +
        + + + +
        +
        +
        @inproceedings{Naha_ACC2022,
        +  address = {Atlanta, Georgia, USA},
        +  author = {Naha, A. and Teixeira, A. M. H. and Ahl\'{e}n, A. and Dey, S.},
        +  booktitle = {American Control Conference},
        +  title = {Sequential Detection of Replay Attacks with a Parsimonious Watermarking Policy},
        +  year = {2022},
        +  doi = {10.23919/ACC53348.2022.9867703},
        +}
        +
        +
        + + + + + + + +
        + +
      12. +
      13. + + + +
        + + +
        + “Risk-averse controller design against data injection attacks on actuators for uncertain control systems”.
        + S. C. Anand and A. M. H. Teixeira.
        + American Control Conference, Atlanta, Georgia, USA, 2022
        + +
        + + + + + + ABS + + + + + + + + + + + + BIB + + + + + + +
        +
        + In this paper, we consider the optimal controller design problem against data injection attacks on actuators for an uncertain control system. We consider attacks that aim at maximizing the attack impact while remaining stealthy in the finite horizon. To this end, we use the Conditional Value-at-Risk to characterize the risk associated with the impact of attacks. The worst-case attack impact is characterized using the recently proposed output-to-output ℓ 2 -gain (OOG). We formulate the design problem and observe that it is non-convex and hard to solve. Using the framework of scenario-based optimization and a convex proxy for the OOG, we propose a convex optimization problem that approximately solves the design problem with probabilistic certificates. Finally, we illustrate the results through a numerical example. +
        +
        + + + +
        +
        +
        @inproceedings{Anand_ACC2022,
        +  address = {Atlanta, Georgia, USA},
        +  author = {Anand, S. C. and Teixeira, A. M. H.},
        +  booktitle = {American Control Conference},
        +  title = {Risk-averse controller design against data injection attacks on actuators for uncertain control systems},
        +  year = {2022},
        +  doi = {10.23919/ACC53348.2022.9867257},
        +  tag = {10001},
        +}
        +
        +
        + + + + + + + +
        + +
      14. +
      15. + + + +
        + + +
        + “Scalable federated machine learning with FEDn”.
        + M. Ekmefjord et al.
        + Symposium on Cluster, Cloud and Internet Computing, Taormina, Italy, 2022
        + +
        + + + + + + ABS + + + + + + + + + + + + BIB + + + + + + +
        +
        + Federated machine learning promises to overcome the input privacy challenge in machine learning. By iteratively updating a model on private clients and aggregating these local model updates into a global federated model, private data is incorporated in the federated model without needing to share and expose that data. Several open software projects for federated learning have appeared. Most of them focuses on supporting flexible experimentation with different model aggregation schemes and with different privacy-enhancing technologies. However, there is a lack of open frameworks that focuses on critical distributed computing aspects of the problem such as scalability and resilience. It is a big step to take for a data scientist to go from an experimental sandbox to testing their federated schemes at scale in real-world geographically distributed settings. To bridge this gap we have designed and developed a production-grade hierarchical federated learning framework, FEDn. The framework is specifically designed to make it easy to go from local development in pseudo-distributed mode to horizontally scalable distributed deployments. FEDn both aims to be production grade for industrial applications and a flexible research tool to explore real-world performance of novel federated algorithms and the framework has been used in number of industrial and academic R&D projects. In this paper we present the architecture and implementation of FEDn. We demonstrate the framework’s scalability and efficiency in evaluations based on two case-studies representative for a cross-silo and a cross-device use-case respectively. +
        +
        + + + +
        +
        +
        @inproceedings{Ekmefjord_CCGrid2022,
        +  address = {Taormina, Italy},
        +  author = {Ekmefjord, M. and Ait-Mlouk, A. and Alawadi, S. and Åkesson, M. and Singh, P. and Spjuth, O. and Toor, S. and Hellander, A.},
        +  booktitle = {Symposium on Cluster, Cloud and Internet Computing},
        +  title = {Scalable federated machine learning with FEDn},
        +  year = {2022},
        +  doi = {10.1109/CCGrid54584.2022.00065},
        +  tag = {10003},
        +}
        +
        +
        + + + + + + + +
        + +
      + +

      2021

      +
      1. + + + +
        + + +
        + “Bayesian network model to distinguish between intentional attacks and accidental technical failures: a case study of floodgates”.
        + S. Chockalingam, W. Pieters, A. M. H. Teixeira, and P. van Gelder.
        + Cybersecurity, vol. 4, no. 29, 2021
        + +
        + + + + + + + + + + + + + + + + BIB + + + + + + + + +
        +
        +
        @article{Chockalingam_2021,
        +  author = {Chockalingam, S. and Pieters, W. and Teixeira, A. M. H. and van Gelder, P.},
        +  journal = {Cybersecurity},
        +  number = {29},
        +  pages = {},
        +  title = {Bayesian network model to distinguish between intentional attacks and accidental technical failures: a case study of floodgates},
        +  volume = {4},
        +  year = {2021}
        +}
        +
        +
        + + + + + + + +
        + +
      2. +
      3. + + + +
        + + +
        + “Design of multiplicative watermarking against covert attacks”.
        + A. J. Gallo, S. C. Anand, A. M. H. Teixeira, and R. M. G. Ferrari.
        + IEEE Conf. Decision and Control, Austin, Texas, USA, 2021
        + +
        + + + + + + + + + + + + + + + + BIB + + + + + + + + +
        +
        +
        @inproceedings{Gallo_CDC2021,
        +  address = {Austin, Texas, USA},
        +  author = {Gallo, A. J. and Anand, S. C. and Teixeira, A. M. H. and Ferrari, R. M. G.},
        +  booktitle = {IEEE Conf. Decision and Control},
        +  title = {Design of multiplicative watermarking against covert attacks},
        +  year = {2021},
        +  doi = {10.1109/CDC45484.2021.9683075}
        +}
        +
        +
        + + + + + + + +
        + +
      4. +
      5. + + + +
        + + +
        + “Stealthy Cyber-Attack Design Using Dynamic Programming”.
        + S. C. Anand and A. M. H. Teixeira.
        + IEEE Conf. Decision and Control, Austin, Texas, USA, 2021
        + +
        + + + + + + + + + + + + + + + + BIB + + + + + + + + +
        +
        +
        @inproceedings{Anand_CDC2021,
        +  address = {Austin, Texas, USA},
        +  author = {Anand, S. C. and Teixeira, A. M. H.},
        +  booktitle = {IEEE Conf. Decision and Control},
        +  title = {Stealthy Cyber-Attack Design Using Dynamic Programming},
        +  year = {2021},
        +  doi = {10.1109/CDC45484.2021.9683451},
        +}
        +
        +
        + + + + + + + +
        + +
      6. +
      7. + + + +
        + + +
        + “Deception Attack Detection Using Reduced Watermarking”.
        + A. Naha, A. M. H. Teixeira, A. Ahlén, and S. Dey.
        + Eur. Control Conf., Rotterdam, The Netherlands, 2021
        + +
        + + + + + + + + + + + + + + + + BIB + + + + + + + + +
        +
        +
        @inproceedings{Naha_ECC2021,
        +  address = {Rotterdam, The Netherlands},
        +  author = {Naha, A. and Teixeira, A. M. H. and Ahl\'{e}n, A. and Dey, S.},
        +  booktitle = {Eur. Control Conf.},
        +  title = {Deception Attack Detection Using Reduced Watermarking},
        +  year = {2021},
        +  doi = {10.23919/ECC54610.2021.9654843}
        +}
        +
        +
        + + + + + + + +
        + +
      8. +
      9. + + + +
        + + +
        + “Introduction to the Book”.
        + R. M. G. Ferrari and A. M. H. Teixeira.
        + in Safety, Security and Privacy for Cyber-Physical Systems, R. M. G. Ferrari and A. M. H. Teixeira, Eds. Cham: Springer International Publishing, 2021, pp. 1–8
        + +
        + + + + + + + + + + + + + + + + BIB + + + + + + + + +
        +
        +
        @incollection{FerrariTeixeira_Springer2021,
        +  author = {Ferrari, Riccardo M. G. and Teixeira, Andr{\'e} M. H.},
        +  editor = {Ferrari, Riccardo M.G. and Teixeira, Andr{\'e} M. H.},
        +  title = {Introduction to the Book},
        +  booktitle = {Safety, Security and Privacy for Cyber-Physical Systems},
        +  year = {2021},
        +  publisher = {Springer International Publishing},
        +  address = {Cham},
        +  pages = {1--8},
        +  isbn = {978-3-030-65048-3},
        +  doi = {10.1007/978-3-030-65048-3_1}
        +}
        +
        +
        + + + + + + + +
        + +
      10. +
      11. + + + +
        + + +
        + “Security Metrics for Control Systems”.
        + A. M. H. Teixeira.
        + in Safety, Security and Privacy for Cyber-Physical Systems, R. M. G. Ferrari and A. M. H. Teixeira, Eds. Cham: Springer International Publishing, 2021, pp. 1–8
        + +
        + + + + + + + + + + + + + + + + BIB + + + + + + + + +
        +
        +
        @incollection{Teixeira_Springer2021,
        +  author = {Teixeira, Andr{\'e} M. H.},
        +  editor = {Ferrari, Riccardo M.G. and Teixeira, Andr{\'e} M. H.},
        +  title = {Security Metrics for Control Systems},
        +  booktitle = {Safety, Security and Privacy for Cyber-Physical Systems},
        +  year = {2021},
        +  publisher = {Springer International Publishing},
        +  address = {Cham},
        +  pages = {1--8},
        +  isbn = {978-3-030-65048-3},
        +  doi = {10.1007/978-3-030-65048-3_6},
        +  tag = {10001}
        +}
        +
        +
        + + + + + + + +
        + +
      12. +
      13. + + + +
        + + +
        + “Detection of Cyber-Attacks: A Multiplicative Watermarking Scheme”.
        + R. M. G. Ferrari and A. M. H. Teixeira.
        + in Safety, Security and Privacy for Cyber-Physical Systems, R. M. G. Ferrari and A. M. H. Teixeira, Eds. Cham: Springer International Publishing, 2021, pp. 1–8
        + +
        + + + + + + + + + + + + + + + + BIB + + + + + + + + +
        +
        +
        @incollection{Ferrari_Springer2021,
        +  author = {Ferrari, Riccardo M. G. and Teixeira, Andr{\'e} M. H.},
        +  editor = {Ferrari, Riccardo M.G. and Teixeira, Andr{\'e} M. H.},
        +  title = {Detection of Cyber-Attacks: A Multiplicative Watermarking Scheme},
        +  booktitle = {Safety, Security and Privacy for Cyber-Physical Systems},
        +  year = {2021},
        +  publisher = {Springer International Publishing},
        +  address = {Cham},
        +  pages = {1--8},
        +  isbn = {978-3-030-65048-3},
        +  doi = {10.1007/978-3-030-65048-3_9}
        +}
        +
        +
        + + + + + + + +
        + +
      14. +
      15. + + + +
        + + +
        + “A Game-Theoretic Approach to Covert Communications in the Presence of Multiple Colluding Wardens”.
        + A. Arghavani, A. Ahlén, A. Teixeira, and S. Dey.
        + 2021 IEEE Wireless Communications and Networking Conference (WCNC), 2021, pp. 1–7
        + +
        + + + + + + + + + + + + + + + + BIB + + + + + + + + +
        +
        +
        @inproceedings{Arghavani_WCNC2021,
        +  title = {A {{Game}}-Theoretic {{Approach}} to {{Covert Communications}} in the {{Presence}} of {{Multiple Colluding Wardens}}},
        +  booktitle = {2021 {{IEEE Wireless Communications}} and {{Networking Conference}} ({{WCNC}})},
        +  author = {Arghavani, Abbas and Ahl{\'e}n, Anders and Teixeira, Andr{\'e} and Dey, Subhrakanti},
        +  year = {2021},
        +  month = mar,
        +  pages = {1--7},
        +  issn = {1558-2612},
        +  doi = {10.1109/WCNC49053.2021.9417312},
        +  copyright = {All rights reserved},
        +  keywords = {communications,Computational modeling,Conferences,game-theory,Games,Linear programming,Nash equilibrium,Numerical simulation,Rayleigh channels,security}
        +}
        +
        +
        + + + + + + + +
        + +
      16. +
      17. + + + +
        + + +
        + “An Evaluation of Container Security Vulnerability Detection Tools”.
        + O. Javed and S. Toor.
        + Cloud and Big Data Computing, 2021
        + +
        + + + + + + + + + + + + + + + + BIB + + + + + + + + +
        +
        +
        @inproceedings{javed_CBDC2021,
        +  title = {An Evaluation of Container Security Vulnerability Detection Tools},
        +  booktitle = {Cloud and Big Data Computing},
        +  author = {Javed, O. and Toor, S.},
        +  year = {2021},
        +  doi = {10.1145/3481646.3481661},
        +  astract = {Container is a lightweight virtualization technology which packages an application, its dependencies and an operating system (OS) to run as an isolated unit. However, the pressing concern with the use of containers is its susceptibility to security attacks. Consequently, a number of container scanning tools are available for detecting container security vulnerabilities. Therefore, in this experience report, we investigate the quality of existing container scanning tools by considering two metrics that reflect coverage and accuracy. We analyze popular public container images hosted on DockerHub using different container scanning tools (i.e., Clair, Anchore, and Microscanner). Our findings show that existing container scanning tools do not detect application package vulnerabilities. Furthermore, we find that existing tools do not have high accuracy.},
        +}
        +
        +
        + + + + + + + +
        + +
      18. +
      19. + + + +
        + + +
        + “Privatized Distributed Anomaly Detection for Large-Scale Nonlinear Uncertain Systems”.
        + V. Rostampour, R. M. G. Ferrari, A. M. H. Teixeira, and T. Keviczky.
        + IEEE Trans. Automatic Control, vol. 66, no. 11, pp. 5299–5313, 2021
        + +
        + + + + + + + + + + + + + + + + BIB + + + + + + + + +
        +
        +
        @article{Rostampour_TAC2020,
        +  author = {Rostampour, V. and Ferrari, R. M.G. and Teixeira, A. M. H. and Keviczky, T.},
        +  journal = {IEEE Trans. Automatic Control},
        +  number = {11},
        +  pages = {5299--5313},
        +  title = {Privatized Distributed Anomaly Detection for Large-Scale Nonlinear Uncertain Systems},
        +  volume = {66},
        +  year = {2021},
        +  doi = {10.1109/TAC.2020.3040251}
        +}
        +
        +
        + + + + + + + +
        + +
      + +

      2020

      +
      1. + + + +
        + + +
        + “A Switching Multiplicative Watermarking Scheme for Detection of Stealthy Cyber-Attacks”.
        + R. Ferrari and A. M. H. Teixeira.
        + IEEE Trans. Automatic Control, vol. 66, no. 6, pp. 2558–2573, 2020
        + +
        + + + + + + + + + + + + + + + + BIB + + + + + + + + +
        +
        +
        @article{Ferrari_TAC2020,
        +  author = {Ferrari, R. and Teixeira, A. M. H.},
        +  journal = {IEEE Trans. Automatic Control},
        +  number = {6},
        +  pages = {2558--2573},
        +  title = {A Switching Multiplicative Watermarking Scheme for Detection of Stealthy Cyber-Attacks},
        +  volume = {66},
        +  year = {2020}
        +}
        +
        +
        + + + + + + + +
        + +
      2. +
      3. + + + +
        + + +
        + “Actuator Security Indices Based on Perfect Undetectability: Computation, Robustness, and Sensor Placement”.
        + J. Milosevic, A. M. H. Teixeira, H. Sandberg, and K. H. Johansson.
        + IEEE Trans. Automatic Control, vol. 65, no. 9, pp. 3816–3831, 2020
        + +
        + + + + + + + + + + + + + + + + BIB + + + + + + + + +
        +
        +
        @article{Milosevic_TAC2020,
        +  author = {Milosevic, J. and Teixeira, A. M. H. and Sandberg, H. and Johansson, K. H.},
        +  doi = {10.1109/TAC.2020.2981392},
        +  journal = {IEEE Trans. Automatic Control},
        +  number = {9},
        +  pages = {3816--3831},
        +  title = {Actuator Security Indices Based on Perfect Undetectability: Computation, Robustness, and Sensor Placement},
        +  volume = {65},
        +  year = {2020}
        +}
        +
        +
        + + + + + + + +
        + +
      4. +
      5. + + + +
        + + +
        + “Joint controller and detector design against
        +data injection attacks on actuators”
        .
        + S. C. Anand and A. M. H. Teixeira.
        + IFAC World Congress, Berlin, Germany, 2020
        + +
        + + + + + + + + + + + + + + + + BIB + + + + + + + + +
        +
        +
        @inproceedings{Anand_2020,
        +  address = {Berlin, Germany},
        +  author = {Anand, S. C. and Teixeira, A M H},
        +  booktitle = {IFAC World Congress},
        +  title = {Joint controller and detector design against
        +  data injection attacks on actuators},
        +  year = {2020}
        +}
        +
        +
        + + + + + + + +
        + +
      6. +
      7. + + + +
        + + +
        + “Privacy-preserving Continuous Tumour Relapse Monitoring Using In-body Radio Signals”.
        + S. Hylamia et al.
        + IEEE Workshop on the Internet of Safe Things (SafeThings), San Francisco, CA, USA, 2020
        + +
        + + + + + + + + + + + + + + + + BIB + + + + + + + + +
        +
        +
        @inproceedings{Hylamia_2020,
        +  address = {San Francisco, CA, USA},
        +  author = {Hylamia, S. and Yan, W. and Teixeira, A M. H. and Asan, N. B. and Perez, M. and Augustine, R. and Voigt, T.},
        +  booktitle = {IEEE Workshop on the Internet of Safe Things (SafeThings)},
        +  title = {Privacy-preserving Continuous Tumour Relapse Monitoring Using In-body Radio Signals},
        +  year = {2020}
        +}
        +
        +
        + + + + + + + +
        + +
      + +

      2019

      +
      1. + + + +
        + + +
        + “Effects of Jamming Attacks on a Control System With Energy Harvesting”.
        + S. Knorn and A. M. H. Teixeira.
        + IEEE Control Systems Letters, vol. 3, no. 4, pp. 829–834, 2019
        + +
        + + + + + + + + + + + + + + + + BIB + + + + + + + + +
        +
        +
        @article{Knorn_CSL2019,
        +  author = {Knorn, S. and Teixeira, A. M. H.},
        +  journal = {IEEE Control Systems Letters},
        +  number = {4},
        +  pages = {829--834},
        +  title = {Effects of Jamming Attacks on a Control System With Energy Harvesting},
        +  volume = {3},
        +  year = {2019}
        +}
        +
        +
        + + + + + + + +
        + +
      2. +
      3. + + + +
        + + +
        + “Optimal stealthy attacks on actuators for strictly proper systems”.
        + A. M. H. Teixeira.
        + IEEE Conf. Decision and Control, Nice, France, 2019
        + +
        + + + + + + + + + + + + + + + + BIB + + + + + + + + +
        +
        +
        @inproceedings{Teixeira_CDC2019,
        +  address = {Nice, France},
        +  author = {Teixeira, A. M. H.},
        +  booktitle = {IEEE Conf. Decision and Control},
        +  title = {Optimal stealthy attacks on actuators for strictly proper systems},
        +  year = {2019}
        +}
        +
        +
        + + + + + + + +
        + +
      4. +
      5. + + + +
        + + +
        + “A Tutorial Introduction to Security and Privacy for Cyber-Physical Systems”.
        + M. S. Chong, H. Sandberg, and A. M. H. Teixeira.
        + Eur. Control Conf., Napoles, Italy, 2019
        + +
        + + + + + + + + + + + + + + + + BIB + + + + + + + + +
        +
        +
        @inproceedings{Chong_ECC2019,
        +  address = {Napoles, Italy},
        +  author = {Chong, M. S. and Sandberg, H. and Teixeira, A. M. H.},
        +  booktitle = {Eur. Control Conf.},
        +  title = {A Tutorial Introduction to Security and Privacy for Cyber-Physical Systems},
        +  year = {2019}
        +}
        +
        +
        + + + + + + + +
        + +
      6. +
      7. + + + +
        + + +
        + “Data Injection Attacks against Feedforward Controllers”.
        + A. M. H. Teixeira.
        + Eur. Control Conf., Napoles, Italy, 2019
        + +
        + + + + + + + + + + + + + + + + BIB + + + + + + + + +
        +
        +
        @inproceedings{Teixeira_ECC2019,
        +  address = {Napoles, Italy},
        +  author = {Teixeira, A. M. H.},
        +  booktitle = {Eur. Control Conf.},
        +  title = {Data Injection Attacks against Feedforward Controllers},
        +  year = {2019}
        +}
        +
        +
        + + + + + + + +
        + +
      8. +
      9. + + + +
        + + +
        + “On the Confidentiality of Linear Anomaly Detector States”.
        + D. Umsonst, E. Nekouei, A. M. H. Teixeira, and H. Sandberg.
        + American Control Conf., Philadelphia, PA, USA, 2019
        + +
        + + + + + + + + + + + + + + + + BIB + + + + + + + + +
        +
        +
        @inproceedings{Umsonst_ACC2019,
        +  address = {Philadelphia, PA, USA},
        +  author = {Umsonst, D. and Nekouei, E. and Teixeira, A. M. H. and Sandberg, H.},
        +  booktitle = {American Control Conf.},
        +  title = {On the Confidentiality of Linear Anomaly Detector States},
        +  year = {2019}
        +}
        +
        +
        + + + + + + + +
        + +
      10. +
      11. + + + +
        + + +
        + “Cyber Risk Analysis of Combined Data Attacks Against Power System State Estimation”.
        + K. Pan, A. M. H. Teixeira, M. Cvetkovic, and P. Palensky.
        + IEEE Trans. Smart Grid, vol. 10, no. 3, pp. 3044–3056, May 2019
        + +
        + + + + + + ABS + + + + + + + + + + + + BIB + + + + + + +
        +
        + Understanding smart grid cyber attacks is key for developing appropriate protection and recovery measures. Advanced attacks pursue maximized impact at minimized costs and detectability. This paper conducts risk analysis of combined data integrity and availability attacks against the power system state estimation. We compare the combined attacks with pure integrity attacks - false data injection (FDI) attacks. A security index for vulnerability assessment to these two kinds of attacks is proposed and formulated as a mixed integer linear programming problem. We show that such combined attacks can succeed with fewer resources than FDI attacks. The combined attacks with limited knowledge of the system model also expose advantages in keeping stealth against the bad data detection. Finally, the risk of combined attacks to reliable system operation is evaluated using the results from vulnerability assessment and attack impact analysis. The findings in this paper are validated and supported by a detailed case study. +
        +
        + + + +
        +
        +
        @article{Pan2018,
        +  archiveprefix = {arXiv},
        +  author = {Pan, Kaikai and Teixeira, Andre M. H. and Cvetkovic, Milos and Palensky, Peter},
        +  doi = {10.1109/TSG.2018.2817387},
        +  eprint = {1708.08349},
        +  issn = {19493053},
        +  journal = {IEEE Trans. Smart Grid},
        +  keywords = {Combined integrity and availability attack,Indexes,Network topology,Power systems,Security,State estimation,Transmission line matrix methods,Transmission line measurements,false data injection,power system state estimation.,risk analysis},
        +  pages = {3044--3056},
        +  volume = {10},
        +  number = {3},
        +  title = {Cyber Risk Analysis of Combined Data Attacks Against Power System State Estimation},
        +  year = {2019},
        +  month = may
        +}
        +
        +
        + + + + + + + +
        + +
      + +

      2018

      +
      1. + + + +
        + + +
        + “Combining Bayesian Networks and Fishbone Diagrams to Distinguish between Intentional Attacks and Accidental Technical Failures”.
        + S. Chockalingam, A. M. H. Teixeira, W. Pieters, N. Khakzad, and P. van Gelder.
        + Proc. 5th Int. Work. Graph. Model. Secur., Oxford, UK, 2018
        + +
        + + + + + + ABS + + + + + + + + + + + + BIB + + + + + + +
        +
        + Because of modern societies’ dependence on industrial control systems, adequate response to system failures is essential. In order to take appropriate measures, it is crucial for operators to be able to distinguish between intentional attacks and accidental technical failures. However, adequate decision support for this matter is lacking. In this paper, we use Bayesian Networks (BNs) to distinguish between intentional attacks and accidental technical failures, based on contributory factors and observations (or test results). To facilitate knowledge elicitation, we use extended shbone diagrams for discussions with experts, and then translate those into the BN formalism. We demonstrate the methodology using an example in a case study from the water management domain. M4 - Citavi +
        +
        + + + +
        +
        +
        @inproceedings{Chockalingam2018,
        +  address = {Oxford, UK},
        +  author = {Chockalingam, Sabarathinam and Teixeira, Andr{\'{e}} M. H. and Pieters, Wolter and Khakzad, Nima and van Gelder, Pieter},
        +  booktitle = {Proc. 5th Int. Work. Graph. Model. Secur.},
        +  title = {Combining Bayesian Networks and Fishbone Diagrams to Distinguish between Intentional Attacks and Accidental Technical Failures},
        +  year = {2018}
        +}
        +
        +
        + + + + + + + +
        + +
      2. +
      3. + + + +
        + + +
        + “Detection of Sensor Data Injection Attacks with Multiplicative Watermarking”.
        + A. M. H. Teixeira and R. M. G. Ferrari.
        + Eur. Control Conf., Cyprus, 2018
        + +
        + + + + + + + + + + + + + + + + BIB + + + + + + + + +
        +
        +
        @inproceedings{Teixeira2018,
        +  address = {Cyprus},
        +  author = {Teixeira, A. M. H. and Ferrari, R. M. G.},
        +  booktitle = {Eur. Control Conf.},
        +  title = {Detection of Sensor Data Injection Attacks with Multiplicative Watermarking},
        +  year = {2018}
        +}
        +
        +
        + + + + + + + +
        + +
      4. +
      5. + + + +
        + + +
        + “Differentially-Private Distributed Fault Diagnosis for Large-Scale Nonlinear Uncertain Systems”.
        + V. Rostampour, R. Ferrari, A. M. H. Teixeira, and T. Keviczky.
        + IFAC-PapersOnLine, vol. 51, no. 24, pp. 975–982, Jan. 2018
        + +
        + + + + + + ABS + + + + + + + + + + + + BIB + + + + + + +
        +
        + Distributed fault diagnosis has been proposed as an effective technique for monitoring large scale, nonlinear and uncertain systems. It is based on the decomposition of the large scale system into a number of interconnected subsystems, each one monitored by a dedicated Local Fault Detector (LFD). Neighboring LFDs, in order to successfully account for subsystems interconnection, are thus required to communicate with each other some of the measurements from their subsystems. Anyway, such communication may expose private information of a given subsystem, such as its local input. To avoid this problem, we propose here to use differential privacy to pre-process data before transmission. +
        +
        + + + +
        +
        +
        @article{Rostampour2018,
        +  author = {Rostampour, Vahab and Ferrari, Riccardo and Teixeira, Andr{\'{e}} M H and Keviczky, Tam{\'{a}}s},
        +  doi = {10.1016/J.IFACOL.2018.09.703},
        +  issn = {2405-8963},
        +  journal = {IFAC-PapersOnLine},
        +  month = jan,
        +  number = {24},
        +  pages = {975--982},
        +  title = {Differentially-Private Distributed Fault Diagnosis for Large-Scale Nonlinear Uncertain Systems},
        +  volume = {51},
        +  year = {2018}
        +}
        +
        +
        + + + + + + + +
        + +
      6. +
      7. + + + +
        + + +
        + “Security measure allocation for industrial control systems: Exploiting systematic search techniques and submodularity”.
        + J. Milošević, A. M. H. Teixeira, T. Tanaka, K. H. Johansson, and H. Sandberg.
        + Int. J. Robust Nonlinear Control, no. 11, pp. 4278–4302, 2018
        + +
        + + + + + + + + + + + + + + + + BIB + + + + + + + + +
        +
        +
        @article{Jezdimir2018,
        +  author = {Milo{\v{s}}evi{\'{c}}, Jezdimir and Teixeira, Andr{\'{e}} M. H. and Tanaka, Takashi and Johansson, Karl H. and Sandberg, Henrik},
        +  doi = {10.1002/rnc.4375},
        +  journal = {Int. J. Robust Nonlinear Control},
        +  vol = {30},
        +  number = {11},
        +  pages = {4278--4302},
        +  title = {Security measure allocation for industrial control systems: Exploiting systematic search techniques and submodularity},
        +  year = {2018}
        +}
        +
        +
        + + + + + + + +
        + +
      8. +
      9. + + + +
        + + +
        + “Secure Cloud Connectivity for Scientific Applications”.
        + L. Osmani et al.
        + IEEE Transactions on Services Computing, 2018
        + +
        + + + + + + ABS + + + + + + + + + + + + BIB + + + + + + +
        +
        + Cloud computing improves utilization and flexibility in allocating computing resources while reducing the infrastructural costs. However, in many cases cloud technology is still proprietary and tainted by security issues rooted in the multi-user and hybrid cloud environment. A lack of secure connectivity in a hybrid cloud environment hinders the adaptation of clouds by scientific communities that require scaling-out of the local infrastructure using publicly available resources for large-scale experiments. In this article, we present a case study of the DII-HEP secure cloud infrastructure and propose an approach to securely scale-out a private cloud deployment to public clouds in order to support hybrid cloud scenarios. A challenge in such scenarios is that cloud vendors may offer varying and possibly incompatible ways to isolate and interconnect virtual machines located in different cloud networks. Our approach is tenant driven in the sense that the tenant provides its connectivity mechanism. We provide a qualitative and quantitative analysis of a number of alternatives to solve this problem. We have chosen one of the standardized alternatives, Host Identity Protocol, for further experimentation in a production system because it supports legacy applications in a topologically-independent and secure way. +
        +
        + + + +
        +
        +
        @article{OsmaniTSC2018,
        +  author = {Osmani, L. and Toor, S. and Komu, N. and Kortelainen, M. and Lindén, T. and White, J. and Khan, R. and Eerola, P. and Tarkoma, S.},
        +  journal = {IEEE Transactions on Services Computing},
        +  number = {},
        +  pages = {},
        +  title = {Secure Cloud Connectivity for Scientific Applications},
        +  volume = {},
        +  year = {2018},
        +  doi = {10.1109/TSC.2015.2469292}
        +}
        +
        +
        + + + + + + + +
        + +
      + +

      2017

      +
      1. + + + +
        + + +
        + “Bayesian network models in cyber security: A systematic review”.
        + S. Chockalingam, W. Pieters, A. M. H. Teixeira, and P. van Gelder.
        + in Secur. IT Syst. Nord. 2017. Lect. Notes Comput. Sci., vol. 10674 LNCS, H. Lipmaa, A. and Mitrokotsa, and R. and Matulevičius, Eds. Springer, Cham, 2017, pp. 105–122
        + +
        + + + + + + ABS + + + + + + + + + + + + BIB + + + + + + +
        +
        + Bayesian Networks (BNs) are an increasingly popular mod- elling technique in cyber security especially due to their capability to overcome data limitations. This is also exemplified by the growth of BN models development in cyber security. However, a comprehensive comparison and analysis of these models is missing. In this paper, we conduct a systematic review of the scientific literature and identify 17 standard BN models in cyber security. We analyse these models based on 8 different criteria and identify important patterns in the use of these models. A key outcome is that standard BNs are noticeably used for problems especially associated with malicious insiders. This study points out the core range of problems that were tackled using standard BN models in cyber security, and illuminates key research gaps. +
        +
        + + + +
        +
        +
        @incollection{Chockalingam2017a,
        +  author = {Chockalingam, Sabarathinam and Pieters, Wolter and Teixeira, Andr{\'{e}} M. H. and van Gelder, Pieter},
        +  booktitle = {Secur. IT Syst. Nord. 2017. Lect. Notes Comput. Sci.},
        +  doi = {10.1007/978-3-319-70290-2_7},
        +  editor = {Lipmaa, Helger and and Mitrokotsa, Aikaterini and and Matulevi{\v{c}}ius, Raimundas},
        +  isbn = {9783319702896},
        +  issn = {16113349},
        +  keywords = {Bayesian attack graph,Bayesian network,Cyber security,Information security,Insider threat},
        +  pages = {105--122},
        +  publisher = {Springer, Cham},
        +  title = {Bayesian network models in cyber security: A systematic review},
        +  volume = {10674 LNCS},
        +  year = {2017}
        +}
        +
        +
        + + + + + + + +
        + +
      2. +
      3. + + + +
        + + +
        + “Co-simulation for Cyber Security Analysis: Data Attacks against Energy Management System”.
        + K. Pan, A. M. H. Teixeira, C. López, and P. Palensky.
        + IEEE Int. Conf. Smart Grid Commun., Dresden, Germany, 2017, pp. 253–258
        + +
        + + + + + + ABS + + + + + + + + + + + + BIB + + + + + + +
        +
        + It is challenging to assess the vulnerability of a cyber-physical power system to data attacks from an integral perspective. In order to support vulnerability assessment except analytic analysis, suitable platform for security tests needs to be developed. In this paper we analyze the cyber security of energy management system (EMS) against data attacks. First we extend our analytic framework that characterizes data attacks as optimization problems with the objectives specified as security metrics and constraints corresponding to the communication network properties. Second, we build a platform in the form of co-simulation - coupling the power system simulator DIgSILENT PowerFactory with communication network simulator OMNeT++, and Matlab for EMS applications (state estimation, optimal power flow). Then the framework is used to conduct attack simulations on the co-simulation based platform for a power grid test case. The results indicate how vulnerable of EMS to data attacks and how co-simulation can help assess vulnerability. +
        +
        + + + +
        +
        +
        @inproceedings{Pan2017,
        +  address = {Dresden, Germany},
        +  archiveprefix = {arXiv},
        +  author = {Pan, Kaikai and Teixeira, Andr{\'{e}} M. H. and L{\'{o}}pez, Claudio and Palensky, Peter},
        +  booktitle = {IEEE Int. Conf. Smart Grid Commun.},
        +  doi = {10.1109/SmartGridComm.2017.8340668},
        +  eprint = {1708.08322},
        +  isbn = {9781538640555},
        +  pages = {253--258},
        +  title = {Co-simulation for Cyber Security Analysis: Data Attacks against Energy Management System},
        +  year = {2017}
        +}
        +
        +
        + + + + + + + +
        + +
      4. +
      5. + + + +
        + + +
        + “Data attacks on power system state estimation: Limited adversarial knowledge vs. limited attack resources”.
        + K. Pan, A. M. H. Teixeira, M. Cvetkovic, and P. Palensky.
        + IECON 2017 - 43rd Annu. Conf. IEEE Ind. Electron. Soc., Beijing, China, 2017, pp. 4313–4318
        + +
        + + + + + + ABS + + + + + + + + + + + + BIB + + + + + + +
        +
        + \textcopyright 2017 IEEE. It has shown that with perfect knowledge of the system model and the capability to manipulate a certain number of measurements, the false data injection (FDI) attacks, as a class of data integrity attacks, can coordinate measurements corruption to keep stealth against the bad data detection schemes. However, a more realistic attack is essentially an attack with limited adversarial knowledge of the system model and limited attack resources due to various reasons. In this paper, we generalize the data attacks that they can be pure FDI attacks or combined with availability attacks (e.g., DoS attacks) and analyze the attacks with limited adversarial knowledge or limited attack resources. The attack impact is evaluated by the proposed metrics and the detection probability of attacks is calculated using the distribution property of data with or without attacks. The analysis is supported with results from a power system use case. The results show how important the knowledge is to the attacker and which measurements are more vulnerable to attacks with limited resources. +
        +
        + + + +
        +
        +
        @inproceedings{Pan2017a,
        +  address = {Beijing, China},
        +  author = {Pan, Kaikai and Teixeira, Andre M. H. and Cvetkovic, Milos and Palensky, Peter},
        +  booktitle = {IECON 2017 - 43rd Annu. Conf. IEEE Ind. Electron. Soc.},
        +  doi = {10.1109/IECON.2017.8216741},
        +  isbn = {978-1-5386-1127-2},
        +  month = oct,
        +  pages = {4313--4318},
        +  title = {Data attacks on power system state estimation: Limited adversarial knowledge vs. limited attack resources},
        +  year = {2017}
        +}
        +
        +
        + + + + + + + +
        + +
      6. +
      7. + + + +
        + + +
        + “Detection and Isolation of Replay Attacks through Sensor Watermarking”.
        + R. M. G. Ferrari and A. M. H. Teixeira.
        + IFAC-PapersOnLine, vol. 50, no. 1, pp. 7363–7368, Jul. 2017
        + +
        + + + + + + ABS + + + + + + + + + + + + BIB + + + + + + +
        +
        + This paper addresses the detection and isolation of replay attacks on sensor measurements. As opposed to previously proposed additive watermarking, we propose a multiplicative watermarking scheme, where each sensor’s output is separately watermarked by being fed to a SISO watermark generator. Additionally, a set of equalizing filters is placed at the controller’s side, which reconstructs the original output signals from the received watermarked data. We show that the proposed scheme has several advantages over existing approaches: it has no detrimental effects on the closed-loop performance in the absence of attacks; it can be designed in a modular fashion, independently of the design of the controller and anomaly detector; it facilitates the detection of replay attacks and the isolation of the time at which the replayed data was recorded. These properties are discussed in detail and the results are illustrated through a numerical example. +
        +
        + + + +
        +
        +
        @article{Ferrari_IFAC_2017,
        +  author = {Ferrari, Riccardo M.G. and Teixeira, Andr{\'{e}} M. H.},
        +  doi = {10.1016/j.ifacol.2017.08.1502},
        +  issn = {24058963},
        +  journal = {IFAC-PapersOnLine},
        +  month = jul,
        +  number = {1},
        +  pages = {7363--7368},
        +  title = {Detection and Isolation of Replay Attacks through Sensor Watermarking},
        +  volume = {50},
        +  year = {2017}
        +}
        +
        +
        + + + + + + + +
        + +
      8. +
      9. + + + +
        + + +
        + “Detection and isolation of routing attacks through sensor watermarking”.
        + R. M. G. Ferrari and A. M. H. Teixeira.
        + Proc. Am. Control Conf., Seattle, WA, USA, 2017, pp. 5436–5442
        + +
        + + + + + + ABS + + + + + + + + + + + + BIB + + + + + + +
        +
        + \textcopyright 2017 American Automatic Control Council (AACC). In networked control systems, leveraging the peculiarities of the cyber-physical domains and their interactions may lead to novel detection and defense mechanisms against malicious cyber-attacks. In this paper, we propose a multiplicative sensor watermarking scheme, where each sensor’s output is separately watermarked by a Single Input Single Output (SISO) filter. Hence, such scheme does not require communication between multiple sensors, but can still lead to detection and isolation of malicious cyber-attacks. In particular, we analyze the benefits of the proposed watermarking scheme for two attack scenarios: The physical sensor re-routing attack and the cyber measurement re-routing one. For each attack scenario, detectability and isolability properties are analyzed with and without the proposed watermarking scheme and we show how the watermarking scheme can be leveraged to detect cyber sensor routing attacks. In order to detect compromised sensors, we design an observer-based detector with a robust adaptive threshold. Additionally, we identify the sensors involved in the re-routing attacks by means of a tailored Recursive Least Squares parameter estimation algorithm. The results are illustrated through a numerical example. +
        +
        + + + +
        +
        +
        @inproceedings{Ferrari2017,
        +  address = {Seattle, WA, USA},
        +  author = {Ferrari, Riccardo M.G. and Teixeira, Andre M. H.},
        +  booktitle = {Proc. Am. Control Conf.},
        +  doi = {10.23919/ACC.2017.7963800},
        +  isbn = {9781509059928},
        +  issn = {07431619},
        +  month = may,
        +  pages = {5436--5442},
        +  title = {Detection and isolation of routing attacks through sensor watermarking},
        +  year = {2017}
        +}
        +
        +
        + + + + + + + +
        + +
      10. +
      11. + + + +
        + + +
        + “Distributed sensor and actuator reconfiguration for fault-tolerant networked control systems”.
        + A. M. H. Teixeira, J. Araujo, H. Sandberg, and K. H. K. H. Johansson.
        + IEEE Trans. Control Netw. Syst., pp. 1–12, 2017
        + +
        + + + + + + ABS + + + + + + + + + + + + BIB + + + + + + +
        +
        + IEEE In this paper, we address the problem of distributed reconfiguration of networked control systems upon the removal of misbehaving sensors and actuators. In particular, we consider systems with redundant sensors and actuators cooperating to recover from faults. Reconfiguration is performed while minimizing a steady-state estimation error covariance and a quadratic control cost. A model-matching condition is imposed on the reconfiguration scheme. It is shown that the reconfiguration and its underlying computation can be distributed. Using an average dwell-time approach, the stability of the distributed reconfiguration scheme under finite-time termination is analyzed. The approach is illustrated in a numerical example. +
        +
        + + + +
        +
        +
        @article{Teixeira_TCNS_2017,
        +  author = {Teixeira, Andre M. H. and Araujo, Jose and Sandberg, Henrik and Johansson, K.H. Karl H.},
        +  doi = {10.1109/TCNS.2017.2732158},
        +  issn = {2325-5870},
        +  journal = {IEEE Trans. Control Netw. Syst.},
        +  keywords = {Actuators,Computational modeling,Estimation error,Networked control systems,Redundancy},
        +  pages = {1--12},
        +  title = {Distributed sensor and actuator reconfiguration for fault-tolerant networked control systems},
        +  year = {2017}
        +}
        +
        +
        + + + + + + + +
        + +
      12. +
      13. + + + +
        + + +
        + “Estimation With Strategic Sensors”.
        + F. Farokhi, A. M. H. Teixeira, and C. Langbort.
        + IEEE Trans. Automat. Contr., vol. 62, no. 2, pp. 724–739, Feb. 2017
        + +
        + + + + + + ABS + + + + + + + + + + + + BIB + + + + + + +
        +
        + \textcopyright 1963-2012 IEEE. We introduce a model of estimation in the presence of strategic, self-interested sensors. We employ a game-Theoretic setup to model the interaction between the sensors and the receiver. The cost function of the receiver is equal to the estimation error variance while the cost function of the sensor contains an extra term which is determined by its private information. We start by the single sensor case in which the receiver has access to a noisy but honest side information in addition to the message transmitted by a strategic sensor. We study both static and dynamic estimation problems. For both these problems, we characterize a family of equilibria in which the sensor and the receiver employ simple strategies. Interestingly, for the dynamic estimation problem, we find an equilibrium for which the strategic sensor uses a memory-less policy. We generalize the static estimation setup to multiple sensors with synchronous communication structure (i.e., all the sensors transmit their messages simultaneously). We prove the maybe surprising fact that, for the constructed equilibrium in affine strategies, the estimation quality degrades as the number of sensors increases. However, if the sensors are herding (i.e., copying each other policies), the quality of the receiver’s estimation improves as the number of sensors increases. Finally, we consider the asynchronous communication structure (i.e., the sensors transmit their messages sequentially). +
        +
        + + + +
        +
        +
        @article{Farokhi2017,
        +  author = {Farokhi, Farhad and Teixeira, Andre M. H. and Langbort, Cedric},
        +  doi = {10.1109/TAC.2016.2571779},
        +  issn = {0018-9286},
        +  journal = {IEEE Trans. Automat. Contr.},
        +  keywords = {Estimation,Kalman filtering,game theory,strategic sensors},
        +  month = feb,
        +  number = {2},
        +  pages = {724--739},
        +  title = {Estimation With Strategic Sensors},
        +  volume = {62},
        +  year = {2017}
        +}
        +
        +
        + + + + + + + +
        + +
      14. +
      15. + + + +
        + + +
        + “Integrated Safety and Security Risk Assessment Methods: A Survey of Key Characteristics and Applications”.
        + S. Chockalingam, D. Hadziosmanovic, W. Pieters, A. M. H. Teixeira, and P. van Gelder.
        + in Crit. Inf. Infrastructures Secur. CRITIS 2016. Lect. Notes Comput. Sci., G. Havarneanu, R. Setola, H. Nassopoulos, and S. Wolthusen, Eds. Springer, Cham, 2017, pp. 50–62
        + +
        + + + + + + ABS + + + + + + + + + + + + BIB + + + + + + +
        +
        + Over the last years, we have seen several security incidents that compromised system safety, of which some caused physical harm to people. Meanwhile, various risk assessment methods have been developed that integrate safety and security, and these could help to address the corresponding threats by implementing suitable risk treatment plans. However, an overarching overview of these methods, systematizing the characteristics of such methods, is missing. In this paper, we conduct a systematic literature review, and identify 7 integrated safety and security risk assessment methods. We analyze these methods based on 5 different criteria, and identify key characteristics and applications. A key outcome is the distinction between sequential and non-sequential integration of safety and security, related to the order in which safety and security risks are assessed. This study provides a basis for developing more effective integrated safety and security risk assessment methods in the future. +
        +
        + + + +
        +
        +
        @incollection{Chockalingam2017,
        +  archiveprefix = {arXiv},
        +  author = {Chockalingam, Sabarathinam and Hadziosmanovic, Dina and Pieters, Wolter and Teixeira, Andre M. H. and van Gelder, Pieter},
        +  booktitle = {Crit. Inf. Infrastructures Secur. CRITIS 2016. Lect. Notes Comput. Sci.},
        +  doi = {10.1007/978-3-319-71368-7_5},
        +  editor = {Havarneanu, G. and Setola, R. and Nassopoulos, H. and Wolthusen, S.},
        +  eprint = {1707.02140},
        +  isbn = {9783319713670},
        +  issn = {16113349},
        +  keywords = {Integrated safety and security risk assessment,Risk analysis,Risk evaluation,Risk identification,Safety risk assessment,Security risk assessment},
        +  month = oct,
        +  pages = {50--62},
        +  publisher = {Springer, Cham},
        +  title = {Integrated Safety and Security Risk Assessment Methods: A Survey of Key Characteristics and Applications},
        +  year = {2017}
        +}
        +
        +
        + + + + + + + +
        + +
      16. +
      17. + + + +
        + + +
        + “Voltage Control in Distributed Generation under Measurement Falsification Attacks”.
        + M. Ma, A. M. H. Teixeira, J. van den Berg, and P. Palensky.
        + IFAC-PapersOnLine, vol. 50, no. 1, pp. 8379–8384, Jul. 2017
        + +
        + + + + + + ABS + + + + + + + + + + + + BIB + + + + + + +
        +
        + Low-voltage distribution grids experience a rising penetration of inverter-based, distributed generation. In order to not only contribute to but also solve voltage problems, these inverters are increasingly asked to participate in intelligent grid controls. Communicating inverters implement distributed voltage droop controls. The impact of cyber-attacks to the stability of such distributed grid controls is poorly researched and therefore addressed in this article. We characterize the potential impact of several attack scenarios by employing the positivity and diagonal dominance properties. In particular, we discuss measurement falsification scenarios where the attacker corrupts voltage measurement data received by the voltage droop controllers. Analytical, control-theoretic methods for assessing the impact on system stability and voltage magnitude are presented and validated via simulation. +
        +
        + + + +
        +
        +
        @article{Ma2017,
        +  author = {Ma, Mingxiao and Teixeira, Andr{\'{e}} M. H. and van den Berg, Jan and Palensky, Peter},
        +  doi = {10.1016/j.ifacol.2017.08.1562},
        +  issn = {24058963},
        +  journal = {IFAC-PapersOnLine},
        +  keywords = {Cyber security,distribution network,risk assessment,stability,voltage control},
        +  month = jul,
        +  number = {1},
        +  pages = {8379--8384},
        +  title = {Voltage Control in Distributed Generation under Measurement Falsification Attacks},
        +  volume = {50},
        +  year = {2017}
        +}
        +
        +
        + + + + + + + +
        + +
      + +

      2016

      +
      1. + + + +
        + + +
        + “Combined data integrity and availability attacks on state estimation in cyber-physical power grids”.
        + K. Pan, A. M. H. Teixeira, M. Cvetkovic, and P. Palensky.
        + IEEE Int. Conf. Smart Grid Commun., Sydney, Australia, 2016, pp. 271–277
        + +
        + + + + + + ABS + + + + + + + + + + + + BIB + + + + + + +
        +
        + \textcopyright 2016 IEEE. This paper introduces combined data integrity and availability attacks to expand the attack scenarios against power system state estimation. The goal of the adversary, who uses the combined attack, is to perturb the state estimates while remaining hidden from the observer. We propose security metrics that quantify vulnerability of power grids to combined data attacks under single and multi-path routing communication models. In order to evaluate the proposed security metrics, we formulate them as mixed integer linear programming (MILP) problems. The relation between the security metrics of combined data attacks and pure data integrity attacks is analyzed, based on which we show that, when data availability and data integrity attacks have the same cost, the two metrics coincide. When data availability attacks have a lower cost than data integrity attacks, we show that a combined data attack could be executed with less attack resources compared to pure data integrity attacks. Furthermore, it is shown that combined data attacks would bypass integrity-focused mitigation schemes. These conclusions are supported by the results obtained on a power system model with and without a communication model with single or multi-path routing. +
        +
        + + + +
        +
        +
        @inproceedings{Pan2016,
        +  address = {Sydney, Australia},
        +  author = {Pan, Kaikai and Teixeira, Andre M H and Cvetkovic, Milos and Palensky, Peter},
        +  booktitle = {IEEE Int. Conf. Smart Grid Commun.},
        +  doi = {10.1109/SmartGridComm.2016.7778773},
        +  isbn = {978-1-5090-4075-9},
        +  month = nov,
        +  pages = {271--277},
        +  title = {Combined data integrity and availability attacks on state estimation in cyber-physical power grids},
        +  year = {2016}
        +}
        +
        +
        + + + + + + + +
        + +
      2. +
      3. + + + +
        + + +
        + “Cyber-Physical-Security Framework for Building Energy Management System”.
        + K. Paridari et al.
        + ACM/IEEE 7th Int. Conf. Cyber-Physical Syst. ICCPS, Vienna, Austria, 2016
        + +
        + + + + + + ABS + + + + + + + + + + + + BIB + + + + + + +
        +
        + \textcopyright 2016 IEEE. Energy management systems (EMS) are used to control energy usage in buildings and campuses, by employing technologies such as supervisory control and data acquisition (SCADA) and building management systems (BMS), in order to provide reliable energy supply and maximise user comfort while minimising energy usage. Historically, EMS systems were installed when potential security threats were only physical. Nowadays, EMS systems are connected to the building network and as a result directly to the outside world. This extends the attack surface to potential sophisticated cyber-attacks, which adversely impact EMS operation, resulting in service interruption and downstream financial implications. Currently, the security systems that detect attacks operate independently to those which deploy resiliency policies and use very basic methods. We propose a novel EMS cyber-physical-security framework that executes a resilient policy whenever an attack is detected using security analytics. In this framework, both the resilient policy and the security analytics are driven by EMS data, where the physical correlations between the data-points are identified to detect outliers and then the control loop is closed using an estimated value in place of the outlier. The framework has been tested using a reduced order model of a real EMS site. +
        +
        + + + +
        +
        +
        @inproceedings{Paridari2016a,
        +  address = {Vienna, Austria},
        +  author = {Paridari, K. and Mady, A.E.-D. and {La Porta}, S. and Chabukswar, R. and Blanco, J. and Teixeira, A. M. H. and Sandberg, H. and Boubekeur, M.},
        +  booktitle = {ACM/IEEE 7th Int. Conf. Cyber-Physical Syst. ICCPS},
        +  doi = {10.1109/ICCPS.2016.7479072},
        +  isbn = {9781509017720},
        +  keywords = {Cyber-physical-security,energy management system,resilient control,security analytics,virtual sensor},
        +  title = {Cyber-Physical-Security Framework for Building Energy Management System},
        +  year = {2016}
        +}
        +
        +
        + + + + + + + +
        + +
      4. +
      5. + + + +
        + + +
        + “Cybersecurity as a Politikum”.
        + L. Fichtner, W. Pieters, and A. Teixeira.
        + Proc. 2016 New Secur. Paradig. Work. NSPW, Granby, CO, USA, 2016, vol. 26-29-Sept, pp. 36–48
        + +
        + + + + + + ABS + + + + + + + + + + + + BIB + + + + + + +
        +
        + \textcopyright 2016 ACM. In the cybersecurity community it is common to think of security as a design feature for systems and infrastructures that may be difficult to balance with other requirements. What is less studied is how security requirements come about, for which reasons, and what their influence is on the actions the system facilitates. Security is for example often used as an argument for or against granting access rights that are of importance to stakeholders, such as in the discussion on counterterrorism and privacy. This paper argues that the ongoing politicization of security issues calls for a paradigm to study cybersecurity as a Politikum: a matter of political concern, embedded in existing and future infrastructures. We summarize literature which inspired this paper and explain the role of security arguments for infrastructure governance. Then we outline the new paradigm and its core concepts and contribution, including the notion of framing. Finally, we present discourse analysis and infrastructure ethnography as research methods and discuss cases in which discourses (may) shape infrastructures, in particular smart cities. +
        +
        + + + +
        +
        +
        @inproceedings{Fichtner2016,
        +  address = {Granby, CO, USA},
        +  author = {Fichtner, Laura and Pieters, Wolter and Teixeira, Andr{\'{e}}},
        +  booktitle = {Proc. 2016 New Secur. Paradig. Work. NSPW},
        +  doi = {10.1145/3011883.3011887},
        +  isbn = {9781450348133},
        +  keywords = {Discourse analysis,Framing,Infrastructure ethnography,Securitization,Security arguments,Security politics,Threat models},
        +  pages = {36--48},
        +  title = {Cybersecurity as a Politikum},
        +  volume = {26-29-Sept},
        +  year = {2016}
        +}
        +
        +
        + + + + + + + +
        + +
      6. +
      7. + + + +
        + + +
        + “Fault Detection and Diagnosis for Compliance Monitoring in International Supply Chains”.
        + Y. Wang et al.
        + 22nd Am. Conf. Inf. Syst., San Diego, CA, USA, 2016
        + +
        + + + + + + ABS + + + + + + + + + + + + BIB + + + + + + +
        +
        + Currently international supply chains are facing risks concerning faults in compliance, such as altering shipping documentations, fictitious inventory, and inter-company manipulations. In this paper a method to detect and diagnose fault scenarios regarding customs compliance in supply chains is proposed. This method forms part of a general approach called model-based auditing, which is based on a normative meta-model of the movement of money and goods or services. The modeling framework is proposed on compliance monitoring of supply chains with focus on information systems and compliance reporting tools. The innovation lies in the application and mapping of modeling techniques from dynamical systems engineering to business process analysis for audit and supervision purposes. Specifically, the application domain is where money, goods as well as information are transferred between international supply chain partners. A case study of a leading company in electronics manufacturing applying the model is analyzed. +
        +
        + + + +
        +
        +
        @inproceedings{Wang2016,
        +  address = {San Diego, CA, USA},
        +  author = {Wang, Yuxin and Teixeira, Andr{\'{e}} A.H. and Tian, Yifu and Hulstijn, Joris and Tan, Yao-Hua Y.-H. and Teixeira, Andr{\'{e}} A.H. and Hulstijn, Joris and Tan, Yao-Hua Y.-H.},
        +  booktitle = {22nd Am. Conf. Inf. Syst.},
        +  month = aug,
        +  title = {Fault Detection and Diagnosis for Compliance Monitoring in International Supply Chains},
        +  year = {2016}
        +}
        +
        +
        + + + + + + + +
        + +
      8. +
      9. + + + +
        + + +
        + “From control system security indices to attack identifiability”.
        + H. Sandberg and A. M. H. A. M. H. Teixeira.
        + 2016 Sci. Secur. Cyber-Physical Syst. Work., Vienna, Austria, 2016, pp. 1–6
        + +
        + + + + + + ABS + + + + + + + + + + + + BIB + + + + + + +
        +
        + \textcopyright 2016 IEEE. In this paper, we investigate detectability and identifiability of attacks on linear dynamical systems that are subjected to external disturbances. We generalize a concept for a security index, which was previously introduced for static systems. The index exactly quantifies the resources necessary for targeted attacks to be undetectable and unidentifiable in the presence of disturbances. This information is useful for both risk assessment and for the design of anomaly detectors. Finally, we show how techniques from the fault detection literature can be used to decouple disturbances and to identify attacks, under certain sparsity constraints. +
        +
        + + + +
        +
        +
        @inproceedings{Sandberg2016,
        +  address = {Vienna, Austria},
        +  author = {Sandberg, Henrik and Teixeira, Andre M.H. A.M.H.},
        +  booktitle = {2016 Sci. Secur. Cyber-Physical Syst. Work.},
        +  doi = {10.1109/SOSCYPS.2016.7580001},
        +  isbn = {978-1-5090-4304-0},
        +  month = apr,
        +  pages = {1--6},
        +  title = {From control system security indices to attack identifiability},
        +  year = {2016}
        +}
        +
        +
        + + + + + + + +
        + +
      + +

      2015

      +
      1. + + + +
        + + +
        + “A secure control framework for resource-limited adversaries”.
        + A. Teixeira, I. Shames, H. Sandberg, and K. H. Johansson.
        + Automatica, vol. 51, no. 1, pp. 135–148, 2015
        + +
        + + + + + + ABS + + + + + + + + + + + + BIB + + + + + + +
        +
        + Cyber-secure networked control is modeled, analyzed, and experimentally illustrated in this paper. An attack space defined by the adversary’s model knowledge, disclosure, and disruption resources is introduced. Adversaries constrained by these resources are modeled for a networked control system architecture. It is shown that attack scenarios corresponding to denial-of-service, replay, zero-dynamics, and bias injection attacks on linear time-invariant systems can be analyzed using this framework. Furthermore, the attack policy for each scenario is described and the attack’s impact is characterized using the concept of safe sets. An experimental setup based on a quadruple-tank process controlled over a wireless network is used to illustrate the attack scenarios, their consequences, and potential counter-measures. +
        +
        + + + +
        +
        +
        @article{Teixeira_Automatica2015,
        +  archiveprefix = {arXiv},
        +  author = {Teixeira, Andr{\'{e}} and Shames, Iman and Sandberg, Henrik and Johansson, Karl Henrik},
        +  doi = {10.1016/j.automatica.2014.10.067},
        +  eprint = {1212.0226},
        +  isbn = {0005-1098},
        +  issn = {00051098},
        +  journal = {Automatica},
        +  keywords = {Attack space,Cyber-physical systems,Secure control systems,System security},
        +  number = {1},
        +  pages = {135--148},
        +  title = {A secure control framework for resource-limited adversaries},
        +  volume = {51},
        +  year = {2015}
        +}
        +
        +
        + + + + + + + +
        + +
      2. +
      3. + + + +
        + + +
        + “Cyber-Secure and Resilient Architectures for Industrial Control Systems”.
        + A. Teixeira, F. Kupzog, H. Sandberg, and K. H. Johansson.
        + in Smart Grid Secur. Innov. Solut. a Mod. Grid, Florian Skopik and Paul Smith, Ed. Elsevier Science Publishing Co Inc, 2015, pp. 149–183
        + +
        + + + + + + ABS + + + + + + + + + + + + BIB + + + + + + +
        +
        + In this chapter, we survey cyber security solutions for control and monitoring systems that are used to manage the Smart Grid. We start with a short review of the history and use of Industrial Control Systems (ICSs) and Supervisory Control and Data Acquisition (SCADA) systems, and how cyber security in control systems has recently become a major concern, in the wake of the Stuxnet and other recently discovered malware. We follow up with surveying information technology and control-centric security tools that can be used to improve the resilience of industrial control systems. Feedback control loops are core components in the Smart Grid, as they enable the maximal utilization of the physical infrastructure and its resources. As the number of control loops in the Smart Grid increases, the cyber security challenges faced by ICSs become increasingly important within the Smart Grid’s context. To highlight such novel challenges, we give an overview of the envisioned control loops in future Smart Grids, and discuss the potential impact of cyber threats targeting critical Smart Grid functionalities. As a case study, false-data injection attacks on power transmission networks are considered. The level of resilience to such attacks is assessed through a control-centric risk assessment methodology, which is also used for allocating the deployment of more modern and secure equipment. The chapter ends with a discussion of future research challenges in the area. +
        +
        + + + +
        +
        +
        @incollection{Teixeira_BC2015,
        +  author = {Teixeira, Andr{\'{e}} and Kupzog, Friederich and Sandberg, Henrik and Johansson, Karl H.},
        +  booktitle = {Smart Grid Secur. Innov. Solut. a Mod. Grid},
        +  doi = {10.1016/B978-0-12-802122-4.00006-7},
        +  editor = {{Florian Skopik and Paul Smith}},
        +  isbn = {9780128023549},
        +  keywords = {Industrial Control Systems,Resilient Control,Risk Assessment,Security},
        +  pages = {149--183},
        +  publisher = {Elsevier Science Publishing Co Inc},
        +  title = {Cyber-Secure and Resilient Architectures for Industrial Control Systems},
        +  year = {2015}
        +}
        +
        +
        + + + + + + + +
        + +
      4. +
      5. + + + +
        + + +
        + “Secure Control Systems: A Quantitative Risk Management Approach”.
        + A. Teixeira, K. Sou, H. Sandberg, and K. Johansson.
        + IEEE Control Syst. Mag., vol. 35, no. 1, pp. 24–45, 2015
        + +
        + + + + + + + + + + + + + + + + BIB + + + + + + + + +
        +
        +
        @article{Teixeira_CSM_2015,
        +  author = {Teixeira, A and Sou, K and Sandberg, H and Johansson, K},
        +  doi = {10.1109/MCS.2014.2364709},
        +  journal = {IEEE Control Syst. Mag.},
        +  keywords = {Communication networks;Computer crime;Computer sec},
        +  number = {1},
        +  pages = {24--45},
        +  title = {Secure Control Systems: A Quantitative Risk Management Approach},
        +  volume = {35},
        +  year = {2015}
        +}
        +
        +
        + + + + + + + +
        + +
      6. +
      7. + + + +
        + + +
        + “Strategic stealthy attacks: The output-to-output ℓ2-gain”.
        + A. Teixeira, H. Sandberg, and K. H. Johansson.
        + Proc. IEEE Conf. Decis. Control, Osaka, Japan, 2015, vol. 54rd IEEE, pp. 2582–2587
        + +
        + + + + + + ABS + + + + + + + + + + + + BIB + + + + + + +
        +
        + \textcopyright 2015 IEEE.In this paper, we characterize and analyze the set of strategic stealthy false-data injection attacks on discrete-time linear systems. In particular, the threat scenarios tackled in the paper consider adversaries that aim at deteriorating the system’s performance by maximizing the corresponding quadratic cost function, while remaining stealthy with respect to anomaly detectors. As opposed to other work in the literature, the effect of the adversary’s actions on the anomaly detector’s output is not constrained to be zero at all times. Moreover, scenarios where the adversary has uncertain model knowledge are also addressed. The set of strategic attack policies is formulated as a non-convex constrained optimization problem, leading to a sensitivity metric denoted as the output-to-output ℓ2-gain. Using the framework of dissipative systems, the output-to-output gain is computed through an equivalent convex optimization problem. Additionally, we derive necessary and sufficient conditions for the output-to-output gain to be unbounded, with and without model uncertainties, which are tightly related to the invariant zeros of the system. +
        +
        + + + +
        +
        +
        @inproceedings{Teixeira_CDC2015,
        +  address = {Osaka, Japan},
        +  author = {Teixeira, Andre and Sandberg, Henrik and Johansson, Karl H.},
        +  booktitle = {Proc. IEEE Conf. Decis. Control},
        +  doi = {10.1109/CDC.2015.7402605},
        +  isbn = {9781479978861},
        +  issn = {07431546},
        +  pages = {2582--2587},
        +  title = {Strategic stealthy attacks: The output-to-output ℓ2-gain},
        +  volume = {54rd IEEE},
        +  year = {2015}
        +}
        +
        +
        + + + + + + + +
        + +
      8. +
      9. + + + +
        + + +
        + “Voltage control for interconnected microgrids under adversarial actions”.
        + A. Teixeira, K. Paridari, H. Sandberg, and K. H. K. H. Johansson.
        + 2015 IEEE 20th Conf. Emerg. Technol. Fact. Autom., Luxembourg, 2015, pp. 1–8
        + +
        + + + + + + ABS + + + + + + + + + + + + BIB + + + + + + +
        +
        + \textcopyright 2015 IEEE. In this paper, we study the impact of adversarial actions on voltage control schemes in interconnected microgrids. Each microgrid is abstracted as a power inverter that can be controlled to regulate its voltage magnitude and phase-angle independently. Moreover, each power inverter is modeled as a single integrator, whose input is given by a voltage droop-control policy that is computed based on voltage magnitude and reactive power injection measurements. Under mild assumptions, we then establish important properties of the nominal linearized closed-loop system, such as stability, positivity, and diagonal dominance. These properties play an important role when characterizing the potential impact of different attack scenarios. In particular, we discuss two attack scenarios where the adversary corrupts measurement data and reference signals received by the voltage droop controllers. The potential impact of instances of each scenario is analyzed using control-theoretic tools, which may be used to develop methodologies for identifying high-risk attack scenarios, as is illustrated by numerical examples. +
        +
        + + + +
        +
        +
        @inproceedings{Teixeira_ETFA2015,
        +  address = {Luxembourg},
        +  author = {Teixeira, Andre and Paridari, Kaveh and Sandberg, Henrik and Johansson, K.H. Karl H.},
        +  booktitle = {2015 IEEE 20th Conf. Emerg. Technol. Fact. Autom.},
        +  doi = {10.1109/ETFA.2015.7301476},
        +  isbn = {978-1-4673-7929-8},
        +  issn = {1946-0740},
        +  keywords = {Inverters,Microgrids,Power system dynamics,Power system stability,Stability analysis,Voltage control,Voltage measurement},
        +  month = sep,
        +  pages = {1--8},
        +  title = {Voltage control for interconnected microgrids under adversarial actions},
        +  year = {2015}
        +}
        +
        +
        + + + + + + + +
        + +
      + +

      2014

      +
      1. + + + +
        + + +
        + “A down-sampled controller to reduce network usage with guaranteed closed-loop performance”.
        + J. Araújo, A. Teixeira, E. Henriksson, and K. H. Johansson.
        + IEEE Conf. Decis. Control, Los Angeles, CA, USA, 2014, no. February, pp. 6849–6856
        + +
        + + + + + + ABS + + + + + + + + + + + + BIB + + + + + + +
        +
        + \textcopyright 2014 IEEE.We propose and evaluate a down-sampled controller which reduces the network usage while providing a guaranteed desired linear quadratic control performance. This method is based on fast and slow sampling intervals, as the closed-system benefits by being brought quickly to steady-state conditions while behaving satisfactorily when being actuated at a slow rate once at those conditions. This mechanism is shown to provide large savings with respect to network usage when compared to traditional periodic time-triggered control and other aperiodic controllers proposed in the literature. +
        +
        + + + +
        +
        +
        @inproceedings{Araujo_CDC2014,
        +  address = {Los Angeles, CA, USA},
        +  author = {Ara{\'{u}}jo, Jos{\'{e}} and Teixeira, Andre and Henriksson, Erik and Johansson, Karl H.},
        +  booktitle = {IEEE Conf. Decis. Control},
        +  doi = {10.1109/CDC.2014.7040465},
        +  isbn = {9781467360883},
        +  issn = {07431546},
        +  number = {February},
        +  pages = {6849--6856},
        +  title = {A down-sampled controller to reduce network usage with guaranteed closed-loop performance},
        +  year = {2014}
        +}
        +
        +
        + + + + + + + +
        + +
      2. +
      3. + + + +
        + + +
        + “Distributed Fault Detection and Isolation Resilient to Network Model Uncertainties”.
        + A. Teixeira, I. Shames, H. Sandberg, and K. H. Johansson.
        + IEEE Trans. Cybern., vol. 44, no. 11, pp. 2024–2037, 2014
        + +
        + + + + + + + + + + + + + + + + BIB + + + + + + + + +
        +
        +
        @article{Teixeira_Cyb_2014,
        +  author = {Teixeira, A and Shames, I and Sandberg, H and Johansson, K H},
        +  doi = {10.1109/TCYB.2014.2350335},
        +  journal = {IEEE Trans. Cybern.},
        +  number = {11},
        +  pages = {2024--2037},
        +  title = {Distributed Fault Detection and Isolation Resilient to Network Model Uncertainties},
        +  volume = {44},
        +  year = {2014}
        +}
        +
        +
        + + + + + + + +
        + +
      4. +
      5. + + + +
        + + +
        + “Gaussian cheap talk game with quadratic cost functions: When herding between strategic senders is a virtue”.
        + F. Farokhi, A. M. H. Teixeira, and C. Langbort.
        + Am. Control Conf., Portland, OR, USA, 2014, pp. 2267–2272
        + +
        + + + + + + + + + + + + + + + + BIB + + + + + + + + +
        +
        +
        @inproceedings{Farokhi_ACC2014,
        +  address = {Portland, OR, USA},
        +  author = {Farokhi, F and Teixeira, A M H and Langbort, C},
        +  booktitle = {Am. Control Conf.},
        +  doi = {10.1109/ACC.2014.6859123},
        +  month = jun,
        +  pages = {2267--2272},
        +  title = {Gaussian cheap talk game with quadratic cost functions: When herding between strategic senders is a virtue},
        +  year = {2014}
        +}
        +
        +
        + + + + + + + +
        + +
      6. +
      7. + + + +
        + + +
        + “Security of smart distribution grids: Data integrity attacks on integrated volt/VAR control and countermeasures”.
        + A. Teixeira, G. Dán, H. Sandberg, R. Berthier, R. B. Bobba, and A. Valdes.
        + Am. Control Conf., Portland, OR, USA, 2014, pp. 4372–4378
        + +
        + + + + + + + + + + + + + + + + BIB + + + + + + + + +
        +
        +
        @inproceedings{Teixeira_ACC2014,
        +  address = {Portland, OR, USA},
        +  author = {Teixeira, A and D{\'{a}}n, G and Sandberg, H and Berthier, R and Bobba, R B and Valdes, A},
        +  booktitle = {Am. Control Conf.},
        +  doi = {10.1109/ACC.2014.6859265},
        +  month = jun,
        +  pages = {4372--4378},
        +  title = {Security of smart distribution grids: Data integrity attacks on integrated volt/{VAR} control and countermeasures},
        +  year = {2014}
        +}
        +
        +
        + + + + + + + +
        + +
      8. +
      9. + + + +
        + + +
        + “Toward Cyber-Secure and Resilient Networked Control Systems”.
        + A. M. H. Teixeira.
        + PhD thesis, KTH Royal Institute of Technology, Stockholm, Sweden, 2014
        + +
        + + + + + + + + + + + + + + + + BIB + + + + + + + + +
        +
        +
        @phdthesis{Teixeira_PhD2014,
        +  author = {Teixeira, Andr\'{e} M. H.},
        +  title = {Toward Cyber-Secure and Resilient Networked Control Systems},
        +  school = {KTH Royal Institute of Technology},
        +  year = {2014},
        +  address = {Stockholm, Sweden},
        +  month = nov
        +}
        +
        +
        + + + + + + + +
        + +
      + +

      2013

      +
      1. + + + +
        + + +
        + “Distributed actuator reconfiguration in networked control systems”.
        + A. Teixeira, J. Araújo, H. Sandberg, and K. H. Johansson.
        + 4th IFAC Work. Distrib. Estim. Control Networked Syst., Koblenz, Germany, 2013
        + +
        + + + + + + + + + + + + + + + + BIB + + + + + + + + +
        +
        +
        @inproceedings{teixeirarecon13,
        +  address = {Koblenz, Germany},
        +  author = {Teixeira, A and Ara{\'{u}}jo, J and Sandberg, H and Johansson, K H},
        +  booktitle = {4th {IFAC} Work. Distrib. Estim. Control Networked Syst.},
        +  month = sep,
        +  title = {Distributed actuator reconfiguration in networked control systems},
        +  year = {2013}
        +}
        +
        +
        + + + + + + + +
        + +
      2. +
      3. + + + +
        + + +
        + “Quantifying Cyber-Security for Networked Control Systems”.
        + A. Teixeira, K. C. Sou, H. Sandberg, and K. H. Johansson.
        + in Control Cyber-Physical Syst., no. 449, D. C. Tarraf, Ed. Springer International Publishing, 2013, pp. 123–142
        + +
        + + + + + + + + + + + + + + + + BIB + + + + + + + + +
        +
        +
        @incollection{Teixeira_Springer2013,
        +  author = {Teixeira, A and Sou, K C and Sandberg, H and Johansson, K H},
        +  booktitle = {Control Cyber-Physical Syst.},
        +  editor = {Tarraf, Danielle C},
        +  number = {449},
        +  pages = {123--142},
        +  publisher = {Springer International Publishing},
        +  series = {Lecture Notes in Control and Information Sciences},
        +  title = {Quantifying Cyber-Security for Networked Control Systems},
        +  year = {2013}
        +}
        +
        +
        + + + + + + + +
        + +
      + +

      2012

      +
      1. + + + +
        + + +
        + “Agents Misbehaving in a Network: a Vice or a Virtue?”.
        + I. Shames, A. M. H. Teixeira, H. Sandberg, and K. H. H. Johansson.
        + IEEE Netw. Mag., vol. 26, no. 3, pp. 35–40, 2012
        + +
        + + + + + + ABS + + + + + + + + + + + + BIB + + + + + + +
        +
        + Misbehaviors among the agents in a network might be intentional or unintentional, they might cause a system-wide failure or they might improve the performance or even enable us to achieve an objective. In this article we consider examples of these possible scenarios. First, we argue the necessity of monitoring the agents in a network to detect if they are misbehaving or not and outline a distributed method in which each agent monitors its neighbors for any sign of misbehavior. Later, we focus on solving the problem of distributed leader selection via forcing the agents to temporarily misbehave, and introduce an algorithm that enables the agents in a network to select their leader without any interference from the outside of the network. \textcopyright 2012 IEEE. +
        +
        + + + +
        +
        +
        @article{Shames_NM2012,
        +  author = {Shames, I. and Teixeira, A.M.H. and Sandberg, H. and Johansson, K.H. H},
        +  doi = {10.1109/MNET.2012.6201214},
        +  issn = {08908044},
        +  journal = {{IEEE} Netw. Mag.},
        +  number = {3},
        +  pages = {35--40},
        +  title = {Agents Misbehaving in a Network: a Vice or a Virtue?},
        +  volume = {26},
        +  year = {2012}
        +}
        +
        +
        + + + + + + + +
        + +
      2. +
      3. + + + +
        + + +
        + “Attack models and scenarios for networked control systems”.
        + A. Teixeira, D. Pérez, H. Sandberg, and K. H. Johansson.
        + Proc. 1st Int. Conf. High Confid. Networked Syst. - HiCoNS ’12, Beijing, China, 2012, pp. 55–64
        + +
        + + + + + + ABS + + + + + + + + + + + + BIB + + + + + + +
        +
        + Cyber-secure networked control is modeled, analyzed, and experimentally illustrated in this paper. An attack space defined by the adversary’s system knowledge, disclosure, and disruption resources is introduced. Adversaries constrained by these resources are modeled for a networked control system architecture. It is shown that attack scenarios corresponding to replay, zero dynamics, and bias injection attacks can be analyzed using this framework. An experimental setup based on a quadruple-tank process controlled over a wireless network is used to illustrate the attack scenarios, their consequences, and potential counter-measures. +
        +
        + + + +
        +
        +
        @inproceedings{kn:Teixeira_HICONS2012,
        +  address = {Beijing, China},
        +  author = {Teixeira, Andr{\'{e}} and P{\'{e}}rez, Daniel and Sandberg, Henrik and Johansson, Karl Henrik},
        +  booktitle = {Proc. 1st Int. Conf. High Confid. Networked Syst. - HiCoNS '12},
        +  doi = {10.1145/2185505.2185515},
        +  isbn = {9781450312639},
        +  issn = {00375675},
        +  pages = {55--64},
        +  title = {Attack models and scenarios for networked control systems},
        +  year = {2012}
        +}
        +
        +
        + + + + + + + +
        + +
      4. +
      5. + + + +
        + + +
        + “Cyber-security of SCADA systems”.
        + G. Andersson et al.
        + IEEE PES Innov. Smart Grid Technol., Washington, DC, USA, 2012, pp. 1–2
        + +
        + + + + + + + + + + + + + + + + BIB + + + + + + + + +
        +
        +
        @inproceedings{Andersson_2012,
        +  address = {Washington, DC, USA},
        +  author = {Andersson, G and Esfahani, P M and Vrakopoulou, M and Margellos, K and Lygeros, J and Teixeira, A and Dan, G and Sandberg, H and Johansson, K H},
        +  booktitle = {IEEE PES Innov. Smart Grid Technol.},
        +  doi = {10.1109/ISGT.2012.6175543},
        +  pages = {1--2},
        +  title = {Cyber-security of SCADA systems},
        +  year = {2012}
        +}
        +
        +
        + + + + + + + +
        + +
      6. +
      7. + + + +
        + + +
        + “Distributed Fault Detection and Isolation with Imprecise Network Models”.
        + I. Shames, A. Teixeira, H. Sandberg, and K. H. Johansson.
        + Am. Control Conf., Montreal, Canada, 2012
        + +
        + + + + + + + + + + + + + + + + BIB + + + + + + + + +
        +
        +
        @inproceedings{kn:Shames2012_ACC,
        +  address = {Montreal, Canada},
        +  author = {Shames, I and Teixeira, A and Sandberg, H and Johansson, K H},
        +  booktitle = {Am. Control Conf.},
        +  month = jun,
        +  title = {Distributed Fault Detection and Isolation with Imprecise Network Models},
        +  year = {2012}
        +}
        +
        +
        + + + + + + + +
        + +
      8. +
      9. + + + +
        + + +
        + “Fault Detection and Mitigation in Kirchhoff Networks”.
        + I. Shames, A. M. H. Teixeira, H. Sandberg, and K. H. Johansson.
        + IEEE Signal Process. Lett., vol. 19, no. 11, pp. 749–752, Nov. 2012
        + +
        + + + + + + + + + + + + + + + + BIB + + + + + + + + +
        +
        +
        @article{Shames_SPL2012,
        +  author = {Shames, I and Teixeira, A M H and Sandberg, H and Johansson, K H},
        +  doi = {10.1109/LSP.2012.2217328},
        +  journal = {{IEEE} Signal Process. Lett.},
        +  month = nov,
        +  number = {11},
        +  pages = {749--752},
        +  title = {Fault Detection and Mitigation in Kirchhoff Networks},
        +  volume = {19},
        +  year = {2012}
        +}
        +
        +
        + + + + + + + +
        + +
      10. +
      11. + + + +
        + + +
        + “Optimal power flow: closing the loop over corrupted data”.
        + A. Teixeira, H. Sandberg, G. Dán, and K. H. Johansson.
        + Am. Control Conf., Montreal, Canada, 2012
        + +
        + + + + + + + + + + + + + + + + BIB + + + + + + + + +
        +
        +
        @inproceedings{kn:Teixeira_ACC2012,
        +  address = {Montreal, Canada},
        +  author = {Teixeira, A and Sandberg, H and D{\'{a}}n, G and Johansson, K H},
        +  booktitle = {Am. Control Conf.},
        +  title = {Optimal power flow: closing the loop over corrupted data},
        +  year = {2012}
        +}
        +
        +
        + + + + + + + +
        + +
      12. +
      13. + + + +
        + + +
        + “Revealing Stealthy Attacks in Control Systems”.
        + A. Teixeira, I. Shames, H. Sandberg, and K. H. H. Johansson.
        + 50th Annu. Allert. Conf. Commun. Control. Comput., Monticello, IL, USA, 2012
        + +
        + + + + + + ABS + + + + + + + + + + + + BIB + + + + + + +
        +
        + In this paper the problem of revealing stealthy data-injection attacks on control systems is addressed. In particular we consider the scenario where the attacker performs zero-dynamics attacks on the system. First, we characterize and analyze the stealthiness properties of these attacks for linear time-invariant systems. Then we tackle the problem of detecting such attacks by modifying the system’s structure. Our results provide necessary and sufficient conditions that the modifications should satisfy in order to detect the zero-dynamics attacks. The results and proposed detection methods are illustrated through numerical examples. \textcopyright 2012 IEEE. +
        +
        + + + +
        +
        +
        @inproceedings{Teixeira_Allerton2012,
        +  address = {Monticello, IL, USA},
        +  author = {Teixeira, A. and Shames, I. and Sandberg, H. and Johansson, K.H. H},
        +  booktitle = {50th Annu. Allert. Conf. Commun. Control. Comput.},
        +  doi = {10.1109/Allerton.2012.6483441},
        +  isbn = {9781467345385},
        +  title = {Revealing Stealthy Attacks in Control Systems},
        +  year = {2012}
        +}
        +
        +
        + + + + + + + +
        + +
      + +

      2011

      +
      1. + + + +
        + + +
        + “Cyber security study of a SCADA energy management system: stealthy deception attacks on the state estimator”.
        + A. Teixeira, G. Dán, H. Sandberg, and K. H. Johansson.
        + 18th IFAC World Congr., Milano, Italy, 2011
        + +
        + + + + + + + + + + + + + + + + BIB + + + + + + + + +
        +
        +
        @inproceedings{kn:Teixeira2011,
        +  address = {Milano, Italy},
        +  author = {Teixeira, A and D{\'{a}}n, G and Sandberg, H and Johansson, K H},
        +  booktitle = {18th {IFAC} World Congr.},
        +  title = {Cyber security study of a {SCADA} energy management system: stealthy deception attacks on the state estimator},
        +  year = {2011}
        +}
        +
        +
        + + + + + + + +
        + +
      2. +
      3. + + + +
        + + +
        + “Distributed Fault Detection for Interconnected Second-Order Systems”.
        + I. Shames, A. M. H. Teixeira, H. Sandberg, and K. H. Johansson.
        + Automatica, vol. 47, no. 12, pp. 2757–2764, 2011
        + +
        + + + + + + ABS + + + + + + + + + + + + BIB + + + + + + +
        +
        + In this paper, the existence of unknown input observers for networks of interconnected second-order linear time invariant systems is studied. Two classes of distributed control systems of large practical relevance are considered. It is proved that for these systems, one can construct a bank of unknown input observers, and use them to detect and isolate faults in the network. The result presents a distributed implementation. In particular, by exploiting the system structure, this work provides further insight into the design of UIO for networked systems. Moreover, the importance of certain network measurements is shown. Infeasibility results with respect to available measurements and faults are also provided, as well as methods to remove faulty agents from the network. Applications to power networks and robotic formations are presented. It is shown how the developed methodology apply to a power network described by the swing equation with a faulty bus. For a multi-robot system, it is illustrated how a faulty robot can be detected and removed. \textcopyright 2011 Elsevier Ltd. All rights reserved. +
        +
        + + + +
        +
        +
        @article{Shamesetal-automatica-11,
        +  author = {Shames, I. and Teixeira, A.M.H. and Sandberg, H. and Johansson, K.H.},
        +  doi = {10.1016/j.automatica.2011.09.011},
        +  issn = {00051098},
        +  journal = {Automatica},
        +  keywords = {Distributed algorithm,Distributed detection,Fault detection and isolation},
        +  number = {12},
        +  pages = {2757--2764},
        +  title = {Distributed Fault Detection for Interconnected Second-Order Systems},
        +  volume = {47},
        +  year = {2011}
        +}
        +
        +
        + + + + + + + +
        + +
      + +

      2010

      +
      1. + + + +
        + + +
        + “Cyber Security Analysis of State Estimators in Electric Power Systems”.
        + A. Teixeira, S. Amin, H. Sandberg, K. H. H. Johansson, and S. S. S. Sastry.
        + 49th IEEE Conf. Decis. Control, Atlanta, GA, USA, 2010
        + +
        + + + + + + ABS + + + + + + + + + + + + BIB + + + + + + +
        +
        + In this paper, we analyze the cyber security of state estimators in Supervisory Control and Data Acquisition (SCADA) systems operating in power grids. Safe and reliable operation of these critical infrastructure systems is a major concern in our society. In current state estimation algorithms there are bad data detection (BDD) schemes to detect random outliers in the measurement data. Such schemes are based on high measurement redundancy. Although such methods may detect a set of very basic cyber attacks, they may fail in the presence of a more intelligent attacker. We explore the latter by considering scenarios where deception attacks are performed, sending false information to the control center. Similar attacks have been studied before for linear state estimators, assuming the attacker has perfect model knowledge. Here we instead assume the attacker only possesses a perturbed model. Such a model may correspond to a partial model of the true system, or even an out-dated model. We characterize the attacker by a set of objectives, and propose policies to synthesize stealthy deceptions attacks, both in the case of linear and nonlinear estimators. We show that the more accurate model the attacker has access to, the larger deception attack he can perform undetected. Specifically, we quantify trade-offs between model accuracy and possible attack impact for different BDD schemes. The developed tools can be used to further strengthen and protect the critical state-estimation component in SCADA systems. \textcopyright2010 IEEE. +
        +
        + + + +
        +
        +
        @inproceedings{kn:Teixeira10,
        +  address = {Atlanta, GA, USA},
        +  author = {Teixeira, A. and Amin, S. and Sandberg, H. and Johansson, K.H. H and Sastry, S.S. S},
        +  booktitle = {49th {IEEE} Conf. Decis. Control},
        +  doi = {10.1109/CDC.2010.5717318},
        +  isbn = {9781424477456},
        +  issn = {01912216},
        +  month = dec,
        +  title = {Cyber Security Analysis of State Estimators in Electric Power Systems},
        +  year = {2010}
        +}
        +
        +
        + + + + + + + +
        + +
      2. +
      3. + + + +
        + + +
        + “Distributed Fault Detection for Interconnected Second-Order Systems with Applications to Power Networks”.
        + I. Shames, A. M. H. Teixeira, H. Sandberg, and K. H. Johansson.
        + First Work. Secur. Control Syst. CPSWeek, Stockholm, Sweden, 2010
        + +
        + + + + + + + + + + + + + + + + BIB + + + + + + + + +
        +
        +
        @inproceedings{Shamesetal_SCS_10,
        +  address = {Stockholm, Sweden},
        +  author = {Shames, I and Teixeira, A M H and Sandberg, H and Johansson, K H},
        +  booktitle = {First Work. Secur. Control Syst. CPSWeek},
        +  month = apr,
        +  title = {Distributed Fault Detection for Interconnected Second-Order Systems with Applications to Power Networks},
        +  year = {2010}
        +}
        +
        +
        + + + + + + + +
        + +
      4. +
      5. + + + +
        + + +
        + “Networked control systems under cyber attacks with applications to power networks”.
        + A. Teixeira, H. Sandberg, and K. H. Johansson.
        + Am. Control Conf., Baltimore, MD, 2010, pp. 3690–3696
        + +
        + + + + + + + + + + + + + + + + BIB + + + + + + + + +
        +
        +
        @inproceedings{Teixeira_ACC2010,
        +  address = {Baltimore, MD},
        +  author = {Teixeira, Andre and Sandberg, H and Johansson, K H},
        +  booktitle = {Am. Control Conf.},
        +  doi = {10.1109/ACC.2010.5530638},
        +  isbn = {978-1-4244-7427-1},
        +  month = jun,
        +  pages = {3690--3696},
        +  title = {Networked control systems under cyber attacks with applications to power networks},
        +  year = {2010}
        +}
        +
        +
        + + + + + + + +
        + +
      6. +
      7. + + + +
        + + +
        + “On security indices for state estimators in power networks”.
        + H. Sandberg, A. Teixeira, and K. H. Johansson.
        + First Work. Secur. Control Syst. CPSWeek, Stockholm, Sweden, 2010
        + +
        + + + + + + + + + + + + + + + + BIB + + + + + + + + +
        +
        +
        @inproceedings{kn:Sandberg10,
        +  address = {Stockholm, Sweden},
        +  author = {Sandberg, H and Teixeira, A and Johansson, K H},
        +  booktitle = {First Work. Secur. Control Syst. CPSWeek},
        +  month = apr,
        +  title = {On security indices for state estimators in power networks},
        +  year = {2010}
        +}
        +
        +
        + + + + + + + +
        + +
      + +
      + +
      + +
      +
      + + + + + + + + + + diff --git a/research/index.html b/research/index.html new file mode 100644 index 00000000..3dd1937c --- /dev/null +++ b/research/index.html @@ -0,0 +1,2032 @@ + + + + + + + + Secure Learning and Control Lab - Research + + + + + + + + + + + + + + + + + + +
      +
      +
      +

      Our Research

      +

      + +

      Our vision is to develop methodologies for designing intelligent autonomous decision-making systems that are secure and resilient against malicious adversaries and natural failures.

      + +

      To do so, we look into these sytems from a security perspective, under various adversary models. Specifically, we develop techniques to assess the risk (i.e., impact and likelihood) of adversaries and failures, and propose methodologies to design and systematically deploy defense measures to prevent, detect, and mitigate malicious attacks and natural disruptive events. In our research, we combine methodologies from cybersecurity, control theory, optimization and machine learning, game-theory and networked systems.

      + +

      Have a look at a popular science video about our research on developing secure control systems. You can also find some of our recent research themes described at the end of this page.

      + + + + +
      + +
      + +

      Selected research themes

      + +
      + +
      +
      + +

      + +

      Security metrics for control systems

      +

      The aim within this theme is to to create novel methodologies addressing cybersecurity problems under uncertainty in learning and control systems. A core element of this research is the development of novel probabilistic risk metrics and optimization-based design methods that jointly consider the impact and the detectability constraints of attacks, as well as model uncertainty and prior beliefs on the adversary model.

      +

      Team members: Sribalaji C. Anand, Anh Tung Nguyen, André M. H. Teixeira

      +

      +

      +

      +
      +
      +
      +
      1. + + + +
        + + +
        + “Risk Assessment of Stealthy Attacks on Uncertain Control Systems”.
        + S. C. Anand, A. M. H. Teixeira, and A. Ahlén.
        + IEEE Trans. Automatic Control (Accepted), 2023
        + +
        + + + + + + ABS + + + + + + + + + + + + BIB + + + + + + +
        +
        + In this article, we address the problem of risk assessment of stealthy attacks on uncertain control systems. Considering data injection attacks that aim at maximizing impact while remaining undetected, we use the recently proposed output-to-output gain to characterize the risk associated with the impact of attacks under a limited system knowledge attacker. The risk is formulated using a well-established risk metric, namely the maximum expected loss. Under this setups, the risk assessment problem corresponds to an untractable infinite non-convex optimization problem. To address this limitation, we adopt the framework of scenario-based optimization to approximate the infinite non-convex optimization problem by a sampled non-convex optimization problem. Then, based on the framework of dissipative system theory and S-procedure, the sampled non-convex risk assessment problem is formulated as an equivalent convex semi-definite program. Additionally, we derive the necessary and sufficient conditions for the risk to be bounded. Finally, we illustrate the results through numerical simulation of a hydro-turbine power system. +
        +
        + + + +
        +
        +
        @article{Anand_TAC2024,
        +  author = {Anand, S. C. and Teixeira, A. M. H. and Ahl\'{e}n, A.},
        +  journal = {IEEE Trans. Automatic Control (Accepted)},
        +  number = {},
        +  pages = {},
        +  title = {Risk Assessment of Stealthy Attacks on Uncertain Control Systems},
        +  volume = {},
        +  year = {2023},
        +  doi = {10.1109/TAC.2023.3318194},
        +  published = {1},
        +  tag = {10001}
        +}
        +
        +
        + + + + + + + +
        + +
      2. +
      3. + + + +
        + + +
        + “Risk-based Security Measure Allocation Against Actuator Attacks”.
        + S. C. Anand and A. M. H. Teixeira.
        + IEEE Open Journal of Control Systems, vol. 2, pp. 297–309, 2023
        + +
        + + + + + + ABS + + + + + + + + + + + + BIB + + + + + + +
        +
        + This article considers the problem of risk-optimal allocation of security measures when the actuators of an uncertain control system are under attack. We consider an adversary injecting false data into the actuator channels. The attack impact is characterized by the maximum performance loss caused by a stealthy adversary with bounded energy. Since the impact is a random variable, due to system uncertainty, we use Conditional Value-at-Risk (CVaR) to characterize the risk associated with the attack. We then consider the problem of allocating the security measures which minimize the risk. We assume that there are only a limited number of security measures available. Under this constraint, we observe that the allocation problem is a mixed-integer optimization problem. Thus we use relaxation techniques to approximate the security allocation problem into a Semi-Definite Program (SDP). We also compare our allocation method (i) across different risk measures: the worst-case measure, the average (nominal) measure, and (ii) across different search algorithms: the exhaustive and the greedy search algorithms. We depict the efficacy of our approach through numerical examples. +
        +
        + + + +
        +
        +
        @article{Anand_IEEEOJCSys2023,
        +  author = {Anand, S. C. and Teixeira, A. M. H.},
        +  journal = {IEEE Open Journal of Control Systems},
        +  number = {},
        +  pages = {297--309},
        +  title = {Risk-based Security Measure Allocation Against Actuator Attacks},
        +  volume = {2},
        +  year = {2023},
        +  doi = {10.1109/OJCSYS.2023.3305831},
        +  published = {1},
        +  tag = {10001}
        +}
        +
        +
        + + + + + + + +
        + +
      4. +
      5. + + + +
        + + +
        + “Risk assessment and optimal allocation of security measures under stealthy false data injection attacks”.
        + S. C. Anand, A. M. H. Teixeira, and A. Ahlén.
        + IEEE Conference on Control Technology and Applications (CCTA), 2022
        + +
        + + + + + + ABS + + + + + + + + + + + + BIB + + + + + + +
        +
        + This paper firstly addresses the problem of risk assessment under false data injection attacks on uncertain control systems. We consider an adversary with complete system knowledge, injecting stealthy false data into an uncertain control system. We then use the Value-at-Risk to characterize the risk associated with the attack impact caused by the adversary. The worst-case attack impact is characterized by the recently proposed output-to-output gain. We observe that the risk assessment problem corresponds to an infinite non-convex robust optimization problem. To this end, we use dissipative system theory and the scenario approach to approximate the risk-assessment problem into a convex problem and also provide probabilistic certificates on approximation. Secondly, we con-sider the problem of security measure allocation. We consider an operator with a constraint on the security budget. Under this constraint, we propose an algorithm to optimally allocate the security measures using the calculated risk such that the resulting Value-at-risk is minimized. Finally, we illustrate the results through a numerical example. The numerical example also illustrates that the security allocation using the Value-at-risk, and the impact on the nominal system may have different outcomes: thereby depicting the benefit of using risk metrics. +
        +
        + + + +
        +
        +
        @inproceedings{AnandCCTA2022,
        +  address = {},
        +  author = {Anand, S. C. and Teixeira, A. M. H. and Ahl\'{e}n, A.},
        +  booktitle = {IEEE Conference on Control Technology and Applications (CCTA)},
        +  title = {Risk assessment and optimal allocation of security measures under stealthy false data injection attacks},
        +  year = {2022},
        +  tag = {10001},
        +  doi = {10.1109/CCTA49430.2022.9966025},
        +}
        +
        +
        + + + + + + + +
        + +
      6. +
      7. + + + +
        + + +
        + “Risk-averse controller design against data injection attacks on actuators for uncertain control systems”.
        + S. C. Anand and A. M. H. Teixeira.
        + American Control Conference, Atlanta, Georgia, USA, 2022
        + +
        + + + + + + ABS + + + + + + + + + + + + BIB + + + + + + +
        +
        + In this paper, we consider the optimal controller design problem against data injection attacks on actuators for an uncertain control system. We consider attacks that aim at maximizing the attack impact while remaining stealthy in the finite horizon. To this end, we use the Conditional Value-at-Risk to characterize the risk associated with the impact of attacks. The worst-case attack impact is characterized using the recently proposed output-to-output ℓ 2 -gain (OOG). We formulate the design problem and observe that it is non-convex and hard to solve. Using the framework of scenario-based optimization and a convex proxy for the OOG, we propose a convex optimization problem that approximately solves the design problem with probabilistic certificates. Finally, we illustrate the results through a numerical example. +
        +
        + + + +
        +
        +
        @inproceedings{Anand_ACC2022,
        +  address = {Atlanta, Georgia, USA},
        +  author = {Anand, S. C. and Teixeira, A. M. H.},
        +  booktitle = {American Control Conference},
        +  title = {Risk-averse controller design against data injection attacks on actuators for uncertain control systems},
        +  year = {2022},
        +  doi = {10.23919/ACC53348.2022.9867257},
        +  tag = {10001},
        +}
        +
        +
        + + + + + + + +
        + +
      8. +
      9. + + + +
        + + +
        + “Security Metrics for Control Systems”.
        + A. M. H. Teixeira.
        + in Safety, Security and Privacy for Cyber-Physical Systems, R. M. G. Ferrari and A. M. H. Teixeira, Eds. Cham: Springer International Publishing, 2021, pp. 1–8
        + +
        + + + + + + + + + + + + + + + + BIB + + + + + + + + +
        +
        +
        @incollection{Teixeira_Springer2021,
        +  author = {Teixeira, Andr{\'e} M. H.},
        +  editor = {Ferrari, Riccardo M.G. and Teixeira, Andr{\'e} M. H.},
        +  title = {Security Metrics for Control Systems},
        +  booktitle = {Safety, Security and Privacy for Cyber-Physical Systems},
        +  year = {2021},
        +  publisher = {Springer International Publishing},
        +  address = {Cham},
        +  pages = {1--8},
        +  isbn = {978-3-030-65048-3},
        +  doi = {10.1007/978-3-030-65048-3_6},
        +  tag = {10001}
        +}
        +
        +
        + + + + + + + +
        + +
      + +
      +
      +
      +
      +
      + +
      +
      + +

      + +

      Secure Federated Machine Learning

      +

      Federated machine learning (FedML) has proven to be a suitable approach for privacy-preserving machine learning across a large number of heterogeneous devices. Our group addresses concerns related to security and privacy in federated machine learning against model poisoning and information leakage attacks. The approach is centered around developing new theories and methodologies to achieve two main aims: secure aggregation of local models under poisoning attacks; private distributed aggregation of local models.

      +

      Team members: Usama Zafar, Salman Toor, André M. H. Teixeira

      +

      +

      +

      +
      +
      +
      + +
      1. + + + +
        + + +
        + “Accelerating Fair Federated Learning: Adaptive Federated Adam”.
        + L. Ju, T. Zhang, S. Toor, and A. Hellander.
        + (Submitted, 2023)
        + +
        + + + + + + ABS + + + + + + + + + + + + BIB + + + + + + +
        +
        + Federated learning is a distributed and privacy-preserving approach to train a statistical model collaboratively from decentralized data of different parties. However, when datasets of participants are not independent and identically distributed (non-IID), models trained by naive federated algorithms may be biased towards certain participants, and model performance across participants is non-uniform. This is known as the fairness problem in federated learning. In this paper, we formulate fairness-controlled federated learning as a dynamical multi-objective optimization problem to ensure fair performance across all participants. To solve the problem efficiently, we study the convergence and bias of Adam as the server optimizer in federated learning, and propose Adaptive Federated Adam (AdaFedAdam) to accelerate fair federated learning with alleviated bias. We validated the effectiveness, Pareto optimality and robustness of AdaFedAdam in numerical experiments and show that AdaFedAdam outperforms existing algorithms, providing better convergence and fairness properties of the federated scheme. +
        +
        + + + +
        +
        +
        @inproceedings{Ju2023,
        +  address = {},
        +  author = {Ju, L. and Zhang, T. and Toor, S. and Hellander, A.},
        +  booktitle = {(Submitted, 2023)},
        +  title = {Accelerating Fair Federated Learning: Adaptive Federated Adam},
        +  published = {0},
        +  tag = {10003}
        +}
        +
        +
        + + + + + + + +
        + +
      2. +
      3. + + + +
        + + +
        + “Scalable federated machine learning with FEDn”.
        + M. Ekmefjord et al.
        + Symposium on Cluster, Cloud and Internet Computing, Taormina, Italy, 2022
        + +
        + + + + + + ABS + + + + + + + + + + + + BIB + + + + + + +
        +
        + Federated machine learning promises to overcome the input privacy challenge in machine learning. By iteratively updating a model on private clients and aggregating these local model updates into a global federated model, private data is incorporated in the federated model without needing to share and expose that data. Several open software projects for federated learning have appeared. Most of them focuses on supporting flexible experimentation with different model aggregation schemes and with different privacy-enhancing technologies. However, there is a lack of open frameworks that focuses on critical distributed computing aspects of the problem such as scalability and resilience. It is a big step to take for a data scientist to go from an experimental sandbox to testing their federated schemes at scale in real-world geographically distributed settings. To bridge this gap we have designed and developed a production-grade hierarchical federated learning framework, FEDn. The framework is specifically designed to make it easy to go from local development in pseudo-distributed mode to horizontally scalable distributed deployments. FEDn both aims to be production grade for industrial applications and a flexible research tool to explore real-world performance of novel federated algorithms and the framework has been used in number of industrial and academic R&D projects. In this paper we present the architecture and implementation of FEDn. We demonstrate the framework’s scalability and efficiency in evaluations based on two case-studies representative for a cross-silo and a cross-device use-case respectively. +
        +
        + + + +
        +
        +
        @inproceedings{Ekmefjord_CCGrid2022,
        +  address = {Taormina, Italy},
        +  author = {Ekmefjord, M. and Ait-Mlouk, A. and Alawadi, S. and Åkesson, M. and Singh, P. and Spjuth, O. and Toor, S. and Hellander, A.},
        +  booktitle = {Symposium on Cluster, Cloud and Internet Computing},
        +  title = {Scalable federated machine learning with FEDn},
        +  year = {2022},
        +  doi = {10.1109/CCGrid54584.2022.00065},
        +  tag = {10003},
        +}
        +
        +
        + + + + + + + +
        + +
      + +
      +
      +
      +
      +
      + +
      + +
      + +
      +
      + +

      + +

      Secure artificial pancreas

      +

      Artificial pancreas are envisioned medical systems whose function is to automatically regulate the blood glucose levels in patients with diabetes, with little to none human initervention. At the core of these systems we have an intellligent device autonomously deciding how much synthetic insulin and glucagon to infuse into the body through infusion pumps, based on data received from sensors located thoughout the body measuring, for instance, blood glucose levels in real-time. Data exchange among the controlling device, the pumps, and the sensors is critical. The whole system must operate safely, even in the presence of adversaries tampering with the communication or devices.

      + +

      In this line of research, we develop schemes to monitor the sensor reading to detect anomalies, and distinguish them from natural unknown disturbances, such as meal intakes, physical exercise, among others.

      +

      Team members: Fatih Emre Tosun, André M. H. Teixeira

      +

      +

      +

      +
      +
      +
      +
      1. + + + +
        + + +
        + “Kullback-Leibler Divergence-Based Detector Design Against Bias Injection Attacks in an Artificial Pancreas System”.
        + F. E. Tosun, A. M. H. Teixeira, A. Ahlén, and S. Dey.
        + 12th IFAC Symposium on Fault Detection, Supervision and Safety for Technical Processes (Accepted), 2024
        + +
        + + + + + + ABS + + + + + + + + + + + + BIB + + + + + + +
        +
        + This paper considers constant bias injection attacks on the glucose sensor deployed in an artificial pancreas system that has an integrator. The main challenge with such apparently simple attacks is that, if the system is linear and has an integrator, they are only detectable for a limited duration. More formally, they are steady-state stealthy attacks. To address this issue, we propose a residual generation method to increase the detectability of these attacks based on the Kullback–Leibler divergence metric. Illustrative examples with numerical simulations are provided to demonstrate the effectiveness of the proposed method. +
        +
        + + + +
        +
        +
        @inproceedings{Tosun_SP024,
        +  author = {Tosun, F. E. and Teixeira, A. M. H. and Ahlén, A. and Dey, S.},
        +  booktitle = {12th IFAC Symposium on Fault Detection, Supervision and Safety for Technical Processes (Accepted)},
        +  title = {Kullback-Leibler Divergence-Based Detector Design Against Bias Injection Attacks in an Artificial Pancreas System},
        +  year = {2024},
        +  published = {1},
        +  tag = {10002}
        +}
        +
        +
        + + + + + + + +
        + +
      2. +
      3. + + + +
        + + +
        + “Quickest Detection of Bias Injection Attacks on the Glucose Sensor in the Artificial Pancreas Under Meal Disturbances”.
        + F. E. Tosun, A. M. H. Teixeira, M. Abdalmoaty, A. Ahlén, and S. Dey.
        + Journal of Process Control, vol. 153, no. 103162, 2024
        + +
        + + + + + + ABS + + + + + + + + + + + + BIB + + + + + + +
        +
        + Modern glucose sensors deployed in closed-loop insulin delivery systems, so-called artificial pancreas use wireless communication channels. While this allows a flexible system design, it also introduces vulnerability to cyberattacks. Timely detection and mitigation of attacks are imperative for device safety. However, large unknown meal disturbances are a crucial challenge in determining whether the sensor has been compromised or the sensor glucose trajectories are normal. We address this issue from a control-theoretic security perspective. In particular, a time-varying Kalman filter is employed to handle the sporadic meal intakes. The filter prediction error is then statistically evaluated to detect anomalies if present. We compare two state-of-the-art online anomaly detection algorithms, namely the χ^2 and CUSUM tests. We establish a robust optimal detection rule for unknown bias injections. Even if the optimality holds only for the restrictive case of constant bias injections, we show that the proposed model-based anomaly detection scheme is also effective for generic non-stealthy sensor deception attacks through numerical simulations +
        +
        + + + +
        +
        +
        @article{Tosun_JPC2024,
        +  author = {Tosun, F. E. and Teixeira, A. M. H. and Abdalmoaty, M. and Ahl\'{e}n, A. and Dey, S.},
        +  journal = {Journal of Process Control},
        +  volume = {153},
        +  number = {103162},
        +  title = {Quickest Detection of Bias Injection Attacks on the Glucose Sensor in the Artificial Pancreas Under Meal Disturbances},
        +  year = {2024},
        +  doi = {10.1016/j.jprocont.2024.103162},
        +  published = {1},
        +  tag = {10002}
        +}
        +
        +
        + + + + + + + +
        + +
      4. +
      5. + + + +
        + + +
        + “Robust Sequential Detection of Non-stealthy Sensor Deception Attacks in an Artificial Pancreas System”.
        + F. E. Tosun and A. M. H. Teixeira.
        + Accepted to IEEE Conference on Decisions and Control (CDC), 2023
        + +
        + + + + + + + + + + + + + + + + BIB + + + + + + + + +
        +
        +
        @inproceedings{Tosun_CDC2023,
        +  address = {},
        +  author = {Tosun, F. E. and Teixeira, A. M. H.},
        +  booktitle = {Accepted to IEEE Conference on Decisions and Control (CDC)},
        +  title = {Robust Sequential Detection of Non-stealthy Sensor Deception Attacks in an Artificial Pancreas System},
        +  year = {2023},
        +  published = {1},
        +  tag = {10002}
        +}
        +
        +
        + + + + + + + +
        + +
      6. +
      7. + + + +
        + + +
        + “Detection of Bias Injection Attacks on the Glucose Sensor in the Artificial Pancreas Under Meal Disturbances”.
        + F. E. Tosun, A. M. H. Teixeira, A. Ahlén, and S. Dey.
        + American Control Conference, Atlanta, Georgia, USA, 2022
        + +
        + + + + + + ABS + + + + + + + + + + + + BIB + + + + + + +
        +
        + The artificial pancreas is an emerging concept of closed-loop insulin delivery that aims to tightly regulate the blood glucose levels in patients with type 1 diabetes. This paper considers bias injection attacks on the glucose sensor deployed in an artificial pancreas. Modern glucose sensors transmit measurements through wireless communication that are vulnerable to cyber-attacks, which must be timely detected and mitigated. To this end, we propose a model-based anomaly detection scheme using a Kalman filter and a χ 2 test. One key challenge is to distinguish cyber-attacks from large unknown disturbances arising from meal intake. This challenge is addressed by an online meal estimator, and a novel time-varying detection threshold. More precisely, we show that the ordinary least squares is the optimal unbiased estimator of the meal size under certain modelling assumptions. Moreover, we derive a novel time-varying threshold for the χ 2 detector to avoid false alarms during meal ingestion. The results are validated by means of numerical simulations. +
        +
        + + + +
        +
        +
        @inproceedings{Tosun_ACC2022,
        +  address = {Atlanta, Georgia, USA},
        +  author = {Tosun, F. E. and Teixeira, A. M. H. and Ahl\'{e}n, A. and Dey, S.},
        +  booktitle = {American Control Conference},
        +  title = {Detection of Bias Injection Attacks on the Glucose Sensor in the Artificial Pancreas Under Meal Disturbances},
        +  year = {2022},
        +  doi = {10.23919/ACC53348.2022.9867556},
        +  tag = {10002},
        +}
        +
        +
        + + + + + + + +
        + +
      + +
      +
      +
      +
      +
      + +
      +
      + +

      + +

      Delay attacks on networked control systems

      +

      Feedback loop delay is known to impose limitations on the achievable performance of control systems. In particular, delays can increase oscillations, reduce regulation accuracy, and may cause destabilization of the control system. Large enough delays may also cause the loss of communication packets between the sensors, the controller, and the actuators, resulting in denial-of-service at the controller. Delays and packet losses are important aspects to be considered in the context of control over wireless communication networks. Unfortunately, delays can also be induced by malicious cyber-attacks that aim to disrupt the system. In the security context, it is important to understand how delays may be induced by adversaries and how the attacks may be disguised as natural properties of the communication channel. Our group investigates novel control-theoretic approaches for understanding, detecting, and mitigating attack-induced delays and packet losses, combining techniques from system identification, anomaly detection, and robust control.

      +

      Team members: Torbjörn Wigren, Ruslan Seifullaev, André M. H. Teixeira

      +

      +

      +

      +
      +
      +
      + +
      1. + + + +
        + + +
        + “Event-triggered control of nonlinear systems under deception and Denial-of-Service attacks”.
        + R. Seifullaev, A. M. H. Teixeira, and A. Ahlén.
        + Submitted
        + +
        + + + + + + + + + + + + + + + + BIB + + + + + + + + +
        +
        +
        @inproceedings{Seifullaev_CDC024,
        +  author = {Seifullaev, R. and Teixeira, A. M. H. and Ahl\'{e}n, A.},
        +  booktitle = {Submitted},
        +  title = {Event-triggered control of nonlinear systems under deception and Denial-of-Service attacks},
        +  year = {},
        +  published = {9999},
        +  tag = {10004}
        +}
        +
        +
        + + + + + + + +
        + +
      2. +
      3. + + + +
        + + +
        + “Delay Attack and Detection in Feedback Linearized Control Systems”.
        + T. Wigren and A. M. H. Teixeira.
        + European Control Conference (Accepted), 2024
        + +
        + + + + + + ABS + + + + + + + + + + + + BIB + + + + + + +
        +
        + Delay injection attacks on nonlinear control systems have many consequences. Nonlinear instability mechanisms, for example finite escape time dynamics, can be triggered which is why rapid attack detection needs research. The paper therefore considers delay attacks on feedback linearized systems and shows how a recursive identification algorithm for nonlinear systems with delay may be used for detection of delay injection in the feedback path. The attack methodology is illustrated using a simulated feedback linearized automotive cruise controller where the attack is disguised, but anyway rapidly detected. +
        +
        + + + +
        +
        +
        @inproceedings{Wigren_ECC2024,
        +  author = {Wigren, T. and Teixeira, A. M. H.},
        +  booktitle = {European Control Conference (Accepted)},
        +  title = {Delay Attack and Detection in Feedback Linearized Control Systems},
        +  year = {2024},
        +  published = {1},
        +  tag = {10004}
        +}
        +
        +
        + + + + + + + +
        + +
      4. +
      5. + + + +
        + + +
        + “Feedback Path Delay Attacks and Detection”.
        + T. Wigren and A. M. H. Teixeira.
        + Accepted to IEEE Conference on Decisions and Control (CDC), 2023
        + +
        + + + + + + + + + + + + + + + + BIB + + + + + + + + +
        +
        +
        @inproceedings{Wigren_CDC2023,
        +  address = {},
        +  author = {Wigren, T. and Teixeira, A. M. H.},
        +  booktitle = {Accepted to IEEE Conference on Decisions and Control (CDC)},
        +  title = {Feedback Path Delay Attacks and Detection},
        +  year = {2023},
        +  published = {1},
        +  tag = {10004}
        +}
        +
        +
        + + + + + + + +
        + +
      6. +
      7. + + + +
        + + +
        + “On-line Identification of Delay Attacks in Networked Servo Control”.
        + T. Wigren and A. M. H. Teixeira.
        + IFAC World Congress, 2023
        + +
        + + + + + + ABS + + + + + + + + + + + + BIB + + + + + + +
        +
        + The paper discusses attacks on networked control loops by increased delay, and shows how existing round trip jitter may disguise such attacks. The attackers objective need not be de-stabilization, the paper argues that making settling time requirements fail can be sufficient. To defend against such attacks, the paper proposes the use of joint recursive prediction error identification of the round trip delay and the networked closed loop dynamics. The proposed identification algorithm allows general defense, since it is designed for delayed nonlinear dynamics in state space form. Simulations show that the method is able to detect a delay attack on a printed circuit board component mounting servo loop, long before the attack reaches full effect. +
        +
        + + + +
        +
        +
        @inproceedings{WigrenIFAC2023,
        +  address = {},
        +  author = {Wigren, T. and Teixeira, A. M. H.},
        +  booktitle = {IFAC World Congress},
        +  title = {On-line Identification of Delay Attacks in Networked Servo Control},
        +  year = {2023},
        +  tag = {10004}
        +}
        +
        +
        + + + + + + + +
        + +
      + +
      +
      +
      +
      +
      + +
      + +
      + +
      +
      + +

      + +

      Security and resilience of networked dynamical systems

      +

      Sustained use of critical infrastructure, such as electrical power and water distribution networks, requires efficient management and control. Facilitated by the advancements in computational devices and non-proprietary communication technology, such as the Internet, the efficient operation of critical infrastructure relies on network decomposition into interconnected subsystems, thus forming networked control systems. However, the use of public and pervasive communication channels leaves these systems vulnerable to cyber attacks. This theme aims to create novel methodologies to enhance the security and resilience of networked dynamical systems under cyber attacks.

      +

      Team members: Anh Tung Nguyen, Alain Govaert, André M. H. Teixeira, Sérgio Pequito

      +

      +

      +

      +
      +
      +
      + +
      1. + + + +
        + + +
        + “Security Allocation in Networked Control Systems under Stealthy Attacks”.
        + A. T. Nguyen, A. M. H. Teixeira, and A. Medvedev.
        + IEEE Trans. Control of Network Systems (Submitted)
        + +
        + + + + + + ABS + + + + + + + + + + + + BIB + + + + + + +
        +
        + This paper considers the problem of security allocation in a networked control system under stealthy attacks in which the system is comprised of interconnected subsystems represented by vertices. A malicious adversary selects a single vertex on which to conduct a stealthy data injection attack to maximally disrupt the local performance while remaining undetected. On the other hand, a defender selects several vertices on which to allocate defense resources against the adversary. First, the objectives of the adversary and the defender with uncertain targets are formulated in probabilistic ways, resulting in an expected worst-case impact of stealthy attacks. Next, we provide a graph-theoretic necessary and sufficient condition under which the cost for the defender and the expected worst-case impact of stealthy attacks are bounded. This condition enables the defender to restrict the admissible actions to a subset of available vertex sets. Then, we cast the problem of security allocation in a Stackelberg game-theoretic framework. Finally, the contribution of this paper is highlighted by utilizing the proposed admissible actions of the defender in the context of large-scale networks. A numerical example of a 50-vertex networked control system is presented to validate the obtained results. +
        +
        + + + +
        +
        +
        @article{Tung_TCNS2024,
        +  author = {Nguyen, A. T. and Teixeira, A. M. H. and Medvedev, A.},
        +  journal = {IEEE Trans. Control of Network Systems (Submitted)},
        +  number = {},
        +  pages = {},
        +  title = {Security Allocation in Networked Control Systems under Stealthy Attacks},
        +  volume = {},
        +  year = {},
        +  published = {0},
        +  tag = {10005}
        +}
        +
        +
        + + + + + + + +
        + +
      2. +
      3. + + + +
        + + +
        + “Security Allocation in Networked Control Systems”.
        + A. T. Nguyen.
        + Licentiate thesis, Uppsala University, Uppsala, Sweden, 2023
        + +
        + + + + + + ABS + + + + + + + + + + + + BIB + + + + + + +
        +
        + Sustained use of critical infrastructure, such as electrical power and water distribution networks, requires efficient management and control. Facilitated by the advancements in computational devices and non-proprietary communication technology, such as the Internet, the efficient operation of critical infrastructure relies on network decomposition into interconnected subsystems, thus forming networked control systems. However, the use of public and pervasive communication channels leaves these systems vulnerable to cyber attacks. Consequently, the critical infrastructure is put at risk of suffering operation disruption and even physical damage that would inflict financial costs as well as pose a hazard to human health. Therefore, security is crucial to the sustained efficient operation of critical infrastructure. + + This thesis develops a framework for evaluating and improving the security of networked control systems in the face of cyber attacks. The considered security problem involves two strategic agents, namely a malicious adversary and a defender, pursuing their specific and conflicting goals. The defender aims to efficiently allocate defense resources with the purpose of detecting malicious activities. Meanwhile, the malicious adversary simultaneously conducts cyber attacks and remains stealthy to the defender. We tackle the security problem by proposing a game-theoretic framework and characterizing its main components: the payoff function, the action space, and the available information for each agent. Especially, the payoff function is characterized based on the output-to-output gain security metric that fully explores the worst-case attack impact. Then, we investigate the properties of the game and how to efficiently compute its equilibrium. Given the combinatorial nature of the defender’s actions, one important challenge is to alleviate the computational burden. To overcome this challenge, the thesis contributes several system- and graph-theoretic conditions that enable the defender to shrink the action space, efficiently allocating the defense resources. The effectiveness of the proposed framework is validated through numerical examples. +
        +
        + + + +
        +
        +
        @phdthesis{Nguyen_Lic2023,
        +  author = {Nguyen, Anh Tung},
        +  title = {Security Allocation in Networked Control Systems},
        +  school = {Uppsala University},
        +  year = {2023},
        +  address = {Uppsala, Sweden},
        +  month = oct,
        +  type = {Licentiate thesis},
        +  tag = {10005}
        +}
        +
        +
        + + + + + + + +
        + +
      4. +
      5. + + + +
        + + +
        + “On the trade-offs between accuracy, privacy, and resilience in average consensus algorithms”.
        + G. Ramos, A. M. H. Teixeira, and S. Pequito.
        + Accepted to IEEE Conference on Decisions and Control (CDC), 2023
        + +
        + + + + + + + + + + + + + + + + BIB + + + + + + + + +
        +
        +
        @inproceedings{Ramos_CDC2023,
        +  author = {Ramos, G. and Teixeira, A. M. H. and Pequito, S.},
        +  booktitle = {Accepted to IEEE Conference on Decisions and Control (CDC)},
        +  title = {On the trade-offs between accuracy, privacy, and resilience in average consensus algorithms},
        +  year = {2023},
        +  published = {1},
        +  tag = {10005},
        +  taga = {10006}
        +}
        +
        +
        + + + + + + + +
        + +
      6. +
      7. + + + +
        + + +
        + “Secure State Estimation with Asynchronous Measurements against Malicious Measurement-data and Time-stamp Manipulation”.
        + Z. Li, A. T. Nguyen, A. M. H. Teixeira, Y. Mo, and K. H. Johansson.
        + Accepted to IEEE Conference on Decisions and Control (CDC), 2023
        + +
        + + + + + + ABS + + + + + + + + + + + + BIB + + + + + + +
        +
        + This paper proposes a secure state estimation scheme with non-periodic asynchronous measurements for linear continuous-time systems under false data attacks on the measurement transmit channel. After sampling the output of the system, a sensor transmits the measurement information in a triple composed of sensor index, time-stamp, and measurement value to the fusion center via vulnerable communication channels. The malicious attacker can corrupt a subset of the sensors through (i) manipulating the time-stamp and measurement value; (ii) blocking transmitted measurement triples; or (iii) injecting fake measurement triples. To deal with such attacks, we propose the design of local estimators based on observability space decomposition, where each local estimator updates the local state and sends it to the fusion center after sampling a measurement. Whenever there is a local update, the fusion center combines all the local states and generates a secure state estimate by adopting the median operator. We prove that local estimators of benign sensors are unbiased with stable covariance. Moreover, the fused central estimation error has bounded expectation and covariance against at most p corrupted sensors as long as the system is 2p-sparse observable. The efficacy of the proposed scheme is demonstrated through an application on a benchmark example of the IEEE 14-bus system. +
        +
        + + + +
        +
        +
        @inproceedings{Li_CDC2023,
        +  address = {},
        +  author = {Li, Z. and Nguyen, A. T. and Teixeira, A. M. H. and Mo, Y. and Johansson, K. H.},
        +  booktitle = {Accepted to IEEE Conference on Decisions and Control (CDC)},
        +  title = {Secure State Estimation with Asynchronous Measurements against Malicious  Measurement-data and Time-stamp Manipulation},
        +  year = {2023},
        +  published = {1},
        +  tag = {10005}
        +}
        +
        +
        + + + + + + + +
        + +
      8. +
      9. + + + +
        + + +
        + “Optimal Detector Placement in Networked Control Systems under Cyber-attacks with Applications to Power Networks”.
        + A. T. Nguyen, S. C. Anand, A. M. H. Teixeira, and A. Medvedev.
        + IFAC World Congress, 2023
        + +
        + + + + + + ABS + + + + + + + + + + + + BIB + + + + + + +
        +
        + This paper proposes a game-theoretic method to address the problem of optimal detector placement in a networked control system under cyber-attacks. The networked control system is composed of interconnected agents where each agent is regulated by its local controller over unprotected communication, which leaves the system vulnerable to malicious cyber-attacks. To guarantee a given local performance, the defender optimally selects a single agent on which to place a detector at its local controller with the purpose of detecting cyber-attacks. On the other hand, an adversary optimally chooses a single agent on which to conduct a cyber-attack on its input with the aim of maximally worsening the local performance while remaining stealthy to the defender. First, we present a necessary and sufficient condition to ensure that the maximal attack impact on the local performance is bounded, which restricts the possible actions of the defender to a subset of available agents. Then, by considering the maximal attack impact on the local performance as a game payoff, we cast the problem of finding optimal actions of the defender and the adversary as a zero-sum game. Finally, with the possible action sets of the defender and the adversary, an algorithm is devoted to determining the Nash equilibria of the zero-sum game that yield the optimal detector placement. The proposed method is illustrated on an IEEE benchmark for power systems. +
        +
        + + + +
        +
        +
        @inproceedings{NguyenIFAC2023,
        +  address = {},
        +  author = {Nguyen, A. T. and Anand, S. C. and Teixeira, A. M. H. and Medvedev, A.},
        +  booktitle = {IFAC World Congress},
        +  title = {Optimal Detector Placement in Networked Control Systems under Cyber-attacks with Applications to Power Networks},
        +  tag = {10005},
        +  year = {2023},
        +}
        +
        +
        + + + + + + + +
        + +
      10. +
      11. + + + +
        + + +
        + “A Zero-Sum Game Framework for Optimal Sensor Placement in Uncertain Networked Control Systems under Cyber-Attacks”.
        + A. T. Nguyen, S. C. Anand, and A. M. H. Teixeira.
        + IEEE Conference on Decision and Control (CDC), 2022
        + +
        + + + + + + ABS + + + + + + + + + + + + BIB + + + + + + +
        +
        + This paper proposes a game-theoretic approach to address the problem of optimal sensor placement against an adversary in uncertain networked control systems. The problem is formulated as a zero-sum game with two players, namely a malicious adversary and a detector. Given a protected performance vertex, we consider a detector, with uncertain system knowledge, that selects another vertex on which to place a sensor and monitors its output with the aim of detecting the presence of the adversary. On the other hand, the adversary, also with uncertain system knowledge, chooses a single vertex and conducts a cyber-attack on its input. The purpose of the adversary is to drive the attack vertex as to maximally disrupt the protected performance vertex while remaining undetected by the detector. As our first contribution, the game payoff of the above-defined zero-sum game is formulated in terms of the Value-at-Risk of the adversary’s impact. However, this game payoff corresponds to an intractable optimization problem. To tackle the problem, we adopt the scenario approach to approximately compute the game payoff. Then, the optimal monitor selection is determined by analyzing the equilibrium of the zero-sum game. The proposed approach is illustrated via a numerical example of a 10-vertex networked control system. +
        +
        + + + +
        +
        +
        @inproceedings{NguyenCDC2022,
        +  address = {},
        +  author = {Nguyen, A. T. and Anand, S. C. and Teixeira, A. M. H.},
        +  booktitle = {IEEE Conference on Decision and Control (CDC)},
        +  title = {A Zero-Sum Game Framework for Optimal Sensor Placement in Uncertain Networked Control Systems under Cyber-Attacks},
        +  year = {2022},
        +  doi = {10.1109/CDC51059.2022.9992468},
        +  tag = {10005}
        +}
        +
        +
        + + + + + + + +
        + +
      12. +
      13. + + + +
        + + +
        + “A Single-Adversary-Single-Detector Zero-Sum Game in Networked Control Systems”.
        + A. T. Nguyen, A. M. H. Teixeira, and A. Medvedev.
        + IFAC Conference on Networked Systems (NecSys), 2022
        + +
        + + + + + + ABS + + + + + + + + + + + + BIB + + + + + + +
        +
        + This paper proposes a game-theoretic approach to address the problem of optimal sensor placement for detecting cyber-attacks in networked control systems. The problem is formulated as a zero-sum game with two players, namely a malicious adversary and a detector. Given a protected target vertex, the detector places a sensor at a single vertex to monitor the system and detect the presence of the adversary. On the other hand, the adversary selects a single vertex through which to conduct a cyber-attack that maximally disrupts the target vertex while remaining undetected by the detector. As our first contribution, for a given pair of attack and monitor vertices and a known target vertex, the game payoff function is defined as the output-to-output gain of the respective system. Then, the paper characterizes the set of feasible actions by the detector that ensures bounded values of the game payoff. Finally, an algebraic sufficient condition is proposed to examine whether a given vertex belongs to the set of feasible monitor vertices. The optimal sensor placement is then determined by computing the mixed-strategy Nash equilibrium of the zero-sum game through linear programming. The approach is illustrated via a numerical example of a 10-vertex networked control system with a given target vertex. +
        +
        + + + +
        +
        +
        @inproceedings{NguyenNecsys2022,
        +  address = {},
        +  author = {Nguyen, A. T. and Teixeira, A. M. H. and Medvedev, A.},
        +  booktitle = {IFAC Conference on Networked Systems (NecSys)},
        +  title = {A Single-Adversary-Single-Detector Zero-Sum Game in Networked Control Systems},
        +  year = {2022},
        +  doi = {10.1016/j.ifacol.2022.07.234},
        +  tag = {10005},
        +}
        +
        +
        + + + + + + + +
        + +
      + +
      +
      +
      +
      +
      + +
      +
      + +

      + +

      Privacy of networked dynamical systems

      +

      Guaranteeing privacy in dynamical networks is particularly important in the pressing concern of privacy in distributed optimization scenarios common in machine learning and artificial intelligence. The intrinsic design of these networks traditionally depends on implicit trust among agents, raising significant privacy issues. We propose a novel approach that integrates control theory and optimization techniques to address these privacy concerns. Our approach aims to refine network architectures and communication protocols, ensuring that the privacy of individual agents is preserved while maintaining the efficacy of collective decision-making processes. This advancement in network design is poised to substantially improve the handling of privacy in dynamical networks, facilitating their reliable and private application in various settings.

      +

      Team members: André M. H. Teixeira, Sérgio Pequito

      +

      +

      +

      +
      +
      +
      + +
      1. + + + +
        + + +
        + “Privacy preserving average consensus through network augmentation”.
        + G. Ramos, A. P. Aguiar, S. Kar, and S. Pequito.
        + IEEE Trans. Automatic Control (Accepted), 2023
        + +
        + + + + + + + + + + + + + + + + BIB + + + + + + + + +
        +
        +
        @article{Ramos_TAC2024,
        +  author = {Ramos, G. and Aguiar, A. P. and Kar, Soummya and Pequito, S.},
        +  journal = {IEEE Trans. Automatic Control (Accepted)},
        +  title = {Privacy preserving average consensus through network augmentation},
        +  year = {2023},
        +  published = {1},
        +  tag = {10006}
        +}
        +
        +
        + + + + + + + +
        + +
      2. +
      3. + + + +
        + + +
        + “Designing communication networks for discrete-time consensus for performance and privacy guarantees”.
        + G. Ramos and S. Pequito.
        + Systems & Control Letters, vol. 180, p. 105608, 2023
        + +
        + + + + + + ABS + + + + + + + + + + + + BIB + + + + + + +
        +
        + Discrete-time consensus plays a key role in multi-agent systems and distributed protocols. Unfortunately, due to the self-loop dynamics of the agents (an agent’s current state depends only on its own immediately previous state, i.e., one time-step in the past), they often lack privacy guarantees. Therefore, in this paper, we propose a novel design that consists of a network augmentation, where each agent uses the previous iteration values and the newly received ones to increase the privacy guarantees. To formally evaluate the privacy of a network of agents, we define the concept of privacy index, which intuitively measures the minimum number of agents that should work in coalition to recover all the initial states. Moreover, we aim to explore if there is a trade-off between privacy and accuracy (rate of convergence) or if we can increase both. We unveil that, with the proposed method, we can design networks with higher privacy index and faster convergence rates. Remarkably, we further ensure that the network always reaches consensus even when the original network does not. Finally, we illustrate the proposed method with examples and present networks that lead to higher privacy levels and, in the majority of the cases, to faster consensus rates. +
        +
        + + + +
        +
        +
        @article{Ramos_CSL2024,
        +  author = {Ramos, G. and Pequito, S.},
        +  journal = {Systems & Control Letters},
        +  volume = {180},
        +  pages = {105608},
        +  year = {2023},
        +  title = {Designing communication networks for discrete-time consensus for performance and privacy guarantees},
        +  doi = {10.1016/j.sysconle.2023.105608},
        +  published = {1},
        +  tag = {10006}
        +}
        +
        +
        + + + + + + + +
        + +
      4. +
      5. + + + +
        + + +
        + “On the trade-offs between accuracy, privacy, and resilience in average consensus algorithms”.
        + G. Ramos, A. M. H. Teixeira, and S. Pequito.
        + Accepted to IEEE Conference on Decisions and Control (CDC), 2023
        + +
        + + + + + + + + + + + + + + + + BIB + + + + + + + + +
        +
        +
        @inproceedings{Ramos_CDC2023,
        +  author = {Ramos, G. and Teixeira, A. M. H. and Pequito, S.},
        +  booktitle = {Accepted to IEEE Conference on Decisions and Control (CDC)},
        +  title = {On the trade-offs between accuracy, privacy, and resilience in average consensus algorithms},
        +  year = {2023},
        +  published = {1},
        +  tag = {10005},
        +  taga = {10006}
        +}
        +
        +
        + + + + + + + +
        + +
      6. +
      7. + + + +
        + + +
        + “Privacy and Security in Network Controlled Systems via Dynamic Masking”.
        + M. Abdalmoaty, S. C. Anand, and A. M. H. Teixeira.
        + IFAC World Congress, 2023
        + +
        + + + + + + ABS + + + + + + + + + VID + + + + + BIB + + + + + + +
        +
        + In this paper, we propose a new architecture to enhance the privacy and security of networked control systems against malicious adversaries. We consider an adversary which first learns the system dynamics (privacy) using system identification techniques, and then performs a data injection attack (security). In particular, we consider an adversary conducting zero-dynamics attacks (ZDA) which maximizes the performance cost of the system whilst staying undetected. However, using the proposed architecture, we show that it is possible to (i) introduce significant bias in the system estimates of the adversary: thus providing privacy of the system parameters, and (ii) efficiently detect attacks when the adversary performs a ZDA using the identified system: thus providing security. Through numerical simulations, we illustrate the efficacy of the proposed architecture. +
        +
        + + + +
        +
        +
        @inproceedings{AbdalmoatyIFAC2023,
        +  address = {},
        +  author = {Abdalmoaty, M. and Anand, S. C. and Teixeira, A. M. H.},
        +  booktitle = {IFAC World Congress},
        +  title = {Privacy and Security in Network Controlled Systems via Dynamic Masking},
        +  year = {2023},
        +  video = {https://youtu.be/uuz5ppriWLk},
        +  tag = {10006}
        +}
        +
        +
        + + + + + + + +
        + +
      + +
      +
      +
      +
      +
      + +
      + +

       

      + +

      … and more.

      + +
      + +
      +
      + + + + + + + + + + diff --git a/research/research_results/index.html b/research/research_results/index.html new file mode 100644 index 00000000..8c249ae0 --- /dev/null +++ b/research/research_results/index.html @@ -0,0 +1,1959 @@ + + + + + + + + Secure Learning and Control Lab - Publications + + + + + + + + + + + + + + + + + + +
      +
      +
      + + +

      Research themes

      + +

      (See also the personal webpage of our group members)

      + +

      Here are our main themes

      + +
      + +
      +
      + +

      + +

      Security metrics for control systems

      +

      The aim within this theme is to to create novel methodologies addressing cybersecurity problems under uncertainty in learning and control systems. A core element of this research is the development of novel probabilistic risk metrics and optimization-based design methods that jointly consider the impact and the detectability constraints of attacks, as well as model uncertainty and prior beliefs on the adversary model.

      +

      Team members: Sribalaji C. Anand, Anh Tung Nguyen, André M. H. Teixeira

      +

      +

      +

      +
      +
      +
      +
      1. + + + +
        + + +
        + “Risk Assessment of Stealthy Attacks on Uncertain Control Systems”.
        + S. C. Anand, A. M. H. Teixeira, and A. Ahlén.
        + IEEE Trans. Automatic Control (Accepted), 2023
        + +
        + + + + + + ABS + + + + + + + + + + + + BIB + + + + + + +
        +
        + In this article, we address the problem of risk assessment of stealthy attacks on uncertain control systems. Considering data injection attacks that aim at maximizing impact while remaining undetected, we use the recently proposed output-to-output gain to characterize the risk associated with the impact of attacks under a limited system knowledge attacker. The risk is formulated using a well-established risk metric, namely the maximum expected loss. Under this setups, the risk assessment problem corresponds to an untractable infinite non-convex optimization problem. To address this limitation, we adopt the framework of scenario-based optimization to approximate the infinite non-convex optimization problem by a sampled non-convex optimization problem. Then, based on the framework of dissipative system theory and S-procedure, the sampled non-convex risk assessment problem is formulated as an equivalent convex semi-definite program. Additionally, we derive the necessary and sufficient conditions for the risk to be bounded. Finally, we illustrate the results through numerical simulation of a hydro-turbine power system. +
        +
        + + + +
        +
        +
        @article{Anand_TAC2024,
        +  author = {Anand, S. C. and Teixeira, A. M. H. and Ahl\'{e}n, A.},
        +  journal = {IEEE Trans. Automatic Control (Accepted)},
        +  number = {},
        +  pages = {},
        +  title = {Risk Assessment of Stealthy Attacks on Uncertain Control Systems},
        +  volume = {},
        +  year = {2023},
        +  doi = {10.1109/TAC.2023.3318194},
        +  published = {1},
        +  tag = {10001}
        +}
        +
        +
        + + + + + + + +
        + +
      2. +
      3. + + + +
        + + +
        + “Risk-based Security Measure Allocation Against Actuator Attacks”.
        + S. C. Anand and A. M. H. Teixeira.
        + IEEE Open Journal of Control Systems, vol. 2, pp. 297–309, 2023
        + +
        + + + + + + ABS + + + + + + + + + + + + BIB + + + + + + +
        +
        + This article considers the problem of risk-optimal allocation of security measures when the actuators of an uncertain control system are under attack. We consider an adversary injecting false data into the actuator channels. The attack impact is characterized by the maximum performance loss caused by a stealthy adversary with bounded energy. Since the impact is a random variable, due to system uncertainty, we use Conditional Value-at-Risk (CVaR) to characterize the risk associated with the attack. We then consider the problem of allocating the security measures which minimize the risk. We assume that there are only a limited number of security measures available. Under this constraint, we observe that the allocation problem is a mixed-integer optimization problem. Thus we use relaxation techniques to approximate the security allocation problem into a Semi-Definite Program (SDP). We also compare our allocation method (i) across different risk measures: the worst-case measure, the average (nominal) measure, and (ii) across different search algorithms: the exhaustive and the greedy search algorithms. We depict the efficacy of our approach through numerical examples. +
        +
        + + + +
        +
        +
        @article{Anand_IEEEOJCSys2023,
        +  author = {Anand, S. C. and Teixeira, A. M. H.},
        +  journal = {IEEE Open Journal of Control Systems},
        +  number = {},
        +  pages = {297--309},
        +  title = {Risk-based Security Measure Allocation Against Actuator Attacks},
        +  volume = {2},
        +  year = {2023},
        +  doi = {10.1109/OJCSYS.2023.3305831},
        +  published = {1},
        +  tag = {10001}
        +}
        +
        +
        + + + + + + + +
        + +
      4. +
      5. + + + +
        + + +
        + “Risk assessment and optimal allocation of security measures under stealthy false data injection attacks”.
        + S. C. Anand, A. M. H. Teixeira, and A. Ahlén.
        + IEEE Conference on Control Technology and Applications (CCTA), 2022
        + +
        + + + + + + ABS + + + + + + + + + + + + BIB + + + + + + +
        +
        + This paper firstly addresses the problem of risk assessment under false data injection attacks on uncertain control systems. We consider an adversary with complete system knowledge, injecting stealthy false data into an uncertain control system. We then use the Value-at-Risk to characterize the risk associated with the attack impact caused by the adversary. The worst-case attack impact is characterized by the recently proposed output-to-output gain. We observe that the risk assessment problem corresponds to an infinite non-convex robust optimization problem. To this end, we use dissipative system theory and the scenario approach to approximate the risk-assessment problem into a convex problem and also provide probabilistic certificates on approximation. Secondly, we con-sider the problem of security measure allocation. We consider an operator with a constraint on the security budget. Under this constraint, we propose an algorithm to optimally allocate the security measures using the calculated risk such that the resulting Value-at-risk is minimized. Finally, we illustrate the results through a numerical example. The numerical example also illustrates that the security allocation using the Value-at-risk, and the impact on the nominal system may have different outcomes: thereby depicting the benefit of using risk metrics. +
        +
        + + + +
        +
        +
        @inproceedings{AnandCCTA2022,
        +  address = {},
        +  author = {Anand, S. C. and Teixeira, A. M. H. and Ahl\'{e}n, A.},
        +  booktitle = {IEEE Conference on Control Technology and Applications (CCTA)},
        +  title = {Risk assessment and optimal allocation of security measures under stealthy false data injection attacks},
        +  year = {2022},
        +  tag = {10001},
        +  doi = {10.1109/CCTA49430.2022.9966025},
        +}
        +
        +
        + + + + + + + +
        + +
      6. +
      7. + + + +
        + + +
        + “Risk-averse controller design against data injection attacks on actuators for uncertain control systems”.
        + S. C. Anand and A. M. H. Teixeira.
        + American Control Conference, Atlanta, Georgia, USA, 2022
        + +
        + + + + + + ABS + + + + + + + + + + + + BIB + + + + + + +
        +
        + In this paper, we consider the optimal controller design problem against data injection attacks on actuators for an uncertain control system. We consider attacks that aim at maximizing the attack impact while remaining stealthy in the finite horizon. To this end, we use the Conditional Value-at-Risk to characterize the risk associated with the impact of attacks. The worst-case attack impact is characterized using the recently proposed output-to-output ℓ 2 -gain (OOG). We formulate the design problem and observe that it is non-convex and hard to solve. Using the framework of scenario-based optimization and a convex proxy for the OOG, we propose a convex optimization problem that approximately solves the design problem with probabilistic certificates. Finally, we illustrate the results through a numerical example. +
        +
        + + + +
        +
        +
        @inproceedings{Anand_ACC2022,
        +  address = {Atlanta, Georgia, USA},
        +  author = {Anand, S. C. and Teixeira, A. M. H.},
        +  booktitle = {American Control Conference},
        +  title = {Risk-averse controller design against data injection attacks on actuators for uncertain control systems},
        +  year = {2022},
        +  doi = {10.23919/ACC53348.2022.9867257},
        +  tag = {10001},
        +}
        +
        +
        + + + + + + + +
        + +
      8. +
      9. + + + +
        + + +
        + “Security Metrics for Control Systems”.
        + A. M. H. Teixeira.
        + in Safety, Security and Privacy for Cyber-Physical Systems, R. M. G. Ferrari and A. M. H. Teixeira, Eds. Cham: Springer International Publishing, 2021, pp. 1–8
        + +
        + + + + + + + + + + + + + + + + BIB + + + + + + + + +
        +
        +
        @incollection{Teixeira_Springer2021,
        +  author = {Teixeira, Andr{\'e} M. H.},
        +  editor = {Ferrari, Riccardo M.G. and Teixeira, Andr{\'e} M. H.},
        +  title = {Security Metrics for Control Systems},
        +  booktitle = {Safety, Security and Privacy for Cyber-Physical Systems},
        +  year = {2021},
        +  publisher = {Springer International Publishing},
        +  address = {Cham},
        +  pages = {1--8},
        +  isbn = {978-3-030-65048-3},
        +  doi = {10.1007/978-3-030-65048-3_6},
        +  tag = {10001}
        +}
        +
        +
        + + + + + + + +
        + +
      + +
      +
      +
      +
      +
      + +
      +
      + +

      + +

      Secure Federated Machine Learning

      +

      Federated machine learning (FedML) has proven to be a suitable approach for privacy-preserving machine learning across a large number of heterogeneous devices. Our group addresses concerns related to security and privacy in federated machine learning against model poisoning and information leakage attacks. The approach is centered around developing new theories and methodologies to achieve two main aims: secure aggregation of local models under poisoning attacks; private distributed aggregation of local models.

      +

      Team members: Usama Zafar, Salman Toor, André M. H. Teixeira

      +

      +

      +

      +
      +
      +
      + +
      1. + + + +
        + + +
        + “Accelerating Fair Federated Learning: Adaptive Federated Adam”.
        + L. Ju, T. Zhang, S. Toor, and A. Hellander.
        + (Submitted, 2023)
        + +
        + + + + + + ABS + + + + + + + + + + + + BIB + + + + + + +
        +
        + Federated learning is a distributed and privacy-preserving approach to train a statistical model collaboratively from decentralized data of different parties. However, when datasets of participants are not independent and identically distributed (non-IID), models trained by naive federated algorithms may be biased towards certain participants, and model performance across participants is non-uniform. This is known as the fairness problem in federated learning. In this paper, we formulate fairness-controlled federated learning as a dynamical multi-objective optimization problem to ensure fair performance across all participants. To solve the problem efficiently, we study the convergence and bias of Adam as the server optimizer in federated learning, and propose Adaptive Federated Adam (AdaFedAdam) to accelerate fair federated learning with alleviated bias. We validated the effectiveness, Pareto optimality and robustness of AdaFedAdam in numerical experiments and show that AdaFedAdam outperforms existing algorithms, providing better convergence and fairness properties of the federated scheme. +
        +
        + + + +
        +
        +
        @inproceedings{Ju2023,
        +  address = {},
        +  author = {Ju, L. and Zhang, T. and Toor, S. and Hellander, A.},
        +  booktitle = {(Submitted, 2023)},
        +  title = {Accelerating Fair Federated Learning: Adaptive Federated Adam},
        +  published = {0},
        +  tag = {10003}
        +}
        +
        +
        + + + + + + + +
        + +
      2. +
      3. + + + +
        + + +
        + “Scalable federated machine learning with FEDn”.
        + M. Ekmefjord et al.
        + Symposium on Cluster, Cloud and Internet Computing, Taormina, Italy, 2022
        + +
        + + + + + + ABS + + + + + + + + + + + + BIB + + + + + + +
        +
        + Federated machine learning promises to overcome the input privacy challenge in machine learning. By iteratively updating a model on private clients and aggregating these local model updates into a global federated model, private data is incorporated in the federated model without needing to share and expose that data. Several open software projects for federated learning have appeared. Most of them focuses on supporting flexible experimentation with different model aggregation schemes and with different privacy-enhancing technologies. However, there is a lack of open frameworks that focuses on critical distributed computing aspects of the problem such as scalability and resilience. It is a big step to take for a data scientist to go from an experimental sandbox to testing their federated schemes at scale in real-world geographically distributed settings. To bridge this gap we have designed and developed a production-grade hierarchical federated learning framework, FEDn. The framework is specifically designed to make it easy to go from local development in pseudo-distributed mode to horizontally scalable distributed deployments. FEDn both aims to be production grade for industrial applications and a flexible research tool to explore real-world performance of novel federated algorithms and the framework has been used in number of industrial and academic R&D projects. In this paper we present the architecture and implementation of FEDn. We demonstrate the framework’s scalability and efficiency in evaluations based on two case-studies representative for a cross-silo and a cross-device use-case respectively. +
        +
        + + + +
        +
        +
        @inproceedings{Ekmefjord_CCGrid2022,
        +  address = {Taormina, Italy},
        +  author = {Ekmefjord, M. and Ait-Mlouk, A. and Alawadi, S. and Åkesson, M. and Singh, P. and Spjuth, O. and Toor, S. and Hellander, A.},
        +  booktitle = {Symposium on Cluster, Cloud and Internet Computing},
        +  title = {Scalable federated machine learning with FEDn},
        +  year = {2022},
        +  doi = {10.1109/CCGrid54584.2022.00065},
        +  tag = {10003},
        +}
        +
        +
        + + + + + + + +
        + +
      + +
      +
      +
      +
      +
      + +
      + +
      + +
      +
      + +

      + +

      Secure artificial pancreas

      +

      Artificial pancreas are envisioned medical systems whose function is to automatically regulate the blood glucose levels in patients with diabetes, with little to none human initervention. At the core of these systems we have an intellligent device autonomously deciding how much synthetic insulin and glucagon to infuse into the body through infusion pumps, based on data received from sensors located thoughout the body measuring, for instance, blood glucose levels in real-time. Data exchange among the controlling device, the pumps, and the sensors is critical. The whole system must operate safely, even in the presence of adversaries tampering with the communication or devices.

      + +

      In this line of research, we develop schemes to monitor the sensor reading to detect anomalies, and distinguish them from natural unknown disturbances, such as meal intakes, physical exercise, among others.

      +

      Team members: Fatih Emre Tosun, André M. H. Teixeira

      +

      +

      +

      +
      +
      +
      +
      1. + + + +
        + + +
        + “Kullback-Leibler Divergence-Based Detector Design Against Bias Injection Attacks in an Artificial Pancreas System”.
        + F. E. Tosun, A. M. H. Teixeira, A. Ahlén, and S. Dey.
        + 12th IFAC Symposium on Fault Detection, Supervision and Safety for Technical Processes (Accepted), 2024
        + +
        + + + + + + ABS + + + + + + + + + + + + BIB + + + + + + +
        +
        + This paper considers constant bias injection attacks on the glucose sensor deployed in an artificial pancreas system that has an integrator. The main challenge with such apparently simple attacks is that, if the system is linear and has an integrator, they are only detectable for a limited duration. More formally, they are steady-state stealthy attacks. To address this issue, we propose a residual generation method to increase the detectability of these attacks based on the Kullback–Leibler divergence metric. Illustrative examples with numerical simulations are provided to demonstrate the effectiveness of the proposed method. +
        +
        + + + +
        +
        +
        @inproceedings{Tosun_SP024,
        +  author = {Tosun, F. E. and Teixeira, A. M. H. and Ahlén, A. and Dey, S.},
        +  booktitle = {12th IFAC Symposium on Fault Detection, Supervision and Safety for Technical Processes (Accepted)},
        +  title = {Kullback-Leibler Divergence-Based Detector Design Against Bias Injection Attacks in an Artificial Pancreas System},
        +  year = {2024},
        +  published = {1},
        +  tag = {10002}
        +}
        +
        +
        + + + + + + + +
        + +
      2. +
      3. + + + +
        + + +
        + “Quickest Detection of Bias Injection Attacks on the Glucose Sensor in the Artificial Pancreas Under Meal Disturbances”.
        + F. E. Tosun, A. M. H. Teixeira, M. Abdalmoaty, A. Ahlén, and S. Dey.
        + Journal of Process Control, vol. 153, no. 103162, 2024
        + +
        + + + + + + ABS + + + + + + + + + + + + BIB + + + + + + +
        +
        + Modern glucose sensors deployed in closed-loop insulin delivery systems, so-called artificial pancreas use wireless communication channels. While this allows a flexible system design, it also introduces vulnerability to cyberattacks. Timely detection and mitigation of attacks are imperative for device safety. However, large unknown meal disturbances are a crucial challenge in determining whether the sensor has been compromised or the sensor glucose trajectories are normal. We address this issue from a control-theoretic security perspective. In particular, a time-varying Kalman filter is employed to handle the sporadic meal intakes. The filter prediction error is then statistically evaluated to detect anomalies if present. We compare two state-of-the-art online anomaly detection algorithms, namely the χ^2 and CUSUM tests. We establish a robust optimal detection rule for unknown bias injections. Even if the optimality holds only for the restrictive case of constant bias injections, we show that the proposed model-based anomaly detection scheme is also effective for generic non-stealthy sensor deception attacks through numerical simulations +
        +
        + + + +
        +
        +
        @article{Tosun_JPC2024,
        +  author = {Tosun, F. E. and Teixeira, A. M. H. and Abdalmoaty, M. and Ahl\'{e}n, A. and Dey, S.},
        +  journal = {Journal of Process Control},
        +  volume = {153},
        +  number = {103162},
        +  title = {Quickest Detection of Bias Injection Attacks on the Glucose Sensor in the Artificial Pancreas Under Meal Disturbances},
        +  year = {2024},
        +  doi = {10.1016/j.jprocont.2024.103162},
        +  published = {1},
        +  tag = {10002}
        +}
        +
        +
        + + + + + + + +
        + +
      4. +
      5. + + + +
        + + +
        + “Robust Sequential Detection of Non-stealthy Sensor Deception Attacks in an Artificial Pancreas System”.
        + F. E. Tosun and A. M. H. Teixeira.
        + Accepted to IEEE Conference on Decisions and Control (CDC), 2023
        + +
        + + + + + + + + + + + + + + + + BIB + + + + + + + + +
        +
        +
        @inproceedings{Tosun_CDC2023,
        +  address = {},
        +  author = {Tosun, F. E. and Teixeira, A. M. H.},
        +  booktitle = {Accepted to IEEE Conference on Decisions and Control (CDC)},
        +  title = {Robust Sequential Detection of Non-stealthy Sensor Deception Attacks in an Artificial Pancreas System},
        +  year = {2023},
        +  published = {1},
        +  tag = {10002}
        +}
        +
        +
        + + + + + + + +
        + +
      6. +
      7. + + + +
        + + +
        + “Detection of Bias Injection Attacks on the Glucose Sensor in the Artificial Pancreas Under Meal Disturbances”.
        + F. E. Tosun, A. M. H. Teixeira, A. Ahlén, and S. Dey.
        + American Control Conference, Atlanta, Georgia, USA, 2022
        + +
        + + + + + + ABS + + + + + + + + + + + + BIB + + + + + + +
        +
        + The artificial pancreas is an emerging concept of closed-loop insulin delivery that aims to tightly regulate the blood glucose levels in patients with type 1 diabetes. This paper considers bias injection attacks on the glucose sensor deployed in an artificial pancreas. Modern glucose sensors transmit measurements through wireless communication that are vulnerable to cyber-attacks, which must be timely detected and mitigated. To this end, we propose a model-based anomaly detection scheme using a Kalman filter and a χ 2 test. One key challenge is to distinguish cyber-attacks from large unknown disturbances arising from meal intake. This challenge is addressed by an online meal estimator, and a novel time-varying detection threshold. More precisely, we show that the ordinary least squares is the optimal unbiased estimator of the meal size under certain modelling assumptions. Moreover, we derive a novel time-varying threshold for the χ 2 detector to avoid false alarms during meal ingestion. The results are validated by means of numerical simulations. +
        +
        + + + +
        +
        +
        @inproceedings{Tosun_ACC2022,
        +  address = {Atlanta, Georgia, USA},
        +  author = {Tosun, F. E. and Teixeira, A. M. H. and Ahl\'{e}n, A. and Dey, S.},
        +  booktitle = {American Control Conference},
        +  title = {Detection of Bias Injection Attacks on the Glucose Sensor in the Artificial Pancreas Under Meal Disturbances},
        +  year = {2022},
        +  doi = {10.23919/ACC53348.2022.9867556},
        +  tag = {10002},
        +}
        +
        +
        + + + + + + + +
        + +
      + +
      +
      +
      +
      +
      + +
      +
      + +

      + +

      Delay attacks on networked control systems

      +

      Feedback loop delay is known to impose limitations on the achievable performance of control systems. In particular, delays can increase oscillations, reduce regulation accuracy, and may cause destabilization of the control system. Large enough delays may also cause the loss of communication packets between the sensors, the controller, and the actuators, resulting in denial-of-service at the controller. Delays and packet losses are important aspects to be considered in the context of control over wireless communication networks. Unfortunately, delays can also be induced by malicious cyber-attacks that aim to disrupt the system. In the security context, it is important to understand how delays may be induced by adversaries and how the attacks may be disguised as natural properties of the communication channel. Our group investigates novel control-theoretic approaches for understanding, detecting, and mitigating attack-induced delays and packet losses, combining techniques from system identification, anomaly detection, and robust control.

      +

      Team members: Torbjörn Wigren, Ruslan Seifullaev, André M. H. Teixeira

      +

      +

      +

      +
      +
      +
      + +
      1. + + + +
        + + +
        + “Event-triggered control of nonlinear systems under deception and Denial-of-Service attacks”.
        + R. Seifullaev, A. M. H. Teixeira, and A. Ahlén.
        + Submitted
        + +
        + + + + + + + + + + + + + + + + BIB + + + + + + + + +
        +
        +
        @inproceedings{Seifullaev_CDC024,
        +  author = {Seifullaev, R. and Teixeira, A. M. H. and Ahl\'{e}n, A.},
        +  booktitle = {Submitted},
        +  title = {Event-triggered control of nonlinear systems under deception and Denial-of-Service attacks},
        +  year = {},
        +  published = {9999},
        +  tag = {10004}
        +}
        +
        +
        + + + + + + + +
        + +
      2. +
      3. + + + +
        + + +
        + “Delay Attack and Detection in Feedback Linearized Control Systems”.
        + T. Wigren and A. M. H. Teixeira.
        + European Control Conference (Accepted), 2024
        + +
        + + + + + + ABS + + + + + + + + + + + + BIB + + + + + + +
        +
        + Delay injection attacks on nonlinear control systems have many consequences. Nonlinear instability mechanisms, for example finite escape time dynamics, can be triggered which is why rapid attack detection needs research. The paper therefore considers delay attacks on feedback linearized systems and shows how a recursive identification algorithm for nonlinear systems with delay may be used for detection of delay injection in the feedback path. The attack methodology is illustrated using a simulated feedback linearized automotive cruise controller where the attack is disguised, but anyway rapidly detected. +
        +
        + + + +
        +
        +
        @inproceedings{Wigren_ECC2024,
        +  author = {Wigren, T. and Teixeira, A. M. H.},
        +  booktitle = {European Control Conference (Accepted)},
        +  title = {Delay Attack and Detection in Feedback Linearized Control Systems},
        +  year = {2024},
        +  published = {1},
        +  tag = {10004}
        +}
        +
        +
        + + + + + + + +
        + +
      4. +
      5. + + + +
        + + +
        + “Feedback Path Delay Attacks and Detection”.
        + T. Wigren and A. M. H. Teixeira.
        + Accepted to IEEE Conference on Decisions and Control (CDC), 2023
        + +
        + + + + + + + + + + + + + + + + BIB + + + + + + + + +
        +
        +
        @inproceedings{Wigren_CDC2023,
        +  address = {},
        +  author = {Wigren, T. and Teixeira, A. M. H.},
        +  booktitle = {Accepted to IEEE Conference on Decisions and Control (CDC)},
        +  title = {Feedback Path Delay Attacks and Detection},
        +  year = {2023},
        +  published = {1},
        +  tag = {10004}
        +}
        +
        +
        + + + + + + + +
        + +
      6. +
      7. + + + +
        + + +
        + “On-line Identification of Delay Attacks in Networked Servo Control”.
        + T. Wigren and A. M. H. Teixeira.
        + IFAC World Congress, 2023
        + +
        + + + + + + ABS + + + + + + + + + + + + BIB + + + + + + +
        +
        + The paper discusses attacks on networked control loops by increased delay, and shows how existing round trip jitter may disguise such attacks. The attackers objective need not be de-stabilization, the paper argues that making settling time requirements fail can be sufficient. To defend against such attacks, the paper proposes the use of joint recursive prediction error identification of the round trip delay and the networked closed loop dynamics. The proposed identification algorithm allows general defense, since it is designed for delayed nonlinear dynamics in state space form. Simulations show that the method is able to detect a delay attack on a printed circuit board component mounting servo loop, long before the attack reaches full effect. +
        +
        + + + +
        +
        +
        @inproceedings{WigrenIFAC2023,
        +  address = {},
        +  author = {Wigren, T. and Teixeira, A. M. H.},
        +  booktitle = {IFAC World Congress},
        +  title = {On-line Identification of Delay Attacks in Networked Servo Control},
        +  year = {2023},
        +  tag = {10004}
        +}
        +
        +
        + + + + + + + +
        + +
      + +
      +
      +
      +
      +
      + +
      + +
      + +
      +
      + +

      + +

      Security and resilience of networked dynamical systems

      +

      Sustained use of critical infrastructure, such as electrical power and water distribution networks, requires efficient management and control. Facilitated by the advancements in computational devices and non-proprietary communication technology, such as the Internet, the efficient operation of critical infrastructure relies on network decomposition into interconnected subsystems, thus forming networked control systems. However, the use of public and pervasive communication channels leaves these systems vulnerable to cyber attacks. This theme aims to create novel methodologies to enhance the security and resilience of networked dynamical systems under cyber attacks.

      +

      Team members: Anh Tung Nguyen, Alain Govaert, André M. H. Teixeira, Sérgio Pequito

      +

      +

      +

      +
      +
      +
      + +
      1. + + + +
        + + +
        + “Security Allocation in Networked Control Systems under Stealthy Attacks”.
        + A. T. Nguyen, A. M. H. Teixeira, and A. Medvedev.
        + IEEE Trans. Control of Network Systems (Submitted)
        + +
        + + + + + + ABS + + + + + + + + + + + + BIB + + + + + + +
        +
        + This paper considers the problem of security allocation in a networked control system under stealthy attacks in which the system is comprised of interconnected subsystems represented by vertices. A malicious adversary selects a single vertex on which to conduct a stealthy data injection attack to maximally disrupt the local performance while remaining undetected. On the other hand, a defender selects several vertices on which to allocate defense resources against the adversary. First, the objectives of the adversary and the defender with uncertain targets are formulated in probabilistic ways, resulting in an expected worst-case impact of stealthy attacks. Next, we provide a graph-theoretic necessary and sufficient condition under which the cost for the defender and the expected worst-case impact of stealthy attacks are bounded. This condition enables the defender to restrict the admissible actions to a subset of available vertex sets. Then, we cast the problem of security allocation in a Stackelberg game-theoretic framework. Finally, the contribution of this paper is highlighted by utilizing the proposed admissible actions of the defender in the context of large-scale networks. A numerical example of a 50-vertex networked control system is presented to validate the obtained results. +
        +
        + + + +
        +
        +
        @article{Tung_TCNS2024,
        +  author = {Nguyen, A. T. and Teixeira, A. M. H. and Medvedev, A.},
        +  journal = {IEEE Trans. Control of Network Systems (Submitted)},
        +  number = {},
        +  pages = {},
        +  title = {Security Allocation in Networked Control Systems under Stealthy Attacks},
        +  volume = {},
        +  year = {},
        +  published = {0},
        +  tag = {10005}
        +}
        +
        +
        + + + + + + + +
        + +
      2. +
      3. + + + +
        + + +
        + “Security Allocation in Networked Control Systems”.
        + A. T. Nguyen.
        + Licentiate thesis, Uppsala University, Uppsala, Sweden, 2023
        + +
        + + + + + + ABS + + + + + + + + + + + + BIB + + + + + + +
        +
        + Sustained use of critical infrastructure, such as electrical power and water distribution networks, requires efficient management and control. Facilitated by the advancements in computational devices and non-proprietary communication technology, such as the Internet, the efficient operation of critical infrastructure relies on network decomposition into interconnected subsystems, thus forming networked control systems. However, the use of public and pervasive communication channels leaves these systems vulnerable to cyber attacks. Consequently, the critical infrastructure is put at risk of suffering operation disruption and even physical damage that would inflict financial costs as well as pose a hazard to human health. Therefore, security is crucial to the sustained efficient operation of critical infrastructure. + + This thesis develops a framework for evaluating and improving the security of networked control systems in the face of cyber attacks. The considered security problem involves two strategic agents, namely a malicious adversary and a defender, pursuing their specific and conflicting goals. The defender aims to efficiently allocate defense resources with the purpose of detecting malicious activities. Meanwhile, the malicious adversary simultaneously conducts cyber attacks and remains stealthy to the defender. We tackle the security problem by proposing a game-theoretic framework and characterizing its main components: the payoff function, the action space, and the available information for each agent. Especially, the payoff function is characterized based on the output-to-output gain security metric that fully explores the worst-case attack impact. Then, we investigate the properties of the game and how to efficiently compute its equilibrium. Given the combinatorial nature of the defender’s actions, one important challenge is to alleviate the computational burden. To overcome this challenge, the thesis contributes several system- and graph-theoretic conditions that enable the defender to shrink the action space, efficiently allocating the defense resources. The effectiveness of the proposed framework is validated through numerical examples. +
        +
        + + + +
        +
        +
        @phdthesis{Nguyen_Lic2023,
        +  author = {Nguyen, Anh Tung},
        +  title = {Security Allocation in Networked Control Systems},
        +  school = {Uppsala University},
        +  year = {2023},
        +  address = {Uppsala, Sweden},
        +  month = oct,
        +  type = {Licentiate thesis},
        +  tag = {10005}
        +}
        +
        +
        + + + + + + + +
        + +
      4. +
      5. + + + +
        + + +
        + “On the trade-offs between accuracy, privacy, and resilience in average consensus algorithms”.
        + G. Ramos, A. M. H. Teixeira, and S. Pequito.
        + Accepted to IEEE Conference on Decisions and Control (CDC), 2023
        + +
        + + + + + + + + + + + + + + + + BIB + + + + + + + + +
        +
        +
        @inproceedings{Ramos_CDC2023,
        +  author = {Ramos, G. and Teixeira, A. M. H. and Pequito, S.},
        +  booktitle = {Accepted to IEEE Conference on Decisions and Control (CDC)},
        +  title = {On the trade-offs between accuracy, privacy, and resilience in average consensus algorithms},
        +  year = {2023},
        +  published = {1},
        +  tag = {10005},
        +  taga = {10006}
        +}
        +
        +
        + + + + + + + +
        + +
      6. +
      7. + + + +
        + + +
        + “Secure State Estimation with Asynchronous Measurements against Malicious Measurement-data and Time-stamp Manipulation”.
        + Z. Li, A. T. Nguyen, A. M. H. Teixeira, Y. Mo, and K. H. Johansson.
        + Accepted to IEEE Conference on Decisions and Control (CDC), 2023
        + +
        + + + + + + ABS + + + + + + + + + + + + BIB + + + + + + +
        +
        + This paper proposes a secure state estimation scheme with non-periodic asynchronous measurements for linear continuous-time systems under false data attacks on the measurement transmit channel. After sampling the output of the system, a sensor transmits the measurement information in a triple composed of sensor index, time-stamp, and measurement value to the fusion center via vulnerable communication channels. The malicious attacker can corrupt a subset of the sensors through (i) manipulating the time-stamp and measurement value; (ii) blocking transmitted measurement triples; or (iii) injecting fake measurement triples. To deal with such attacks, we propose the design of local estimators based on observability space decomposition, where each local estimator updates the local state and sends it to the fusion center after sampling a measurement. Whenever there is a local update, the fusion center combines all the local states and generates a secure state estimate by adopting the median operator. We prove that local estimators of benign sensors are unbiased with stable covariance. Moreover, the fused central estimation error has bounded expectation and covariance against at most p corrupted sensors as long as the system is 2p-sparse observable. The efficacy of the proposed scheme is demonstrated through an application on a benchmark example of the IEEE 14-bus system. +
        +
        + + + +
        +
        +
        @inproceedings{Li_CDC2023,
        +  address = {},
        +  author = {Li, Z. and Nguyen, A. T. and Teixeira, A. M. H. and Mo, Y. and Johansson, K. H.},
        +  booktitle = {Accepted to IEEE Conference on Decisions and Control (CDC)},
        +  title = {Secure State Estimation with Asynchronous Measurements against Malicious  Measurement-data and Time-stamp Manipulation},
        +  year = {2023},
        +  published = {1},
        +  tag = {10005}
        +}
        +
        +
        + + + + + + + +
        + +
      8. +
      9. + + + +
        + + +
        + “Optimal Detector Placement in Networked Control Systems under Cyber-attacks with Applications to Power Networks”.
        + A. T. Nguyen, S. C. Anand, A. M. H. Teixeira, and A. Medvedev.
        + IFAC World Congress, 2023
        + +
        + + + + + + ABS + + + + + + + + + + + + BIB + + + + + + +
        +
        + This paper proposes a game-theoretic method to address the problem of optimal detector placement in a networked control system under cyber-attacks. The networked control system is composed of interconnected agents where each agent is regulated by its local controller over unprotected communication, which leaves the system vulnerable to malicious cyber-attacks. To guarantee a given local performance, the defender optimally selects a single agent on which to place a detector at its local controller with the purpose of detecting cyber-attacks. On the other hand, an adversary optimally chooses a single agent on which to conduct a cyber-attack on its input with the aim of maximally worsening the local performance while remaining stealthy to the defender. First, we present a necessary and sufficient condition to ensure that the maximal attack impact on the local performance is bounded, which restricts the possible actions of the defender to a subset of available agents. Then, by considering the maximal attack impact on the local performance as a game payoff, we cast the problem of finding optimal actions of the defender and the adversary as a zero-sum game. Finally, with the possible action sets of the defender and the adversary, an algorithm is devoted to determining the Nash equilibria of the zero-sum game that yield the optimal detector placement. The proposed method is illustrated on an IEEE benchmark for power systems. +
        +
        + + + +
        +
        +
        @inproceedings{NguyenIFAC2023,
        +  address = {},
        +  author = {Nguyen, A. T. and Anand, S. C. and Teixeira, A. M. H. and Medvedev, A.},
        +  booktitle = {IFAC World Congress},
        +  title = {Optimal Detector Placement in Networked Control Systems under Cyber-attacks with Applications to Power Networks},
        +  tag = {10005},
        +  year = {2023},
        +}
        +
        +
        + + + + + + + +
        + +
      10. +
      11. + + + +
        + + +
        + “A Zero-Sum Game Framework for Optimal Sensor Placement in Uncertain Networked Control Systems under Cyber-Attacks”.
        + A. T. Nguyen, S. C. Anand, and A. M. H. Teixeira.
        + IEEE Conference on Decision and Control (CDC), 2022
        + +
        + + + + + + ABS + + + + + + + + + + + + BIB + + + + + + +
        +
        + This paper proposes a game-theoretic approach to address the problem of optimal sensor placement against an adversary in uncertain networked control systems. The problem is formulated as a zero-sum game with two players, namely a malicious adversary and a detector. Given a protected performance vertex, we consider a detector, with uncertain system knowledge, that selects another vertex on which to place a sensor and monitors its output with the aim of detecting the presence of the adversary. On the other hand, the adversary, also with uncertain system knowledge, chooses a single vertex and conducts a cyber-attack on its input. The purpose of the adversary is to drive the attack vertex as to maximally disrupt the protected performance vertex while remaining undetected by the detector. As our first contribution, the game payoff of the above-defined zero-sum game is formulated in terms of the Value-at-Risk of the adversary’s impact. However, this game payoff corresponds to an intractable optimization problem. To tackle the problem, we adopt the scenario approach to approximately compute the game payoff. Then, the optimal monitor selection is determined by analyzing the equilibrium of the zero-sum game. The proposed approach is illustrated via a numerical example of a 10-vertex networked control system. +
        +
        + + + +
        +
        +
        @inproceedings{NguyenCDC2022,
        +  address = {},
        +  author = {Nguyen, A. T. and Anand, S. C. and Teixeira, A. M. H.},
        +  booktitle = {IEEE Conference on Decision and Control (CDC)},
        +  title = {A Zero-Sum Game Framework for Optimal Sensor Placement in Uncertain Networked Control Systems under Cyber-Attacks},
        +  year = {2022},
        +  doi = {10.1109/CDC51059.2022.9992468},
        +  tag = {10005}
        +}
        +
        +
        + + + + + + + +
        + +
      12. +
      13. + + + +
        + + +
        + “A Single-Adversary-Single-Detector Zero-Sum Game in Networked Control Systems”.
        + A. T. Nguyen, A. M. H. Teixeira, and A. Medvedev.
        + IFAC Conference on Networked Systems (NecSys), 2022
        + +
        + + + + + + ABS + + + + + + + + + + + + BIB + + + + + + +
        +
        + This paper proposes a game-theoretic approach to address the problem of optimal sensor placement for detecting cyber-attacks in networked control systems. The problem is formulated as a zero-sum game with two players, namely a malicious adversary and a detector. Given a protected target vertex, the detector places a sensor at a single vertex to monitor the system and detect the presence of the adversary. On the other hand, the adversary selects a single vertex through which to conduct a cyber-attack that maximally disrupts the target vertex while remaining undetected by the detector. As our first contribution, for a given pair of attack and monitor vertices and a known target vertex, the game payoff function is defined as the output-to-output gain of the respective system. Then, the paper characterizes the set of feasible actions by the detector that ensures bounded values of the game payoff. Finally, an algebraic sufficient condition is proposed to examine whether a given vertex belongs to the set of feasible monitor vertices. The optimal sensor placement is then determined by computing the mixed-strategy Nash equilibrium of the zero-sum game through linear programming. The approach is illustrated via a numerical example of a 10-vertex networked control system with a given target vertex. +
        +
        + + + +
        +
        +
        @inproceedings{NguyenNecsys2022,
        +  address = {},
        +  author = {Nguyen, A. T. and Teixeira, A. M. H. and Medvedev, A.},
        +  booktitle = {IFAC Conference on Networked Systems (NecSys)},
        +  title = {A Single-Adversary-Single-Detector Zero-Sum Game in Networked Control Systems},
        +  year = {2022},
        +  doi = {10.1016/j.ifacol.2022.07.234},
        +  tag = {10005},
        +}
        +
        +
        + + + + + + + +
        + +
      + +
      +
      +
      +
      +
      + +
      +
      + +

      + +

      Privacy of networked dynamical systems

      +

      Guaranteeing privacy in dynamical networks is particularly important in the pressing concern of privacy in distributed optimization scenarios common in machine learning and artificial intelligence. The intrinsic design of these networks traditionally depends on implicit trust among agents, raising significant privacy issues. We propose a novel approach that integrates control theory and optimization techniques to address these privacy concerns. Our approach aims to refine network architectures and communication protocols, ensuring that the privacy of individual agents is preserved while maintaining the efficacy of collective decision-making processes. This advancement in network design is poised to substantially improve the handling of privacy in dynamical networks, facilitating their reliable and private application in various settings.

      +

      Team members: André M. H. Teixeira, Sérgio Pequito

      +

      +

      +

      +
      +
      +
      + +
      1. + + + +
        + + +
        + “Privacy preserving average consensus through network augmentation”.
        + G. Ramos, A. P. Aguiar, S. Kar, and S. Pequito.
        + IEEE Trans. Automatic Control (Accepted), 2023
        + +
        + + + + + + + + + + + + + + + + BIB + + + + + + + + +
        +
        +
        @article{Ramos_TAC2024,
        +  author = {Ramos, G. and Aguiar, A. P. and Kar, Soummya and Pequito, S.},
        +  journal = {IEEE Trans. Automatic Control (Accepted)},
        +  title = {Privacy preserving average consensus through network augmentation},
        +  year = {2023},
        +  published = {1},
        +  tag = {10006}
        +}
        +
        +
        + + + + + + + +
        + +
      2. +
      3. + + + +
        + + +
        + “Designing communication networks for discrete-time consensus for performance and privacy guarantees”.
        + G. Ramos and S. Pequito.
        + Systems & Control Letters, vol. 180, p. 105608, 2023
        + +
        + + + + + + ABS + + + + + + + + + + + + BIB + + + + + + +
        +
        + Discrete-time consensus plays a key role in multi-agent systems and distributed protocols. Unfortunately, due to the self-loop dynamics of the agents (an agent’s current state depends only on its own immediately previous state, i.e., one time-step in the past), they often lack privacy guarantees. Therefore, in this paper, we propose a novel design that consists of a network augmentation, where each agent uses the previous iteration values and the newly received ones to increase the privacy guarantees. To formally evaluate the privacy of a network of agents, we define the concept of privacy index, which intuitively measures the minimum number of agents that should work in coalition to recover all the initial states. Moreover, we aim to explore if there is a trade-off between privacy and accuracy (rate of convergence) or if we can increase both. We unveil that, with the proposed method, we can design networks with higher privacy index and faster convergence rates. Remarkably, we further ensure that the network always reaches consensus even when the original network does not. Finally, we illustrate the proposed method with examples and present networks that lead to higher privacy levels and, in the majority of the cases, to faster consensus rates. +
        +
        + + + +
        +
        +
        @article{Ramos_CSL2024,
        +  author = {Ramos, G. and Pequito, S.},
        +  journal = {Systems & Control Letters},
        +  volume = {180},
        +  pages = {105608},
        +  year = {2023},
        +  title = {Designing communication networks for discrete-time consensus for performance and privacy guarantees},
        +  doi = {10.1016/j.sysconle.2023.105608},
        +  published = {1},
        +  tag = {10006}
        +}
        +
        +
        + + + + + + + +
        + +
      4. +
      5. + + + +
        + + +
        + “Privacy and Security in Network Controlled Systems via Dynamic Masking”.
        + M. Abdalmoaty, S. C. Anand, and A. M. H. Teixeira.
        + IFAC World Congress, 2023
        + +
        + + + + + + ABS + + + + + + + + + VID + + + + + BIB + + + + + + +
        +
        + In this paper, we propose a new architecture to enhance the privacy and security of networked control systems against malicious adversaries. We consider an adversary which first learns the system dynamics (privacy) using system identification techniques, and then performs a data injection attack (security). In particular, we consider an adversary conducting zero-dynamics attacks (ZDA) which maximizes the performance cost of the system whilst staying undetected. However, using the proposed architecture, we show that it is possible to (i) introduce significant bias in the system estimates of the adversary: thus providing privacy of the system parameters, and (ii) efficiently detect attacks when the adversary performs a ZDA using the identified system: thus providing security. Through numerical simulations, we illustrate the efficacy of the proposed architecture. +
        +
        + + + +
        +
        +
        @inproceedings{AbdalmoatyIFAC2023,
        +  address = {},
        +  author = {Abdalmoaty, M. and Anand, S. C. and Teixeira, A. M. H.},
        +  booktitle = {IFAC World Congress},
        +  title = {Privacy and Security in Network Controlled Systems via Dynamic Masking},
        +  year = {2023},
        +  video = {https://youtu.be/uuz5ppriWLk},
        +  tag = {10006}
        +}
        +
        +
        + + + + + + + +
        + +
      + +
      +
      +
      +
      +
      + +
      + +

       

      + +
      + +
      +
      + + + + + + + + + + diff --git a/team/index.html b/team/index.html new file mode 100644 index 00000000..2a21da3c --- /dev/null +++ b/team/index.html @@ -0,0 +1,565 @@ + + + + + + + + Secure Learning and Control Lab - Team + + + + + + + + + + + + + + + + + + +
      +
      +
      + + +

      Group Members

      + +

      We are looking for new PhD students, Postdocs, and Master students to join the team (see openings) !

      + +

      Jump to staff, master and bachelor students. +

      + +

      Staff

      + +
      + +
      +

      + +
      +

      André Teixeira

      +

      Associate Professor, Lab Director

      + +

      André Teixeira is an Associate Professor at the Division of Systems and Control, Department of Information Technology, Uppsala University, Sweden. He received the M.Sc. degree in electrical and computer engineering from the Faculdade de Engenharia da Universidade do Porto, Porto, Portugal, in 2009, and the Ph. D. degree in automatic control from the KTH Royal Institute of Technology, Stockholm, Sweden, in 2014. From 2014 to 2015, he was a Postdoctoral Researcher at the Department of Automatic Control, KTH Royal Institute of Technology, Stockholm, Sweden. From October 2015 to August 2017, Teixeira was an Assistant Professor in Cybersecurity of Critical Infrastructures at the Faculty of Technology, Policy and Management, Delft University of Technology, The Netherlands. From September 2017 to April 2021, he was an Assistant Professor at the Department of Electrical Engineering at Uppsala University. Teixeira was a recipient for the Best Student-Paper Award from the IEEE Multi-Conference on Systems and Control in 2014, and an Honorable Mention for the Paul M. Frank Award at the IFAC SAFEPROCESS 2018. He was awarded a Starting Grant by the Swedish Research Council in 2018, and he is among the 20 young researchers in Sweden who received the Future Research Leaders 7 grant by the Swedish Foundation for Strategic Research in 2020. He was awarded the Lilly and Sven Thuréus prize in 2023 by The Royal Society of Sciences at Uppsala. In 2023, André was appointed as a Wallenberg Academy Fellow by the Knut and Alice Wallenberg Foundation.

      +
      + +

      +

      + +
      + +
      + +
      + +
      +

      + +
      +

      Sergio Pequito

      +

      Associate Professor

      + +

      Sérgio Pequito is an associate professor in automatic control in the Department of Information Technology, at Uppsala University. Pequito’s research consists of understanding the global qualitative behavior of large-scale systems from their structural or parametric descriptions and provides a rigorous framework for the design, analysis, optimization, and control of large-scale systems. His interests span neuroscience and biomedicine, where dynamical systems and control theoretic tools can be leveraged to develop new analysis tools for brain dynamics toward effective personalized medicine and improve bidirectional interfaces. Pequito was awarded the best student paper finalist in the 48th IEEE Conference on Decision and Control (2009) and the 2016 O. Hugo Schuck Award in the Theory Category by the American Automatic Control Council.

      +
      + +

      +

      + +
      + +
      + +
      + +
      +

      + +
      +

      Salman Toor

      +

      Associate Professor

      + +

      Salman Toor is an Associate Professor at the Division of Scientific Computing, Department of Information Technology, Uppsala University, Sweden. He earned his Masters and PhD in Scientific Computing from Uppsala University. In 2014, Toor finished his postdoctoral research from CMS program, Helsinki Institute of Physics, Finland. His area of expertise includes management, scalability and performance of distributed infrastructures for scientific applications. Toor is an active member of Distributed Computing Applications (DCA) group at Uppsala University. From 2015-2017, Toor was employed as a researcher in the Department of Information Technology, Uppsala University and as a senior cloud architect at Swedish National Infrastructure for Computing (SNIC). His research focuses on Distributed Computing Infrastructures.

      +
      + +

      +

      + +
      + +
      + +
      + +
      +

      + +
      +

      Torbjörn Wigren

      +

      Guest Researcher

      + +

      Torbjörn Wigren is a Guest Researcher at the Division of Systems and Control, Department of Information Technology, Uppsala University, Sweden. He received the M.Sc. degree in engineering physics (electrical engineering) in 1985, and the Dr. of Technology degree in automatic control in 1990, both from Uppsala University, Uppsala Sweden. His main employer from 2001 is Ericsson AB, where he is a Principal Developer, responsible for R&D on radio near feedback control and signal processing algorithms for 5G and 6G cellular systems. Before joining Ericsson, he held positions with Bofors Aerotronics (1985-1991), Ericsson Radio Systems (1991-1995) and Celsius Tech Systems (1995-2001) where he was involved in development of fire control systems, audio signal processing, and passive air-target tracking. During 2000 - 2018 he was Adjunct Professor of Automatic Control at Uppsala University. His research is focused on nonlinear dynamic systems, including recursive identification, optimal control and estimation, as well as on the use of feedback principles in machine learning.

      +
      + +

      +

      + +
      + +
      + +
      + +
      +

      + +
      +

      Per Mattsson

      +

      Associate Professor

      + +

      Per Mattsson is an Associate Professor in automatic control in the Department of Information Technology at Uppsala University. He received his Ph.D. degree in automatic control and system identification from Uppsala University in 2016. Mattsson’s research focuses on the development and analysis of data-driven methods for modeling, control, and predictive maintenance.

      +
      + +

      +

      + +
      + +
      + +
      + +
      +

      + +
      +

      Ruslan Seifullaev

      +

      Postdoc, started August 2023

      + +

      Ruslan Seifullaev is a Postdoctoral Researcher at the Division of Systems and Control, Department of Information Technology, Uppsala University, Sweden. He received the Diploma (M.Sc.) degree in theoretical cybernetics and the Candidate of Science (Ph.D.) degree in discrete mathematics and mathematical cybernetics from St. Petersburg University in 2012 and 2016, respectively. From 2014 to 2018, he was employed as a Research Engineer at the Institute of Problems in Mechanical Engineering of Russian Academy of Sciences. In 2023, he received the Ph.D. degree in signal processing from the Division of Signals and Systems, Uppsala University. His research interests include nonlinear control theory, time-delay systems, and networked control systems.

      +
      + +

      +

      + +
      + +
      + +
      + +
      +

      + +
      +

      Daniel Arnström

      +

      Postdoc, started August 2023

      + +

      Daniel Arnström is a Postdoc at the Division of Systems and Control, Department of Information Technology, Uppsala University, Sweden. He received the Ph.D in automatic control from Linköping University, Sweden, in 2023. Previously, he had received M.Sc and Licentiate degrees from Linköping University in 2018 and 2021, respectively. At the 22nd World Congress of the International Federation of Automatic Control (IFAC) he was awarded the Young Author Prize (YAP) for his work on embedded optimization solvers. His research interests include reliable embedded optimization and reliable real-time Model Predictive Control (MPC); for reliability, his research interests include computational, safety, and security aspects.

      +
      + +

      +

      + +
      + +
      + +
      + +
      +

      + +
      +

      Alain Govaert

      +

      Postdoc, started September 2023

      + +

      Alain Govaert is a Postdoctoral researcher at the Division of Systems and Control, Department of Information Technology, Uppsala University, Sweden. He received the M.Sc. degree in Industrial Engineering and the Ph.D. degree in automatic control from the Faculty of Sciences at University of Groningen in the Netherlands in 2015 and 2020, respectively. His research interests include complex systems theory, game theory, random graphs, and control systems.

      +
      + +

      +

      + +
      + +
      + +
      + +
      +

      + +
      +

      Jingwei Dong

      +

      Postdoc, started January 2024

      + +

      Jingwei Dong is a Postdoctoral Researcher at the Division of Systems and Control, Department of Information Technology, Uppsala University, Sweden. He received the M. Eng degree in Control Science and Engineering from Harbin Institute of Technology, China, in 2018, and the Ph.D. degree in Systems and Control from Delft Center for Systems and Control, TU Delft, The Netherlands, in 2023. His research interests include optimization-based fault diagnosis, security of cyber-physical systems, control theory, and optimization methods.

      +
      + +

      +

      + +
      + +
      + +
      + +
      +

      + +
      +

      Sribalaji C. Anand

      +

      Ph.D. student, started August 2019

      + +

      Sribalaji C. Anand is a Ph.D. student specializing in Automatic Control, at the Division of Signals and Systems, Department of Electrical Engineering, Uppsala University, Sweden. He works under the supervision of Dr. André Teixeira and Prof. Anders Ahlén. His research interests include optimization, Security of cyber-physical systems, Adaptive control. He received his M.Sc. degree in systems and control from the Delft Centre for Systems and Control (DCSC), TU Delft, the Netherlands in 2017. From 2016 to 2017, he was a research assistant at the Robotics Research Centre, International Institute of Information Technology (IIIT), Hyderabad, India. He received his Bachelor’s degree in Mechatronics from SASTRA University, India. He was the recipient of the Dean’s lister merit scholarship award for the years 2012 to 2016.

      +
      + +

      +

      + +
      + +
      + +
      + +
      +

      + +
      +

      Fatih Emre Tosun

      +

      Ph.D. student, started October 2019

      + +

      Fatih Emre Tosun received the B.S. and M.S. degrees in mechatronics engineering from Sabancı University, Istanbul, Turkey, in 2015 and 2019, respectively. He is currently working toward the Ph.D. degree in electrical engineering with Uppsala University, Uppsala, Sweden.,He conducted research in system design and control for physical human–robot interaction and series elastic actuation. His current research interests include secure and resilient control systems.

      +
      + +

      +

      + +
      + +
      + +
      + +
      +

      + +
      +

      Anh Tung Nguyen

      +

      Ph.D. student, started May 2021

      + +

      Anh Tung Nguyen is a Ph.D. student at the Division of Systems and Control, Department of Information Technology, Uppsala University, Sweden. He was born in 1995, Hanoi city, the capital of Vietnam. He received the Degree of Engineer in Automatic Control (5-year Talent program) from the Department of Automatic Control, School of Electrical Engineering, Hanoi University of Science and Technology, Hanoi, Vietnam in 2018. In 2017, he was selected as Top 10 Young Engineer and Scientist Award granted by the Honda Foundation. He was a visiting student at the WPI International Institute for Carbon-Neutral Energy Research, Kyushu University, Fukuoka, Japan from September to December 2018. From 2019 to 2021, he was a research assistant at the Guidance, Navigation, and Control Laboratory, Sejong University, Seoul, Korea. He received the Degree of Master of Engineering in Aerospace Engineering from the Department of Aerospace Engineering, Sejong University, Seoul, Korea in 2021. His research interests include control theory, multi-agent systems, and cyber-physical security.

      +
      + +

      +

      + +
      + +
      + +
      + +
      +

      + +
      +

      Zhenlu Sun

      +

      Ph.D. student, started October 2022

      + +

      Zhenlu Sun is a Ph.D. student at the Division of Scientific Computing, Department of Information Technology, Uppsala University, Sweden. He received the Bachelor’s Degree in Measurement and Control Technology and Instrument from Shanghai Maritime University, Shanghai, China. He received the Master’s Degree in Control Science and Engineering from Beijing Institute of Technology, Beijing, China. Zhenlu worked at Intel China for three years, focusing on design and development of cloud computing and edge computing under the 5G telecom context. Before joining Intel, he was a software engineer at Cadence Design Systems from 2017 to 2019, focusing on development of EDA software toolkit. He is conducting research in cybersecurity and machine learning for critical infrastructures under the supervision of Prof. Salman Toor and Prof. André Teixeira. His research interests include security and privacy, distributed computing, machine learning and 5G telecom technologies.

      +
      + +

      +

      + +
      + +
      + +
      + +
      +

      + +
      +

      Usama Zafar

      +

      Ph.D. student, started February 2023

      + +

      Usama Zafar is a Ph.D. student at the Division of Scientific Computing, Department of Information Technology, Uppsala University, Sweden. He received his Bachelor’s Degree in Computer Software Engineering from National University of Sciences and Technology (NUST), Islamabad, Pakistan. He completed his Master’s Degree in Advanced Computing Science from Tsinghua University, Beijing, China. Usama has worked at Netsol Technologies for two years, focusing on research and development of FinTech products. He is currently conducting research in secure federated machine learning under the supervision of Prof. Salman Toor and Prof. André Teixeira. His research interests include distributed computing, security and privacy, distributed and federated machine learning.

      +
      + +

      +

      + +
      + +
      + +
      + +
      +

      + +
      +

      Lovisa Eriksson

      +

      Ph.D. student, started August 2023

      + +

      Lovisa Eriksson is a Ph.D. student at the Division of Systems and Control, Department of Information Technology, Uppsala University, Sweden. She works under the supervision of Prof. André Teixiera and Prof. Dave Zachariah. Her research interests include machine learning, security and privacy, and decision theory. She earned her B.S.s degree in Mathematics 2021, and her M.S.s degree in Data Science 2023, both from Uppsala University.

      +
      + +

      +

      + +
      + +
      + +

      Master and Bachelor Students

      + +
      + +
      +

      Andreas Hertzberg,

      +

      Master student, Spring 2024 - “Secure Multi-Agent Control Systems”

      +
        + + + + + + + + + +
      +
      + +
      +

      Linus Svensson,

      +

      Master student, Spring 2023 - “Modelling of cyber-physical security for an automotive battery control system”

      +
        + + + + + + + + + +
      +
      + +
      + +
      + +
      +

      Karl Walletin,

      +

      Master student, Spring 2022 - “Implementation and evaluation of digital signal watermarking for control systems”

      +
        + + + + + + + + + +
      +
      + +
      + +

      Alumni

      + +
      + +
      +

      +

      Mohamed Abdalmoaty

      +

      2021 - 2023
      Role: Postdoc

      (Postdoc at ETH Zurich from 2023)
      ORCID: 0000-0001-5474-7060

      +
        + +
      +
      + +
      + +

      Former visitors, BSc/MSc students

      +
      + + + +
      +

      Master students

      + +

      Duc Huy Le, +Master student, Spring 2023 - “Exploration-Exploitation Trade-off Approaches in Multi-Armed Bandit”

      + +

      Teja Kedar Vaddehulgesh, +Master student, Spring 2023 - “Evaluation of Cyber-Attacks in Networked Control Systems”

      + +

      Ankit Khandeparkar, +Master student, Spring 2023 - “Embedded Control of a Rotary Inverted Pendulum”

      + +

      Rana Faheem Iftikhar, +Master student, Spring 2023 - “Fault Tolerant Stabilizability in Multihop Control Networks”

      + +

      Benjamin Bucknall, +Master student, Spring 2022 - “Promoting Exploration in Reinforcement Learning through Surprise-Based Intrinsic Motivation”

      + +

      Oscar Larsson, +Master student, Spring 2022 - “Generation and Detection of Adversarial Attacks in the Power Grid”

      + +
      + + + +
      + + +
      + +
      +
      + + + + + + + + + +