Showing 197 to 200

Eshell as gymnasium

Did you note how underpowered is Eshell out of the box? There are almost no premade commands above and beyond what we'd expect from any comint mode, even in em-extras or the ELPAs… we have to write the features we want ourselves!

As it is, Eshell (and shell-mode and other comint modes) has been special only to the minority of the Emacs community who hold a lot of skill in Elisp. For the rest, it's just a weird sort of alternative to their terminal emulator, with some ups and some downs.

Yet… it has the potential to do a lot for the newbie. If you approach it a certain way, it works as a stepping stone to general Emacs-fu. Terminal emulators have ruined our mindsets, and continuing to rely on the likes of ansi-term (or using shell-mode as if it was no different from a terminal)1 hinders developing effective ways to control your system, and as a consequence, hinders developing Emacs-fu too.

Priorities in our approach:

  • generalize skills
    • Why can I manipulate text in Eshell with grep, sort, uniq etc, but not outside Eshell? Unix tools like these live in silos.
      • Even with the lovely command objed-ipipe, I'm just carrying the Unix silo with me, which has to be set up akin to a trebuchet instead of integrating naturally with my work.
  • get out of the shell
    • Always try to find a way to do something that would work outside the shell too.
  • avoid memorizing redundant ways to do similar things

Consider the coreutils mostly obsolete (Never learn Bash):

  • We shouldn't need ls when we have dired
  • We shouldn't need cd when we have find-file
  • We shouldn't need grep when we have keep-lines/flush-lines
  • We shouldn't need find when we have multi-occur
  • and so on

Pretend you never learned the coreutils. How do you solve your next problem? There's usually a way, and it'll be a trick you can reuse!

My learning loop has been to solve a specific problem, then generalize it.

  • First I wrote a command my-copy-region-into-variable. Then I implemented automatic backreferences: the outputs of every shell command is automatically saved into an Emacs-global variable with no effort on my part.
  • First I wrote a command my-replace-path-at-point-with-truename. Then I wrote the more general my-cycle-path-at-point.
  • First I wrote a command my-replace-var-at-point-with-value which only looked up envvars like $DOOMDIR, extended it to fall back on Lisp vars if available, then realized that this is just crux-eval-and-replace plus envvars, so I instead extended that to also "eval-and-replace" envvars.
    • Then it turned out there's no reason to bind my custom version of crux-eval-and-replace to a key: instead, you can make it so that after every vanilla eval-last-sexp or eval-defun, the evalled thing is marked (without moving point) and its result copied into your kill ring, so you can simply call yank if you wished to replace. You can additionally ensure that any motion pops the mark and restores point and any active region, so there's no interference with the mark workflow you may have had going.
      • An alternative to activating the region is to keep the distinction between eval and eval-print, make the result print after point (i don't see the rationale for the default behavior of printing before point, it doesn't seem to have any workflow in mind), and use C-w optionally to remove the original sexp (it works without an active region).
  • First I wrote a command my-insert-other-buffer-file-name. It's useful many times, but sometimes doesn't insert the buffer I had in mind. Enter my-insert-other-buffer-file-name-and-cycle-repeat.

What links here

Created (3 years ago)

Keto recipes

Recipes

Purpose of a recipe collection? Make a meal plan (random selection is fine), calculate a shopping list from that, then stop making decisions about what to cook or stock up on.

To adapt to sales and dumpster-finds, recipes should be as general as possible. The shopping list should also be interpreted loosely: when seeing a sale on cheddar, you can substitute out brie for more cheddar.

TODO Frittata

4 servings:

  • 300 g mushrooms
  • 200 g leafy greens
  • 100 g onion
  • 100 g butter
  • 12 eggs
  • 200 g chevre/brie or any cheese-like product
  • salt and pepper

Pre-fry the mushrooms and onions, then mix everything in a bowl.

Either cook directly in the same frying pan (1-2 servings at a time) or in an oven pan.

Coconut porridge

2 servings:

  • 200 ml coconut milk/cream
  • 50 g butter
  • 2 tbsp coconut flour
  • 1 tsp psyllium husk fiber
  • 2 eggs

Melt coconut cream and butter in a pot. Add the rest and whisk under low heat until consistency reaches porridge. Serve with berries.

Egg butter

4 servings:

  • 12 large eggs
  • 100 g butter

Boil eggs, peel them and mash together with butter. Use as spread on cucumber slices.

Fried eggs, fried half-tomatoes, cheese cubes

1 serving:

  • 100 g cheese
  • 2 eggs
  • 1 tomato

Scrambled eggs and tomato, Chinese style

1 serving:

  • 3 eggs
  • 1 tomato

Asian cabbage stir fry

2 servings:

  • 200 g cabbage
  • 1/2 tbsp white vinegar
  • 1 clove of garlic
  • 1 "clove" of fresh ginger
  • 1/2 tsp chili flakes
  • 300 g ground beef
  • half onion or 1 tsp onion powder
  • butter
  • salt and pepper
  • sesame oil

Wasabi mayo

  • 1 dl mayo
  • 1 tsp wasabi paste

Shred cabbage finely. Fry it until soft, but not brown, then move to a bowl with vinegar. Saute spices for a few minutes. Add meat, cook through. Put cabbage back in. Drizzle with sesame oil before serving. Optionally, make wasabi mayo.

TODO Thai fish curry

