Skip to main content

notebooks - Can I enter the traditional form for Binomial as input in an expression?


Is there a way to enter the traditional form of a binomial coefficient, i.e. ${n \choose k}$ instead of Binomial[n,k], like I would enter a radical sign $\sqrt{x}$ using Ctrl-Shift-2? I would like to enter it that way in a notebook, and see it in that form in the input as well as output equations, just like the radical. I know that I can use TraditionalForm to convert it on output, but I don't need to do that to see radicals instead of Sqrt.



Answer



You could do it using the following (this is the first version of the answer; don't use it if you want the more complete solution below):


SetOptions[EvaluationNotebook[],InputAliases->{"bn"->
FormBox[TemplateBox[{"\[SelectionPlaceholder]",
"\[Placeholder]"},"Binomial"],InputForm]}]

Then enter escbnesc to get a placeholder that you can tab through:


pic



Then enter the numbers and press shift-enter to evaluate.


Edit


To make the output appear formatted without invoking TraditionalForm, you'd have to define a wrapper function and its style. I'll set the keyboard shortcut in a way that doesn't erase previous definitions.


ClearAll[myBinomial]

appearance[x_, y_] := TemplateBox[{x, y}, "myBinomial",
DisplayFunction :> (RowBox[{"(", "\[NoBreak]",
GridBox[{{#1}, {#2}}, RowSpacings -> 1, ColumnSpacings -> 1,
RowAlignments -> Baseline, ColumnAlignments -> Center],
"\[NoBreak]", ")"}] &),

InterpretationFunction :> (RowBox[{"myBinomial", "[",
RowBox[{#1, ",", #2}], "]"}] &)
]

myBinomial[n_?NumericQ, k_?NumericQ] := Binomial[n, k]

myBinomial /: MakeBoxes[myBinomial[n_, k_], StandardForm] :=
appearance[ToBoxes[n], ToBoxes[k]]

SetOptions[EvaluationNotebook[],

InputAliases ->
DeleteDuplicates@
Join[{"bn" ->
appearance["\[SelectionPlaceholder]", "\[Placeholder]"]},
InputAliases /.
Quiet[Options[EvaluationNotebook[], InputAliases]] /.
InputAliases -> {}]
]

Now the template appears as before, but when the function arguments aren't numerical, it's also displayed in 2D form. One could add additional definitions to myBinomial depending on what cases you want the 2D display to apply to. Whenever there is no definition for myBinomial, it is left unevaluated and will be displayed in the formatted style.



Update in response to comment:


Similar templates can also be created for other two-dimensional symbols using other types of brackets. As an example, here are shortcuts for StirlingS1 and StirlingS2 that can be entered as escs1esc and escs2esc:


appearanceS1[x_, y_] := 
TemplateBox[{x, y}, "myStirlingS1",
DisplayFunction :> (StyleBox[
RowBox[{"[", "\[NoBreak]",
GridBox[{{#1}, {#2}}, RowSpacings -> 1, ColumnSpacings -> 1,
RowAlignments -> Baseline, ColumnAlignments -> Center],
"\[NoBreak]", "]"}], SpanMaxSize -> Infinity] &),
InterpretationFunction :> (RowBox[{"myStirlingS1", "[",

RowBox[{#1, ",", #2}], "]"}] &)]

myStirlingS1[n_?NumericQ, k_?NumericQ] := StirlingS1[n, k]

myStirlingS1 /: MakeBoxes[myStirlingS1[n_, k_], StandardForm] :=
appearanceS1[ToBoxes[n], ToBoxes[k]]

appearanceS2[x_, y_] :=
TemplateBox[{x, y}, "myStirlingS2",
DisplayFunction :> (StyleBox[

RowBox[{"{", "\[NoBreak]",
GridBox[{{#1}, {#2}}, RowSpacings -> 1, ColumnSpacings -> 1,
RowAlignments -> Baseline, ColumnAlignments -> Center],
"\[NoBreak]", "}"}], SpanMaxSize -> Infinity] &),
InterpretationFunction :> (RowBox[{"myStirlingS2", "[",
RowBox[{#1, ",", #2}], "]"}] &)]

myStirlingS2[n_?NumericQ, k_?NumericQ] := StirlingS2[n, k]

myStirlingS2 /: MakeBoxes[myStirlingS2[n_, k_], StandardForm] :=

appearanceS2[ToBoxes[n], ToBoxes[k]]

SetOptions[EvaluationNotebook[],
InputAliases ->
DeleteDuplicates@
Join[{"s1" ->
appearanceS1["\[SelectionPlaceholder]", "\[Placeholder]"],
"s2" -> appearanceS2["\[SelectionPlaceholder]",
"\[Placeholder]"]},
InputAliases /.

Quiet[Options[EvaluationNotebook[], InputAliases]] /.
InputAliases -> {}]
]

In these definitions, I added one additional ingredient: the square and curly brackets for these symbols are not automatically extensible, so they don't grow like the round brackets used in Binomial. To fix this, I added a StyleBox with option SpanMaxSize -> Infinity.


Also, the shortcuts are be appended to the InputAliases without erasing previous definitions. To make the shortcuts work, this step has to be done after defining the wrapper functions appearance and appearanceS1/S2.


With this, you can get output like this:


s1


for StirlingS1 and


s2



for StirlingS2.


Comments

Popular posts from this blog

plotting - How to draw lines between specified dots on ListPlot?

I would like to create a plot where I have unconnected dots and some connected. So far, I have figured out how to draw the dots. My code is the following: ListPlot[{{1, 1}, {2, 2}, {3, 3}, {4, 4}, {1, 4}, {2, 5}, {3, 6}, {4, 7}, {1, 7}, {2, 8}, {3, 9}, {4, 10}, {1, 10}, {2, 11}, {3, 12}, {4,13}, {2.5, 7}}, Ticks -> {{1, 2, 3, 4}, None}, AxesStyle -> Thin, TicksStyle -> Directive[Black, Bold, 12], Mesh -> Full] I have thought using ListLinePlot command, but I don't know how to specify to the command to draw only selected lines between the dots. Do have any suggestions/hints on how to do that? Thank you. Answer One possibility would be to use Epilog with Line : ListPlot[ {{1, 1}, {2, 2}, {3, 3}, {4, 4}, {1, 4}, {2, 5}, {3, 6}, {4, 7}, {1, 7}, {2, 8}, {3, 9}, {4, 10}, {1, 10}, {2, 11}, {3, 12}, {4, 13}, {2.5, 7}}, Ticks -> {{1, 2, 3, 4}, None}, AxesStyle -> Thin, TicksStyle -> Directive[Black, Bold, 12], Mesh -> Full, Epilog -> { Line[ ...

equation solving - Invert and fit implicitly defined curve

I need to fit an implicitly defined curve. I thought I could get some data out of Solve , and then using FindFit . Therefore, I would like to find the relation the parametric curve defined by $F(x,y)=0$: Solve[-(1/2) + 1/2 (0.41202 BesselK[0, 0.1 Sqrt[x^2 + y^2]] + (0.101483 x BesselK[1, 0.1 Sqrt[x^2 + y^2]])/Sqrt[x^2 + y^2]) == 0, y] But I can't get an output: Solve was unable to solve the system with inexact coefficients or the system obtained by direct rationalization of inexact numbers present in the system. Since many of the methods used by Solve require exact input, providing Solve with an exact version of the system may help. >> Edit: In particular, I would like to fit the data coming from the curve with the expression of another curve, and not with a function $f(x)$. In particular, since this clearly looks like a cardioid , I would like it to fit to something like it. What other strategies could I try?

dynamic - How can I make a clickable ArrayPlot that returns input?

I would like to create a dynamic ArrayPlot so that the rectangles, when clicked, provide the input. Can I use ArrayPlot for this? Or is there something else I should have to use? Answer ArrayPlot is much more than just a simple array like Grid : it represents a ranged 2D dataset, and its visualization can be finetuned by options like DataReversed and DataRange . These features make it quite complicated to reproduce the same layout and order with Grid . Here I offer AnnotatedArrayPlot which comes in handy when your dataset is more than just a flat 2D array. The dynamic interface allows highlighting individual cells and possibly interacting with them. AnnotatedArrayPlot works the same way as ArrayPlot and accepts the same options plus Enabled , HighlightCoordinates , HighlightStyle and HighlightElementFunction . data = {{Missing["HasSomeMoreData"], GrayLevel[ 1], {RGBColor[0, 1, 1], RGBColor[0, 0, 1], GrayLevel[1]}, RGBColor[0, 1, 0]}, {GrayLevel[0], GrayLevel...