Scientific Computing

CTest parallel run by default

CMake environment variable CTEST_PARALLEL_LEVEL controls default test parallellism to save test run wallclock time. CTEST_PARALLEL_LEVEL=0 uses unbounded test parallelism. If the computer runs out of memory or has conflicts with parallel tests, use fixtures and resource locks to control test run parallelism on a per-test basis.

CTest parallel somewhat randomizes the order of the tests. ctest –schedule-random randomizes the order of tests even for serial test runs.

This example run on a 4-core machine shows that no extra command line parameters are needed to use CTEST_PARALLEL_LEVEL:

CMakeLists.txt:

cmake_minimum_required(VERSION 3.12)

project(par LANGUAGES NONE)

enable_testing()

message(STATUS "ENV{CTEST_PARALLEL_LEVEL}: $ENV{CTEST_PARALLEL_LEVEL}")

foreach(t RANGE 8)
  add_test(NAME sleep${t} COMMAND ${CMAKE_COMMAND} -E sleep 1)
endforeach()
export CTEST_PARALLEL_LEVEL=0

ctest --test-dir build

or

ctest --test-dir build --parallel
Internal ctest changing into directory: C:/temp/build
Test project C:/temp/build
    Start 2: sleep1
    Start 5: sleep4
    Start 3: sleep2
    Start 7: sleep6
1/8 Test #5: sleep4 ...........................   Passed    1.05 sec
    Start 6: sleep5
2/8 Test #7: sleep6 ...........................   Passed    1.04 sec
    Start 1: sleep0
3/8 Test #2: sleep1 ...........................   Passed    1.06 sec
    Start 8: sleep7
4/8 Test #3: sleep2 ...........................   Passed    1.06 sec
    Start 4: sleep3
5/8 Test #1: sleep0 ...........................   Passed    1.06 sec
6/8 Test #6: sleep5 ...........................   Passed    1.06 sec
7/8 Test #8: sleep7 ...........................   Passed    1.05 sec
8/8 Test #4: sleep3 ...........................   Passed    1.05 sec

100% tests passed, 0 tests failed out of 8

Total Test time (real) =   2.14 sec

X11 on macOS

X11 can be accessed using XQuartz as available via Homebrew.

brew install libx11 xquartz

To finish the one-time setup of XQuartz, logout/login or reboot. Check that X11 server is available by

echo $DISPLAY

which should show a temporary directory ending like “org.xquartz:0”.

Demo and troubleshooting

See that X11 is working with the classic Xeyes test GUI.

xeyes

A useful image browsing program on Linux, macOS etc. is feh:

brew install feh

Troubleshooting: XQuartz GitHub Issues

Specifically, be sure XQuartz is enabled in Login Items to fix problems like the XQuartz window won’t open.

XQuartz will open automatically when any X11 program is started.


Related: PulseAudio on macOS

macOS power-off USB sleep

By default, macOS keeps USB ports constantly providing power while in sleep mode, which can run down the laptop battery if a USB device such as a docking station is plugged in without a power adapter. pmset macOS command utility can set USB ports to power-off when the lid is closed. This works by putting the laptop into hibernate mode, which makes the laptop wake up a few seconds slower than the standard sleep.

Get current power settings:

pmset -g

Note the “hibernatemode” value.

  • 3: sleep mode with power on to USB ports.
  • 25: DeepSleep hibernate, which powers off USB ports.
pmset -a hibernatemode 25

Test this by pushing the power button or closing the laptop lid. Wait a minute to see if the USB device loses power. A USB power analyzer (volt meter) can be used to check the USB port power as well.

10 meter AM / FM calling frequency

The 10 meter ham radio band has a suggested FM calling frequency of 29.6 MHz, which is nestled among the repeater frequencies. With a dedicated 10 meter FM band antenna tuned for the 29.5 - 29.7 MHz range, this works fine. However, many 10 meter operators primarily use CW, data, SSB, and similar modes in the 28.0 - 28.5 MHz range. Most popular 10m antennas such as a dipole antenna or 1/4 wavelength vertical antenna tuned for say 28.3 MHz may have an excessively high SWR at 29.6 MHz. Operators using inexpensive converted 27 MHz CB radios may not be able to tune the non-5kHz offset channel. That is, they might be able to tune to 29.605 MHz, but not 29.600 MHz.

The 10m AM mode calling frequency is generally 29.0 MHz, which is much closer to the 28 MHz SSB/CW frequencies. This allows more efficient use of the same antenna for both 10m SSB/CW and AM. An AM channel offset as much as 5 kHz can generally still be heard by another AM receiver, but with reduced signal efficiency. 10 kHz AM channel spacing is generally adequate for AM radios (as observed by CB radio channel plans and MW AM broadcast plans).

It is worth considering a “new” FM calling frequency near but just above 29 MHz with a 5 kHz offset to address using inexpensive converted CB radios and more optimally using the same antenna as for 28 MHz SSB/CW. We suggest considering 29.055 MHz as a new 10 meter FM calling frequency. This is far enough away from the AM calling frequency of 29.0 MHz and typically working frequencies just above 29.0 MHz.

In this table, the “converted CB channel” assumes common export radio channel charts. The specific radio may have a different channel number for the same frequency. We’ve put in a possible “new” AM calling frequency of 29.005 MHz for converted CB radios, if such would be desired. The jump in channel sequencing from channels 23, 24, 25 is a de facto standard.