2 servings:

  • 650 g salmon or boneless fillets, in pieces
  • 2 tbsp red curry paste
  • 500 ml coconut cream/milk
  • 450 g cauliflower or broccoli
  • cilantro
  • butter
  • salt and pepper

Preheat oven to 200 C. Grease a baking dish and put in the fish pieces snugly. Salt and pepper generously and place butter on top of each fish piece. Mix coconut cream, curry paste and cilantro in a small bowl and pour over the fish. Bake for 20 minutes.

Cut the cauliflower into small florets and boil in lightly salted water for a couple of minutes. Serve with the fish.

Pesto chicken casserole

2 servings:

  • 650 g boneless chicken thighs
  • salt and pepper
  • butter
  • 80 ml (80 g) pesto
  • 3 dl whipping cream
  • 90 g (160 ml) pitted olives
  • 140 g feta cheese, diced
  • 1 clove of garlic

For serving

  • 140 g (600 ml) leafy greens

Preheat oven to 200 C. Cut chicken into bites. Season and fry in batches. Mix pesto and heavy cream in a bowl. Place chicken in a baking dish together with olives, feta and garlic, and pour the pesto-cream mixture over this. Bake for 20-30 minutes.

Salmon meatballs with bechamel

2 servings:

  • 600 g salmon
  • 1 egg
  • 120 ml cream
  • dill (optional)
  • salt and pepper
  • butter
  • 450 g cauliflower

Lemon bechamel sauce

  • 280 ml cream
  • 130 g cream cheese
  • 4 tsp lemon juice
  • salt and pepper
  • nutmeg (optional)
  • 1 tsp lemon zest (optional)

3 cookwares: 1 frying pan, 2 pots.

Salmon balls: Put fish, egg, cream and spices in a food processor and process until smooth. Shape into little rolls with wet hands, approx 2 tbsp each. Fry over medium heat until golden, then over low heat for a few minutes so it's thoroughly cooked.

Cauliflower: Cut into big wedges and boil them.

Bechamel sauce: Boil all ingredients under continuous stirring, then let it simmer until good consistency.

Beef ramen

  • 2 garlic cloves
  • 1 tbsp sriracha
  • 340 g steak, thinly sliced
  • 2 boiled eggs
  • salt and pepper
  • 280 g bok choy
  • 220 g shirataki noodles or zucchini noodles
  • half onion, chopped
  • sesame oil
  • chili flakes
  • fresh cilantro
  • sesame seeds

Mix garlic, sriracha and beef. Boil eggs. Fry bok choy while being careful not to break or mash it. Remove bok choy and fry beef.

Boil noodles in beef broth. Remove from heat and add sesame oil.

Serve the beef and vegs in bowls, ladle the noodles+broth into them. Top with sesame seeds, cilantro and chili flakes.

TODO Chicken fajita bowl

2 servings:

  • 220 g lettuce
  • 140 g tomatoes
  • 1 avocado
  • 1 onion
  • 1 green bell pepper
  • 900 g boneless chicken thighs
  • butter
  • salt and pepper
  • fresh cilantro
  • 2 tbsp Tex-Mex seasoning (or your own mix)
  • 180 ml (90 g) cheese, shredded (pref. cheddar)
  • 240 ml sour cream (optional)

Prep the toppings: Tear lettuce, chop tomatoes, chop avocados, chop fresh cilantro and shred cheese. Set aside in separate piles.

Slice onion and bell pepper thin. Cut chicken into thin strips and fry it. At the end of frying, add onion, pepper, and seasoning.

Serve in a bowl where the ingredients are separated, optionally with sour cream on top.

Mexican scrambled eggs

2 servings:

  • 2 jalapenos
  • 6 large eggs
  • 20 g onion
  • 60 g cheese
  • 100 g tomato
  • butter
  • salt, pepper, paprika, rosemary, chili, garlic

Chop everything finely. Fry onion, jalapenos and tomatoes. Pour beaten eggs into pan and scramble. Add cheese and season.

Zucchini carbonara

2 servings:

  • 400 g zucchini (use a potato peeler or spiralizer to make noodles)
  • 120 ml whipping cream
  • 160 g bacon or pancetta, diced
  • 2 egg yolks
  • 2 egg whites
  • 120 ml shredded parmesan

Boil cream gently until it has reduced to approx 3/4. Stir occasionally to prevent a skin from forming.

Fry bacon. Lift out the bacon pieces and fry eggwhites in the same pan.

When cream has cooled to just warm, combine all, putting in the zucchini noodles last.

TODO Classic bacon and eggs

1 serving:

  • 140 g bacon
  • 2-3 eggs
  • tomatoes (optional)
  • thyme (optional)

Sliced liver

2 servings:

  • 1 fist-size chunk of liver
  • 2 onions
  • butter

This one requires prep. Assuming your liver is not already frozen, cut it in fist-sized pieces and freeze for 2-3 hours to give them solidity. Take them out and cut in as thin slices as you can manage, then return to freezer. Their slices will get stuck to each other, it's okay since you'll thaw a whole fist at once.

When it's time to cook, thaw the slices and fry them in a pan with onion.

TODO Liver pate

approximatively… 4 servings

  • 400 g liver
  • 300 g onion
  • 300 g cabbage (optional) (add 1 egg)
  • 3 eggs
  • 150 g butter or 300 g cream (in which case add 2 eggs)
  • herbs (pref. marjoram)
  • black pepper
  • 1 tsp salt, add 3/4 tsp if you used cream, add 3/4 tsp if you added cabbage

