Skip to main content

No project description provided

Project description

SWOOPS Optimization GUI

Setup, Workflows, Orchestrate, Optimize, Plot, Surrogates

Author: Jason Krist

Date: October 1st, 2025

Description

SWOOPS is an in-progress Graphical User Interface (GUI) designed for parametric optimization. Each letter of SWOOPS stands for a feature set that is within the scope of the tool. Swoops are also the name for the bats in super mario, hence the mascot for the tool is a swoop named Zippy, which is an homage to the Microsoft Office Assistance Clippy.

Table of Contents

  1. Why Create Swoops?
  2. Core Tenets
  3. Feature Sets
  4. Architectural Choices
  5. Target Uses
  6. Install
  7. Usage (Incomplete)
  8. Roadmap

Why Create Swoops?

SWOOPS is a culmination of everything I want in an optimization GUI. Below are my grievances with the state of current optimization interfaces:

  • COTS (Commercial Off The Shelf) tools are expensive, lack necessary configurability, and prioritize supporting tools within their own ecosystem
  • COTS tools have architectures which make interoperability with open source optimization frameworks difficult
  • Open source frameworks have little to no GUIs, with DAKOTA being the exception
  • Custom tools have high tech debt and steep learning curves
  • Unfriendly user experience across the board

Therefore, I have developed SWOOPS with the "Core Tenets" below in mind.

Table of Contents

Core Tenets

  1. Democratize Optimization
  2. Prioritize User Experience
  3. Seamless Automation
  4. Free and Open Source Core Program
  5. Modularity is a Must
  6. Encourage Community Collaboration
  7. Make Lasting Contributions

Table of Contents

Feature Sets

  1. Setup - prepare files or processes for optimization, which includes file parsers and workflow templates
  2. Workflows - specify tasks, inputs, outputs, and dependencies of a workflow
  3. Orchestrate - export and execute a workflow. See progress as it completes
  4. Optimize - specify constraints, objectives, algorithms, and check ongoing optimization progress
  5. Plot - create user-defined plots from existing data sets or optimization results
  6. Surrogates - create and test surrogate models for utilizing in multi-fidelity optimization

Table of Contents

Architectural Choices

  • Written in Python due to the breadth of experience for develops in this field, and because it is the language of choice for existing frameworks
  • Primarily target desktop platform for architectural simplicity
  • QT (Pyside6) chosen for being the most robust, feature rich, and cross-platform Desktop GUI Framework in Python

Table of Contents

Target Uses

  • Generic workflow automation
  • DOE (Design of Experiments) and analyzing interaction effects
  • Early conceptual design optimization with derivatives and tightly coupled variables
  • Gradient free, multi-fidelity optimization for design tuning
  • Multi-objective optimization for pareto optimal solutions

Table of Contents

Install

pip install swoops

Table of Contents

Usage (Incomplete)

python test_app.py

Dark Mode

Light Mode

Video Test

Add more GUI usage steps and images here.

Python In-Line Usage (Incomplete)

Probably don't need this section.

Command Line Usage (Incomplete)

swoops [-h] [-file FILE] [-b]

Table of Contents

Roadmap

Complete

  1. Backend data structures which can represent most optimization setups
  2. Widgets
    1. Docked windows - each widget is nested in a dockable window
    2. Tree View - visualize nested data structures or file system
    3. Edit Window - visualize and edit all attributes of a data structure
    4. Table View - visualize and edit a large set of entities and their attributes in a table
    5. Web View - load local HTML files (Plotly, N2 Diagram) or online web pages
    6. Plot View - load interactive Matplotlib plots
    7. Python Code Editor - text edit python scripts
  3. Undoablility for Data Structure and Widget related changes (new, delete, edit)
  4. Tabs which can contain different widgets and layouts
  5. Rudimentary export script for swoops data structures to GEMSEO optimization format

In Progress

  1. Block Diagram Viewer - visualize Workflow, Dependencies, and data flow
  2. Get App fully functional for simple demos. This encompasses many small To-Do's
  3. Python Command Window - run python commands in-session and see results

Future Plans

  1. File Parser for defining variable locations in input or output files
  2. Workflow "Templates" can be created with Empty values which are highlighted to user to complete
  3. Create a "Library" of common tasks with drag-and-drop functionality
  4. User-friendly, Documented Python API
  5. Custom optimization orchestrator with modular optimizer interface
  6. "Zippy" button opens a helper overlay for tutorials and trainings
  7. Out-of-the-Box interoperability with GEMSEO, OpenMDAO, and Pymoo. Potentially work on supporting Philote, CSDL, and SUAVE.

Table of Contents

Read The Docs (Incomplete)

Download "docs" folder or check preview.

Contributing

Message me on Github.

License

GNU GPLv3

Copyright:

(c) 2025, Jason Krist

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

swoops-0.0.6.tar.gz (20.1 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

swoops-0.0.6-py3-none-any.whl (16.8 kB view details)

Uploaded Python 3

File details

Details for the file swoops-0.0.6.tar.gz.

File metadata

  • Download URL: swoops-0.0.6.tar.gz
  • Upload date:
  • Size: 20.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.12.0

File hashes

Hashes for swoops-0.0.6.tar.gz
Algorithm Hash digest
SHA256 bc34313a1df6d608c4013fcc880490de545d5219a5e443c5f5327d8e750daef2
MD5 c429c45414a34457b742ab3b71be5c1e
BLAKE2b-256 f74d45d4c021c7fdee3dee8d06b1ed9d2111c8f7f7e9480ab2a7b7ccca1b1ee2

See more details on using hashes here.

File details

Details for the file swoops-0.0.6-py3-none-any.whl.

File metadata

  • Download URL: swoops-0.0.6-py3-none-any.whl
  • Upload date:
  • Size: 16.8 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.12.0

File hashes

Hashes for swoops-0.0.6-py3-none-any.whl
Algorithm Hash digest
SHA256 df3e78e958e278f4567479b15f3df43bb366c62158b04ba14d690f701b90d86d
MD5 e74e3235b33a162d6d67d57857b73996
BLAKE2b-256 4e486518d61e5c1021de2411850659af21e9c2441404a3a0c6706f7eea6c1ee4

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page