frequency (MHz) mode description converted CB channel
29.000 AM 10 meter AM calling frequency
29.005 AM AM calling freq. for converted CB radios 20
29.015 AM AM working frequency 1 21
29.025 AM AM working frequency 2 22
29.035 FM FM working frequency 1 24
29.045 FM FM working frequency 2 25
29.055 FM 10 meter FM calling frequency 23

CB Radio 11 meter DX

In 2017, WT Docket 10-119 modernized FCC 27 MHz (11 meter) CB Radio Rules as published in the Federal Register, including replacing 95.333 and 95.933. The obsolete Part 95.413 rule limiting legal CB radio communications to 250 km was removed.

CB Radio rules do not specify a maximum range for CB radio communications, as long as the other station is in the United States or Canada. Therefore, “DX”, two-way long distance communication typically using non-groundwave propagation such as skywave, meteor scatter, etc. is legal for USA CB radio operators with other CB radio stations in the United States and Canada.

At dusk/dawn, a form of skywave propagation known as greyline propagation can occur, allowing strong signals between distant stations within the same dawn/dusk region as seen on this live map. If propagation is enhanced but no station is transmitting on the frequency one is listening to, the propagation enhancement is not noticed. Like on other frequency bands, listening for known transmitters is a useful DX detection technique in the 11 meter band. For example, Broadcast Auxiliary Remote Stations (STL) can be heard around 26 MHz. 27.025 MHz CB radio channel 6 in the AM mode is a common frequency for CB DX. The 12 meter and 10 meter NCDXF beacons provide another source of live propagation detection, especially for seeing if the MUF is near the 11 meter band. The UK CADS and Ireland WPAS 11 meter community service broadcasts overlap with some traditional CB radio frequencies.

International DX groups may use calling frequencies including SSB 26.285 MHz, FM 26.805 MHz, and SSB 27.555 MHz, but these frequencies are generally not legal to transmit on.

Cleanup unused files in Linux

Keep at least 10% of drive space to avoid:

  • SSD wear
  • HDD fragmentation

Determine free space on Linux / macOS / Windows Subsystem for Linux with " ncdu. ncdu uses Ncurses terminal graphics to quickly show the biggest files in the Linux filesystem tree. ncdu is very handy to find large files or directories that may be unneeded.

df -h

gives a drive-level summary of disk usage.

Package managers cache installed files in case of need to reinstall, but the packages can be redownloaded if needed to save disk space by clearing the cache. Clear the package cache–for APT (common in Debian-based systems):

apt autoclean

or for DNF (Fedora, RHEL, CentOS):

dnf clean dbcache

Remove unwanted packages

TeX Live documentation can consume a lot of disk space. To cleanup the documentation, consider removing packages matching texlive-*doc. This also removes texlive-full but with no detriment to TeX Live working.

Synaptic list of files to remove for texlive-doc to save disk space

Packages removed for texlive-doc to save over 1 GB of disk space.


Related:

CMake FindOpenSSL hints

For all CMake find_*() commands including FindOpenSSL, the package path can be hinted by setting an appropriate environment variable or CMake variable. This examples supposes a Homebrew package manager has installed OpenSSL, which the user wishes to use in a CMake project. To hint the package path when configuring a CMake project, either specify OpenSSL_ROOT by environment variable:

export OpenSSL_ROOT=$(brew --prefix openssl)

or directly in the CMake configure command:

cmake -B build -DOpenSSL_ROOT=$(brew --prefix openssl)

The example CMakeLists.txt:

cmake_minimum_required(VERSION 3.16)

project(f LANGUAGES NONE)

find_package(OpenSSL REQUIRED)

Use the –debug-find CMake option to see the paths CMake is searching.

To disable various search paths, consider the following CMake variables. These are normally only used for debugging or special cases.

set(CMAKE_FIND_USE_CMAKE_PATH false)
set(CMAKE_FIND_USE_CMAKE_SYSTEM_PATH false)
set(CMAKE_FIND_USE_CMAKE_ENVIRONMENT_PATH false)
set(CMAKE_FIND_USE_SYSTEM_ENVIRONMENT_PATH false)

Homebrew uses subdirectories to separate different versions of packages. CMake does not recursively search as that would in general not have a stopping condition and at least significantly slow down the search performance.

GitHub Actions Apple Silicon CPU

GitHub Actions macOS runners use Apple Silicon CPU, which is what most Apple users have. Some build issues including the linker have historically had Apple Silicon-specific issues. Generally it’s good to test on the same CPU architecture as the target platform.

We sometimes find it necessary to select the Xcode version compatible with Homebrew GCC if build errors occur that are not present on a physical Apple Silicon laptop.

jobs:

  mac:
    runs-on: macos-1atest

    strategy:
      matrix:
        cxx: [g++-14, clang++]

    env:
      HOMEBREW_NO_AUTO_CLEANUP: 1
      CXX: ${{ matrix.cxx }}

    steps:
    - uses: actions/checkout

    - run: sudo xcode-select --switch /Applications/Xcode_15.1.app

    - run: cmake --workflow --preset debug

    - run: cmake --workflow --preset release

In this example Ninja enables quick testing of builds in Debug and Release mode, which is important to catch bugs.

macOS WiFi BSSID scan

The undocumented, discontinued macOS command-line utility airport– not to be confused with the Airport Utility app–gave detailed information about the current WiFi connection and nearby WiFi APs. This utility was located at /System/Library/PrivateFrameworks/Apple80211.framework/Versions/Current/Resources/airport.

Since discontining airport, current BSSID requires using CoreWLAN framework as demonstrated in Python scan-wifi-python.

Apple provides a list of device WiFi support.