Run through a blender and pour result into a baking pan, bake like a cake. Have patience while baking, let the crust turn very dark. Cut and eat the same way you would a chocolate cake. If you have to blend in batches, make sure all batches have eggs, it makes the process easy.

TODO Herring snack

2 servings:

  • 300 g frozen herring

This one requires prep. You must buy frozen herring, thaw it just enough to separate the fillets, and re-freeze them in plastic wrap. This makes it easy to retrieve just one fillet and fry it for a quick snack. In addition, keep a tiny frying pan specifically for this purpose so you don't have to wash it quite so thoroughly of the fish smell.

Further, it's a good idea to make a daily habit for one week: one herring fillet before eating anything else (perhaps even before your morning coffee). If you never seem to get around to eating fish, you must teach your subconscious that it's quick, easy, trivial, and delicious.

TODO Kelp lasagna

  • Kelp sheets
  • Ground beef
  • Crushed tomatoes
  • Cheese
  • Sour cream, whipping cream or cream cheese

Rehydrate kelp sheets for a few hours. Boil them in lightly salted water for 10 minutes.

Make ground beef sauce.

Finally, build a lasagna.

TODO Seaweed carbonara

  • Ground beef

What links here

  • On diet
Created (3 years ago)

Wayland vs. X11

Computing

Wayland is a topic of intense bikeshedding (like systemd). My jury's out, but here are some observations.

  • It seems we're waiting for the library wlroots to grow to the size of Xorg itself before we can say Wayland is "ready".
  • For now, a Wayland compositor needs (a lot) more code than an X window manager.
  • Normally, when programs are simplified, it's in a good way – more composable and interoperable. But Wayland compositors are not unified and often not very interoperable with other programs. So the Wayland protocol is a simplification that also worsens composability instead of improving it. Like Denote (2023-02-26​)!
    • However, this has a flip side. With such a design, it is possible to implement screen security, resistance to keyloggers, and block popups that look like password prompts. The compositor exposes to other programs only what it chooses to expose and can correctly predict what will be drawn to screen.
    • It's possible to have an unified API that's agreed on by many compositor developers, but it would be opt-in on the part of the developers. Companies like Red Hat and Canonical may not bother, and because we have no way to talk to the equivalent of an underlying X server, there will be no standard hacks to modify their window managers to our purposes.
      • sadly, no unified API yet? wlroots does not expose one, I think.
  • Better text rendering on 4K displays.
Created (3 years ago)

Time series analysis

Components of a time series

  • Seasonality/periodicity
  • Stationarity
  • Autocorrelation

Stochastic process

OK, so I was considering what's a Dirichlet distribution and what's a categorical, because I don't know what a slice from the area chart of activities over 24 hours (you know the one) would be. I guess categorical, not Dirichlet, because it's a rigid group of probabilities, like the Bernoulli

Good visualization of Bernoulli: gave me an "aha".

File:Bernoulli_Distribution.PNG

Then onwards to the categorical. Look!

File:2D-simplex.svg

This is a regular Cartesian 3-D coordinate system, so you're meant to see the triangle as standing slanted against the vertical axis. Make sense?

The entire triangle is not a categorical distribution; rather, the triangle is the space of all possible categorical distributions. One distribution would be a single point on it. A tuple of three p-values that add up to 1.

This triangle visualization is important, because now see the Dirichlet:

en.wikipedia.org/wiki/File:Dirichlet.pdf


Now let's backtrack to the Bernoulli and beta distributions to make sure you understand it. Does the beta make sense to you – are you fully clear on what the x and y axes represent?

File:Beta_distribution_pdf.svg

At any point on the x-axis between 0 and 1, you have a tuple of two values p and (1-p). So, x = 0.3 represents the Bernoulli distribution where p = 0.3 and 1-p = 0.7. And the y-axis says how likely you are to observe this particular tuple. Yes, kind of a "probability of a probability"… Although x could represent any number-pair that has to add to 1 or some other given fixed sum.

But really, when you model a generative process as a Bernoulli of unknown parameters, it makes sense to have, as prior, a probability distribution over all possible Bernoulli distributions, so yes, a prob of a prob.

You might think p = 0.1 and 1-p = 0.9 is a likely description of the generative process behind some variable but the reversed pair is not, so for your beta prior you might set α = 2 and β = 5 (orange line here).


So that one area chart is a distribution of categoricals over time.

A distribution of Dirichlets over time would be like if we took one of those triangles and extrude it out like a Toblerone. If we imagine the white background as invisible, it might look like a blue snake in the midst of writhing around.

This led me to ask what a Dirichlet process is. Ok, first it's a stochastic process. Are they always over time? Of course not necessarily, but what exemplifies it as a process is there's usually some relation to "past" values or simply "neighboring values on one axis", that axis not being one of the parameters to the Dirichlet itself.

A simple stochastic process is the Bernoulli process, which you'll recognize as the coin-flip process. A sequence of iid rv where each rv takes values 0 or 1. There's no autocorrelation of any kind. We can still draw a contiguous line on a chart if we consider each draw of the process as the sum of all previous draws.

A random walk is similar. The simple random walk is like the coin-flip process, but the rv takes values of 1 or -1 instead of 1 or 0. Interestingly, it's kind of hard to define one on continuous time – normally the steps in the time t are discrete.

