Files
Upsilon/apps/probability/app.h
circuit10 b44a95a9b3 Casio fx-CG series port (#324)
* Initial test - working on Linux

* Try to make it work with liba

* Stop using liba and the filesystem

* IT WORKS

* Key input, full res, fix some of the crashes

* Fix the hang when doing calculations

* Add some more key mappings

* Fix the square root issue

* Icons

* Better key mappings, brightness control, better gamma correction, more effficient framebuffer

* Cleanup stage 1

* Cleanup stage 2

* Make the build system build a g3a

* Make it not exit when you press the menu button

* Add Casio port to README

* Use omega-master instead of omega-dev

* Fix mistake with cherry-picking in the README

* Fix internal storage crash

* Fix compile error on Numworks calculators

* Upsilon branding

* Sharper icon

* Make the CI work

* Add power off and improve menu

* Map Alpha + up/down to the brightness shortcut

* Add missing file

* Fix web CI build

* Revert "Fix web CI build"

This reverts commit f19657d9fc.

* Change "prizm" to "fxcg"

* Add FASTLOAD option for Add-in Push

* Add some charatcers to the catalog on Casio and improve key mappings

* Build with -Os -flto

* Disable LTO for now as it's causing crashes

* Put back the fonts I accidently changed

I'd like to add an option for this though as I prefer the ones from Epsilon
2023-05-10 18:28:18 +02:00

89 lines
3.4 KiB
C++

#ifndef PROBABILITY_PROBABILITY_APP_H
#define PROBABILITY_PROBABILITY_APP_H
#include <escher.h>
#include "distribution_controller.h"
#include "calculation_controller.h"
#include "parameters_controller.h"
#include "../shared/text_field_delegate_app.h"
#include "distribution/binomial_distribution.h"
#include "distribution/exponential_distribution.h"
#include "distribution/normal_distribution.h"
#include "distribution/poisson_distribution.h"
#include "distribution/uniform_distribution.h"
#include "calculation/left_integral_calculation.h"
#include "calculation/right_integral_calculation.h"
#include "calculation/finite_integral_calculation.h"
#include "../shared/shared_app.h"
constexpr static size_t max(const int * data, int seed = 0) {
return (*data == 0 ? seed : max(data+1, *data > seed ? *data : seed));
}
namespace Probability {
class App : public Shared::TextFieldDelegateApp {
public:
class Descriptor : public ::App::Descriptor {
public:
I18n::Message name() override;
I18n::Message upperName() override;
App::Descriptor::ExaminationLevel examinationLevel() override;
const Image * icon() override;
};
class Snapshot : public ::SharedApp::Snapshot {
public:
enum class Page {
Distribution,
Parameters,
Calculations
};
Snapshot();
~Snapshot();
App * unpack(Container * container) override;
Descriptor * descriptor() override;
void reset() override;
Distribution * distribution();
Calculation * calculation();
Page activePage();
void setActivePage(Page activePage);
private:
constexpr static int k_distributionSizes[] = {sizeof(BinomialDistribution),sizeof(ExponentialDistribution), sizeof(NormalDistribution), sizeof(PoissonDistribution), sizeof(UniformDistribution), 0};
constexpr static size_t k_distributionSize = max(k_distributionSizes);
constexpr static int k_calculationSizes[] = {sizeof(LeftIntegralCalculation),sizeof(FiniteIntegralCalculation), sizeof(RightIntegralCalculation), 0};
constexpr static size_t k_calculationSize = max(k_calculationSizes);
void deleteDistributionAndCalculation();
void initializeDistributionAndCalculation();
#if (defined __EMSCRIPTEN__) || (defined _FXCG)
constexpr static int k_distributionAlignments[] = {alignof(BinomialDistribution),alignof(ExponentialDistribution), alignof(NormalDistribution), alignof(PoissonDistribution), alignof(UniformDistribution), 0};
constexpr static size_t k_distributionAlignment = max(k_distributionAlignments);
constexpr static int k_calculationAlignments[] = {alignof(LeftIntegralCalculation),alignof(FiniteIntegralCalculation), alignof(RightIntegralCalculation), 0};
constexpr static size_t k_calculationAlignment = max(k_calculationAlignments);
alignas(k_distributionAlignment) char m_distribution[k_distributionSize];
alignas(k_calculationAlignment) char m_calculation[k_calculationSize];
#else
char m_distribution[k_distributionSize];
char m_calculation[k_calculationSize];
#endif
Page m_activePage;
};
static App * app() {
return static_cast<App *>(Container::activeApp());
}
Snapshot * snapshot() const { return static_cast<Snapshot *>(::App::snapshot()); }
TELEMETRY_ID("Probability");
private:
App(Snapshot * snapshot);
CalculationController m_calculationController;
ParametersController m_parametersController;
DistributionController m_distributionController;
StackViewController m_stackViewController;
};
}
#endif