Sin descripción

anfractuosity 665600a614 Bump version hace 1 año
.github 7f8318652e Create FUNDING.yml hace 2 años
docs 34787516d3 Update changelog and readme hace 1 año
icons 77ee1e9357 Play and pause icons hace 2 años
photos ba06c88ac7 Processing captures hace 2 años
scenes 519832c75d Update about screen with version hace 1 año
screenshots b184cc95b1 Screenshots hace 2 años
README.md ba06c88ac7 Processing captures hace 2 años
application.fam 665600a614 Bump version hace 1 año
scope.c 15eef4b609 Simple FFT spectrum analyser hace 1 año
scope_10px.png e3ff8565e4 Initial scope app hace 3 años
scope_app_i.h 15eef4b609 Simple FFT spectrum analyser hace 1 año

README.md

flipperscope

To compile and install

cd flipperzero-firmware/applications_user
git clone https://github.com/anfractuosity/flipperscope.git
cd ..
./fbt DEBUG=1 VERBOSE=1 fap_scope
./fbt launch_app APPSRC=applications_user/flipperscope

Alternatively the binary can now be installed from https://lab.flipper.net/apps/flipperscope or the Flipper Mobile App.

Provide signal to pin 16/PC0, with a voltage ranging from 0V to 2.5V and ground to pin 18/GND.

Press the 'ok' button (button in the centre of joypad) to pause/unpause the waveform display.

Demo showing three different waveform types from a signal generator.

Also see Derek Jamison's demonstration of this app as well as other interesting projects.

Measurements

  • Measures frequency of waveform in hertz
  • Measures voltage: min, max, Vpp

Signal Generator

Flipper Zero running flipperscope

Rigol

Flipper Zero running flipperscope

Processing captures

You can use the following simple Python script, for processing the captured waveforms, from flipperscope.

import matplotlib.pyplot as plt
import numpy as np
import struct

fig, ax = plt.subplots()
data = open("Sine.dat", "rb").read()
y = [(float(x[0]) / 2500) * 2.5 for x in struct.iter_unpack("<H", data)]
x = np.arange(len(y))

ax.plot(x, y, label='Voltage')
ax.set_xlabel('Sample')
ax.set_ylabel('Voltage / V')
ax.set_title('ADC Voltage')
ax.set_ylim([0, 2.5])
ax.legend()
plt.show()

Captured waveform

To Do

  • Customisable input pin
  • Trigger type mode
  • FFT
  • ...

Inspiration