The Wiener process, historically also called the Brownian motion process, is based on the normal distribution instead of the Bernoulli. The size of each change is distributed per the Gaussian.

File:DriftedWienerProcess1D.svg

Apparently, the Wiener process is a member of several families of processes: Markov processes, Levy processes and Gaussian processes.

The Wiener is Markovian, really? This leads me to: what is a Markov process? Wikipedia and Google seem to treat the term as synonymous with a Markov chain.

Generally, "a Markov chain is a stochastic model describing a sequence of possible events in which the probability of each event depends only on the state attained in the previous event."

As with most processes, there is a distinction between discrete-time (DTMC) and continuous time (CTMC) Markov chains.

AR/MA

One of the simplest time series models is a Moving Average model. It predicts the next point as the mean of all past datapoints, end of story. The equation is as follows.

xt = μ

Actually I lied, that's just conceptual. You need a few more variables,

  • εt-i ("error terms", how much a datapoint was off from μ at time t),
  • θi,
  • and one hyperparameter q which controls how high i goes (so how many datapoints back to look).

The MA(q) model:

node:internal/modules/cjs/loader:1228 throw err; ^ Error: Cannot find module 'katex' Require stack: - /home/kept/private-dotfiles/.config/emacs/texToMathML.js at Module._resolveFilename (node:internal/modules/cjs/loader:1225:15) at Module._load (node:internal/modules/cjs/loader:1051:27) at Module.require (node:internal/modules/cjs/loader:1311:19) at require (node:internal/modules/helpers:179:18) at Object. (/home/kept/private-dotfiles/.config/emacs/texToMathML.js:1:15) at Module._compile (node:internal/modules/cjs/loader:1469:14) at Module._extensions..js (node:internal/modules/cjs/loader:1548:10) at Module.load (node:internal/modules/cjs/loader:1288:32) at Module._load (node:internal/modules/cjs/loader:1104:12) at Function.executeUserEntryPoint [as runMain] (node:internal/modules/run_main:173:12) { code: 'MODULE_NOT_FOUND', requireStack: [ '/home/kept/private-dotfiles/.config/emacs/texToMathML.js' ] } Node.js v20.18.1

For I suspect archaic reasons, the q parameter is also called the "order" of the model. And with that we have revealed the jargon behind the classic time series models, MA(q), AR(p), ARMA(q, p) and ARIMA(q, d, p).

AR: Autoregressive MA: Moving Average ARMA: Autoregressive Moving Average ARIMA: Autoregressive Integrated Moving Average

Each of these time series models exist in different orders. E.g. MA(0), MA(1), MA(2), AR(0), AR(1), AR(2), ARMA(1, 2), ARIMA(1, 2, 3).

ARIMA(1, 0, 0) is AR(1).

ARIMA(0, 0, 1) is MA(1).

ARIMA(1, 0, 1) is ARMA(1, 1).

Others: ARIMAX, VARIMA, SARIMA, FARIMA/ARFIMA.

Given an ARIMA(p,d,q), if d>0 one can modle this as an ARMA by running an ARMA(p,q) after differencing the original series d times.

Before 1970, econometricians and time series analysts used vastly different methods to model a time series. Econometricians modeled time series are a standard linear regression with explanatory variables suggested by economic theory/intuition to explain the movements in time series data. They assumed that the time series being ‘nonstationary’ (growing overtime) had no effect on their empirical analysis. Time series analysts on the other hand ignored this traditional econometric analysis. They modeled a time series as a function of its past values. They worked around the problem of nonstationarity by differencing the data to make it stationary. Then, Clive Granger and Paul Newbold happened[1]. Econometricians were forced to pay attention to the methods of time series analysts, the most famous of which was the Box–Jenkins approach developed by George P Box and Gwilym Jenkins and published in their legendary monograph Time Series Analysis: Forecasting and Control[2] .

Box and Jenkins claimed (successfully) that nonstationary data can be made stationary by differencing the series.

Econometricians ignored the Box-Jenkins approach at first but were forced to pay attention to them when it ARIMA forecasts started consistently outperforming forecasts based on standard econometric modelling. The lack of sound economic theory behind the ARIMA was troubling for econometricians to accept. They responded by developing another class of models that incorporated auroregressive and moving average components of Box-Jenkins approach with the ‘explanatory variables’ approach of standard econometrics. The simplest of such models is the ARIMAX which is just an ARIMA with additional explanatory variables provided by economic theory.

ARIMA models are applied in some cases where data show evidence of non-stationarity, where an initial differencing step (corresponding to the "integrated" part of the model) can be applied one or more times to eliminate the non-stationarity.

The AR part of ARIMA indicates that the evolving variable of interest is regressed on its own lagged (i.e., prior) values. The MA part indicates that the regression error is actually a linear combination of error terms whose values occurred contemporaneously and at various times in the past.

VARIMA (Vector Autoregressive…) is for when you have multiple time series, then at each time point t you can think of it as having a vector of values.

Sometimes a seasonal effect is suspected in the model; in that case, it is generally considered better to use a SARIMA (seasonal ARIMA) model than to increase the order of the AR or MA parts of the model.

If the time-series is suspected to exhibit long-range dependence, then the d parameter may be allowed to have non-integer values in an autoregressive fractionally integrated moving average model, which is also called a Fractional ARIMA (FARIMA or ARFIMA) model.

The Hurst exponent is used as a measure of long-term memory of time series. It relates to the autocorrelations of the time series, and the rate at which these decrease as the lag between pairs of values increases.

Invertability of MA processes

Difference between time series and survival analysis

Survival analysis: dataset looks like this, and each row concerns a separate individual.

time to death
20
23
2
10
22
21

Time series analysis: dataset looks like this, and the whole dataset is about a single individual.

time value of interest
1 40
2 39
3 40
4 41
5 47
6 46

The Wiener process - "Brownian motion"

d<- tibble(x = rnorm(100),
           y = rnorm(100))
ggplot(aes(x, y)) + geom_point()
ts.plot(d$x)
ts.plot(d$y)

The higher the temperature, the more powerful movements.

  1. X(0) = 0
  2. independent and stationary increases
  3. X(t2 ) - X(t1) ∈ N(E[Δ t]= 0, σ \sqrt[t_2 - t_1])
  4. E[X(t)] = 0, γ(s,t) = σ min(s, t)
  5. Not derivable

Sampled wiener process

X(tn) = X(0) + &varphi;1 + &varphi;2 + … + &varphi;n = X(tn-1) + &varphi;n

X(t1) = X(0) + &varphi;1

Discrete random walk!

The discrete "sampled process": X(tn) = X(tn-1) + &varphi;n where &varphi;n ∈ N(0, σe), which is Gaussian white noise.

Example: satellites Sputnik 1, 2, 3 triangulates a GPS user's position and introduces white noise, electronic warfare.

Random walk

{ &varphi;1, &varphi;2, …, &varphi;n } a sequence of independent identically distributed random variables E(&varphi;i) = 0

Cov(&varphi;i, &varphi;j) = 0 where i ≠ j, otherwise σ2e.

Yt = 0 + &varphi;1, &varphi;2, …, &varphi;t = ∑ &varphi;i

This is the same as running cumsum() in R.

  1. E(Y(t)) = E(∑&varphi;i) = ∑ E(&varphi;i) = 0 + 0 + 0 … 0 = 0, iow the expected value is a constant
  2. V(Y(t)) = V(∑&varphi;i) = ∑ V(&varphi;i) = V(&varphi;1) + V(&varphi;2) + … + V(&varphi;t) = = σ2e + σ2e + … + σ2e = tσ2e so the variance depends on t \implies not stationary
  3. γY(t, s) = (a t × s covariance matrix) = ∑ ∑ C(&varphi;i, &varphi;j) = t We said this is zero for all i ≠ j, so this is the same as V(Y(t)) i.e. tσ2e. Though if 1 ≤ s ≤ t, it is sσ2e!

Example:

node:internal/modules/cjs/loader:1228 throw err; ^ Error: Cannot find module 'katex' Require stack: - /home/kept/private-dotfiles/.config/emacs/texToMathML.js at Module._resolveFilename (node:internal/modules/cjs/loader:1225:15) at Module._load (node:internal/modules/cjs/loader:1051:27) at Module.require (node:internal/modules/cjs/loader:1311:19) at require (node:internal/modules/helpers:179:18) at Object. (/home/kept/private-dotfiles/.config/emacs/texToMathML.js:1:15) at Module._compile (node:internal/modules/cjs/loader:1469:14) at Module._extensions..js (node:internal/modules/cjs/loader:1548:10) at Module.load (node:internal/modules/cjs/loader:1288:32) at Module._load (node:internal/modules/cjs/loader:1104:12) at Function.executeUserEntryPoint [as runMain] (node:internal/modules/run_main:173:12) { code: 'MODULE_NOT_FOUND', requireStack: [ '/home/kept/private-dotfiles/.config/emacs/texToMathML.js' ] } Node.js v20.18.1

node:internal/modules/cjs/loader:1228 throw err; ^ Error: Cannot find module 'katex' Require stack: - /home/kept/private-dotfiles/.config/emacs/texToMathML.js at Module._resolveFilename (node:internal/modules/cjs/loader:1225:15) at Module._load (node:internal/modules/cjs/loader:1051:27) at Module.require (node:internal/modules/cjs/loader:1311:19) at require (node:internal/modules/helpers:179:18) at Object. (/home/kept/private-dotfiles/.config/emacs/texToMathML.js:1:15) at Module._compile (node:internal/modules/cjs/loader:1469:14) at Module._extensions..js (node:internal/modules/cjs/loader:1548:10) at Module.load (node:internal/modules/cjs/loader:1288:32) at Module._load (node:internal/modules/cjs/loader:1104:12) at Function.executeUserEntryPoint [as runMain] (node:internal/modules/run_main:173:12) { code: 'MODULE_NOT_FOUND', requireStack: [ '/home/kept/private-dotfiles/.config/emacs/texToMathML.js' ] } Node.js v20.18.1

node:internal/modules/cjs/loader:1228 throw err; ^ Error: Cannot find module 'katex' Require stack: - /home/kept/private-dotfiles/.config/emacs/texToMathML.js at Module._resolveFilename (node:internal/modules/cjs/loader:1225:15) at Module._load (node:internal/modules/cjs/loader:1051:27) at Module.require (node:internal/modules/cjs/loader:1311:19) at require (node:internal/modules/helpers:179:18) at Object. (/home/kept/private-dotfiles/.config/emacs/texToMathML.js:1:15) at Module._compile (node:internal/modules/cjs/loader:1469:14) at Module._extensions..js (node:internal/modules/cjs/loader:1548:10) at Module.load (node:internal/modules/cjs/loader:1288:32) at Module._load (node:internal/modules/cjs/loader:1104:12) at Function.executeUserEntryPoint [as runMain] (node:internal/modules/run_main:173:12) { code: 'MODULE_NOT_FOUND', requireStack: [ '/home/kept/private-dotfiles/.config/emacs/texToMathML.js' ] } Node.js v20.18.1

node:internal/modules/cjs/loader:1228 throw err; ^ Error: Cannot find module 'katex' Require stack: - /home/kept/private-dotfiles/.config/emacs/texToMathML.js at Module._resolveFilename (node:internal/modules/cjs/loader:1225:15) at Module._load (node:internal/modules/cjs/loader:1051:27) at Module.require (node:internal/modules/cjs/loader:1311:19) at require (node:internal/modules/helpers:179:18) at Object. (/home/kept/private-dotfiles/.config/emacs/texToMathML.js:1:15) at Module._compile (node:internal/modules/cjs/loader:1469:14) at Module._extensions..js (node:internal/modules/cjs/loader:1548:10) at Module.load (node:internal/modules/cjs/loader:1288:32) at Module._load (node:internal/modules/cjs/loader:1104:12) at Function.executeUserEntryPoint [as runMain] (node:internal/modules/run_main:173:12) { code: 'MODULE_NOT_FOUND', requireStack: [ '/home/kept/private-dotfiles/.config/emacs/texToMathML.js' ] } Node.js v20.18.1

Strong autocorrelation here.

Characteristics of AR

A simple general model AR(p = 1): { Yt = Φ Yt-1 + &varphi;t, &varphi;t ∈ N(0, σe) }

What happens if Φ > 1, Φ = 0, |Φ| > 1, -1 < Φ < 0, 0 < Φ < 1 ??

Φ = 0
\implies Yt = &varphi;t, so just white noise unrelated to the past
Φ > 1
(for example) Φ = 2 means that Y2 = 2 Y1 + &varphi;2 Y3 = 2 Y2 + &varphi;3 and so on, it is explosive & non-stationary and eclipses the effect of &varphi;t (?)
0 < Φ < 1
(for example) Φ = 0.9 means that Y1 = 0.9Y0 + &varphi;1 Y2 = 0.9Y1 + &varphi;2 the effect of previous values is continually being subdued
-1 < Φ < 0
(for example) Φ = -0.9 Y1 = -0.9Y0 + &varphi;1 Y2 = -0.9(-0.9Y0) + &varphi;2 It flips sign for every point. If the starting value is 4, it goes to -3.6, then 3.24 and so on, hugging the x-axis ever closer.
|Φ| > 1
(for example) Φ = -2 Like the case of Φ = 2, but it flips sign. So it gets further and further away from the x-axis.

Unevenly spaced time series

When analysts are presented with unevenly-spaced sensor data, they usually convert the unevenly-spaced data to a evenly-spaced time series by regular sampling or linear interpolation. This conversion helps get the data into a format that are used by the most common tools for time series analysis. In addition to the constraints on data size, this method also presents other practical challenges:

It is easy to make mistakes. Since evenly-spaced time series are usually stored without timestamps (in an array, along with the start time and time interval), it’s easy to use the wrong time units — conversions are notoriously error-prone — or mix up when the data was recorded. It encourages bloat. If you have data from several sources with different time resolution, the usual approach is to sample at the smallest time resolution. You can end up with a time series that is sampled every second from a sensor that samples every hour.

Beyond the practical challenges, there are technical reasons to be careful when converting unevenly-spaced data to regular time series including:

Data loss and dilution. You lose data that are closely spaced, and you add redundant data points when the data are too sparse.

Time information. The duration between each measurement can contain useful information about the data. For example, based on the frequency and duration of the light switching on or off, we can safely say that the second house is more likely to use an automated light switch than the first house.

Kalman Filter

Kalman filters are ideal for systems which are continuously changing. They have the advantage that they are light on memory (they don’t need to keep any history other than the previous state), and they are very fast, making them well suited for real time problems and embedded systems.

Let’s make a toy example: You’ve built a little robot that can wander around in the woods, and the robot needs to know exactly where it is so that it can navigate.

We’ll say our robot has a state node:internal/modules/cjs/loader:1228 throw err; ^ Error: Cannot find module 'katex' Require stack: - /home/kept/private-dotfiles/.config/emacs/texToMathML.js at Module._resolveFilename (node:internal/modules/cjs/loader:1225:15) at Module._load (node:internal/modules/cjs/loader:1051:27) at Module.require (node:internal/modules/cjs/loader:1311:19) at require (node:internal/modules/helpers:179:18) at Object. (/home/kept/private-dotfiles/.config/emacs/texToMathML.js:1:15) at Module._compile (node:internal/modules/cjs/loader:1469:14) at Module._extensions..js (node:internal/modules/cjs/loader:1548:10) at Module.load (node:internal/modules/cjs/loader:1288:32) at Module._load (node:internal/modules/cjs/loader:1104:12) at Function.executeUserEntryPoint [as runMain] (node:internal/modules/run_main:173:12) { code: 'MODULE_NOT_FOUND', requireStack: [ '/home/kept/private-dotfiles/.config/emacs/texToMathML.js' ] } Node.js v20.18.1 , which is just a position and a velocity: node:internal/modules/cjs/loader:1228 throw err; ^ Error: Cannot find module 'katex' Require stack: - /home/kept/private-dotfiles/.config/emacs/texToMathML.js at Module._resolveFilename (node:internal/modules/cjs/loader:1225:15) at Module._load (node:internal/modules/cjs/loader:1051:27) at Module.require (node:internal/modules/cjs/loader:1311:19) at require (node:internal/modules/helpers:179:18) at Object. (/home/kept/private-dotfiles/.config/emacs/texToMathML.js:1:15) at Module._compile (node:internal/modules/cjs/loader:1469:14) at Module._extensions..js (node:internal/modules/cjs/loader:1548:10) at Module.load (node:internal/modules/cjs/loader:1288:32) at Module._load (node:internal/modules/cjs/loader:1104:12) at Function.executeUserEntryPoint [as runMain] (node:internal/modules/run_main:173:12) { code: 'MODULE_NOT_FOUND', requireStack: [ '/home/kept/private-dotfiles/.config/emacs/texToMathML.js' ] } Node.js v20.18.1

In our example it’s position and velocity, but it could be data about the amount of fluid in a tank, the temperature of a car engine, the position of a user’s finger on a touchpad, or any number of things you need to keep track of.

Our robot also has a GPS sensor, which is accurate to about 10 meters, which is good, but it needs to know its location more precisely than 10 meters. There are lots of gullies and cliffs in these woods, and if the robot is wrong by more than a few feet, it could fall off a cliff. So GPS by itself is not good enough.

We might also know something about how the robot moves: It knows the commands sent to the wheel motors, and its knows that if it’s headed in one direction and nothing interferes, at the next instant it will likely be further along that same direction. But of course it doesn’t know everything about its motion: It might be buffeted by the wind, the wheels might slip a little bit, or roll over bumpy terrain; so the amount the wheels have turned might not exactly represent how far the robot has actually traveled, and the prediction won’t be perfect.

  • The GPS sensor tells us something about the state, but only indirectly, and with some uncertainty or inaccuracy.
  • Our prediction tells us something about how the robot is moving, but only indirectly, and with some uncertainty or inaccuracy.

But if we use all the information available to us, can we get a better answer than either estimate would give us by itself?

We don’t know what the actual position and velocity are; there are a whole range of possible combinations of position and velocity that might be true, but some of them are more likely than others:

2020-11-10 00-55-54 gauss 0

2020-11-10 00-56-50 gauss 1

In the above picture, position and velocity are uncorrelated, which means that the state of one variable tells you nothing about what the other might be.

The example below shows something more interesting: Position and velocity are correlated. The likelihood of observing a particular position depends on what velocity you have:

2020-11-10 00-56-57 gauss 3

This kind of situation might arise if, for example, we are estimating a new position based on an old one. If our velocity was high, we probably moved farther, so our position will be more distant.

This correlation is captured by something called a covariance matrix. In short, each element of the matrix node:internal/modules/cjs/loader:1228 throw err; ^ Error: Cannot find module 'katex' Require stack: - /home/kept/private-dotfiles/.config/emacs/texToMathML.js at Module._resolveFilename (node:internal/modules/cjs/loader:1225:15) at Module._load (node:internal/modules/cjs/loader:1051:27) at Module.require (node:internal/modules/cjs/loader:1311:19) at require (node:internal/modules/helpers:179:18) at Object. (/home/kept/private-dotfiles/.config/emacs/texToMathML.js:1:15) at Module._compile (node:internal/modules/cjs/loader:1469:14) at Module._extensions..js (node:internal/modules/cjs/loader:1548:10) at Module.load (node:internal/modules/cjs/loader:1288:32) at Module._load (node:internal/modules/cjs/loader:1104:12) at Function.executeUserEntryPoint [as runMain] (node:internal/modules/run_main:173:12) { code: 'MODULE_NOT_FOUND', requireStack: [ '/home/kept/private-dotfiles/.config/emacs/texToMathML.js' ] } Node.js v20.18.1 is the degree of correlation between the ith state variable and the jth state variable. (You might be able to guess that the covariance matrix is symmetric, which means that it doesn’t matter if you swap i and j). Covariance matrices are often labelled “node:internal/modules/cjs/loader:1228 throw err; ^ Error: Cannot find module 'katex' Require stack: - /home/kept/private-dotfiles/.config/emacs/texToMathML.js at Module._resolveFilename (node:internal/modules/cjs/loader:1225:15) at Module._load (node:internal/modules/cjs/loader:1051:27) at Module.require (node:internal/modules/cjs/loader:1311:19) at require (node:internal/modules/helpers:179:18) at Object. (/home/kept/private-dotfiles/.config/emacs/texToMathML.js:1:15) at Module._compile (node:internal/modules/cjs/loader:1469:14) at Module._extensions..js (node:internal/modules/cjs/loader:1548:10) at Module.load (node:internal/modules/cjs/loader:1288:32) at Module._load (node:internal/modules/cjs/loader:1104:12) at Function.executeUserEntryPoint [as runMain] (node:internal/modules/run_main:173:12) { code: 'MODULE_NOT_FOUND', requireStack: [ '/home/kept/private-dotfiles/.config/emacs/texToMathML.js' ] } Node.js v20.18.1 ”, so we call their elements “node:internal/modules/cjs/loader:1228 throw err; ^ Error: Cannot find module 'katex' Require stack: - /home/kept/private-dotfiles/.config/emacs/texToMathML.js at Module._resolveFilename (node:internal/modules/cjs/loader:1225:15) at Module._load (node:internal/modules/cjs/loader:1051:27) at Module.require (node:internal/modules/cjs/loader:1311:19) at require (node:internal/modules/helpers:179:18) at Object. (/home/kept/private-dotfiles/.config/emacs/texToMathML.js:1:15) at Module._compile (node:internal/modules/cjs/loader:1469:14) at Module._extensions..js (node:internal/modules/cjs/loader:1548:10) at Module.load (node:internal/modules/cjs/loader:1288:32) at Module._load (node:internal/modules/cjs/loader:1104:12) at Function.executeUserEntryPoint [as runMain] (node:internal/modules/run_main:173:12) { code: 'MODULE_NOT_FOUND', requireStack: [ '/home/kept/private-dotfiles/.config/emacs/texToMathML.js' ] } Node.js v20.18.1 ”.

2020-11-10 00-57-07 gauss 2

Example dataset would be nice, so I can translate what guides tell me into something meaningful for me.


Dynamic linear models (DLM) are a special case of general state space models. Estimates for a DLM can be gotten by the famous Kalman filter.

ARMA models are a special case of state space models.


The Kalman filter and generalized variants are based on a hidden Markov model (HMM) where all latent and observed variables are continuous. So I guess you would not use it for a classification problem. Though apparently DuckDuckGo returns hits. yuyanwei.github.io/papers/kai2020orderingACCESS.pdf seems well written.

Correlation and covariance

  • Cov(X, Y) is also written γX,Y(X,Y) and defined as E(XY) - E(X)E(Y).
  • Corr(X, Y) is also written ρX,Y(X,Y).

Having only one subscript (CovX) makes it an autocovariance function. You may see it written the following way. Otherwise it is called cross-covariance.

node:internal/modules/cjs/loader:1228 throw err; ^ Error: Cannot find module 'katex' Require stack: - /home/kept/private-dotfiles/.config/emacs/texToMathML.js at Module._resolveFilename (node:internal/modules/cjs/loader:1225:15) at Module._load (node:internal/modules/cjs/loader:1051:27) at Module.require (node:internal/modules/cjs/loader:1311:19) at require (node:internal/modules/helpers:179:18) at Object. (/home/kept/private-dotfiles/.config/emacs/texToMathML.js:1:15) at Module._compile (node:internal/modules/cjs/loader:1469:14) at Module._extensions..js (node:internal/modules/cjs/loader:1548:10) at Module.load (node:internal/modules/cjs/loader:1288:32) at Module._load (node:internal/modules/cjs/loader:1104:12) at Function.executeUserEntryPoint [as runMain] (node:internal/modules/run_main:173:12) { code: 'MODULE_NOT_FOUND', requireStack: [ '/home/kept/private-dotfiles/.config/emacs/texToMathML.js' ] } Node.js v20.18.1

Having only one subscript (CorrX) makes it an autocorrelation function (ACF). Yoy may see it written the following way. Otherwise it is called cross-correlation.

node:internal/modules/cjs/loader:1228 throw err; ^ Error: Cannot find module 'katex' Require stack: - /home/kept/private-dotfiles/.config/emacs/texToMathML.js at Module._resolveFilename (node:internal/modules/cjs/loader:1225:15) at Module._load (node:internal/modules/cjs/loader:1051:27) at Module.require (node:internal/modules/cjs/loader:1311:19) at require (node:internal/modules/helpers:179:18) at Object. (/home/kept/private-dotfiles/.config/emacs/texToMathML.js:1:15) at Module._compile (node:internal/modules/cjs/loader:1469:14) at Module._extensions..js (node:internal/modules/cjs/loader:1548:10) at Module.load (node:internal/modules/cjs/loader:1288:32) at Module._load (node:internal/modules/cjs/loader:1104:12) at Function.executeUserEntryPoint [as runMain] (node:internal/modules/run_main:173:12) { code: 'MODULE_NOT_FOUND', requireStack: [ '/home/kept/private-dotfiles/.config/emacs/texToMathML.js' ] } Node.js v20.18.1

Stationarity

There is weak (WSS) and strict stationarity. In Swedish, those are abbreviated s.s.p and s.p respectively, though s.p sometimes just means stochastic process! :/

Some names for WSS are weak-sense stationarity, wide-sense stationarity and covariance-stationarity.

Any strictly stationary process is also weakly stationary (so long as it has a defined mean and a covariance).

All of the following are required to make a process Yt stationary.

  • E(Yt) is constant.
  • The autocovariance does not depend on t: Cov(Yt, Yt+k) is the same as Cov(Yt+1, Yt+k+1), only the interval length k affects it. When this fact has been discovered, you often write γX(k) as a shorthand for γX(t, t+k).

Differencing

One way to make some time series stationary is to compute the differences between consecutive observations. This is known as differencing. Differencing can help stabilize the mean of a time series by removing changes in the level of a time series, and so eliminating trend and seasonality.

Transformations such as logarithms can help to stabilize the variance of a time series.

One of the ways for identifying non-stationary times series is the ACF plot. For a stationary time series, the ACF will drop to zero relatively quickly, while the ACF of non-stationary data decreases slowly.

Ergodicity

A stochastic process is said to be ergodic if its statistical properties can be deduced from a single, sufficiently long, random sample of the process. You don't have to look at multiple realizations, for example.

What links here

Created (3 years ago)
Showing 197 to 200