研究恒星的属性
从 StarData 中可以检索超过 105 颗恒星的属性. 选取一个 3000 颗恒星的随机取样进行研究.
In[1]:=
stars = StarData[{"RandomEntities", 3000}];
对每一个实体都提供有各种属性信息.
In[2]:=
sun = \!\(\*
NamespaceBox["LinguisticAssistant",
DynamicModuleBox[{Typeset`query$$ = "Sun", Typeset`boxes$$ =
TemplateBox[{"\"Sun\"",
RowBox[{"Entity", "[",
RowBox[{"\"Star\"", ",", "\"Sun\""}], "]"}],
"\"Entity[\\\"Star\\\", \\\"Sun\\\"]\"", "\"star\""},
"Entity"],
Typeset`allassumptions$$ = {{
"type" -> "Clash", "word" -> "Sun",
"template" -> "Assuming \"${word}\" is ${desc1}. Use as \
${desc2} instead", "count" -> "4",
"Values" -> {{
"name" -> "Star", "desc" -> " referring to stars",
"input" -> "*C.Sun-_*Star-"}, {
"name" -> "CalendarEventName", "desc" -> "a weekday",
"input" -> "*C.Sun-_*CalendarEventName-"}, {
"name" -> "Word", "desc" -> "a word",
"input" -> "*C.Sun-_*Word-"}, {
"name" -> "Surname", "desc" -> "a surname",
"input" -> "*C.Sun-_*Surname-"}}}},
Typeset`assumptions$$ = {}, Typeset`open$$ = {1, 2},
Typeset`querystate$$ = {
"Online" -> True, "Allowed" -> True,
"mparse.jsp" -> 1.321761`6.572697926887039, "Messages" -> {}}},
DynamicBox[ToBoxes[
AlphaIntegration`LinguisticAssistantBoxes["", 4, Automatic,
Dynamic[Typeset`query$$],
Dynamic[Typeset`boxes$$],
Dynamic[Typeset`allassumptions$$],
Dynamic[Typeset`assumptions$$],
Dynamic[Typeset`open$$],
Dynamic[Typeset`querystate$$]], StandardForm],
ImageSizeCache->{114., {7., 15.}},
TrackedSymbols:>{
Typeset`query$$, Typeset`boxes$$, Typeset`allassumptions$$,
Typeset`assumptions$$, Typeset`open$$, Typeset`querystate$$}],
DynamicModuleValues:>{},
UndoTrackedVariables:>{Typeset`open$$}],
BaseStyle->{"Deploy"},
DeleteWithContents->True,
Editable->False,
SelectWithContents->True]\);
In[3]:=
StarData[sun, "Properties"] // Length
Out[3]=
提取随机选择的恒星的有效温度,且只选取有数据的恒星.
In[4]:=
temps = Flatten[
DeleteMissing[StarData[#, "EffectiveTemperature"]] & /@
Partition[stars, 100]];
计算温度的某些描述性统计量.
In[5]:=
stats = {Min, Max, Mean, Median, StandardDeviation};
TableForm[{Map[#[temps] &, stats]}, TableHeadings -> {None, stats}]
Out[5]//TableForm=
绘制恒星温度的直方图.
In[6]:=
h = Histogram[temps, 25, PDF, AxesLabel -> Automatic]
Out[6]=
用非参数化分布估计温度分布.
In[7]:=
skd = SmoothKernelDistribution[temps, "Oversmooth"]
Out[7]=
用长尾参数化分布估计温度分布.
In[8]:=
edist = EstimatedDistribution[temps, StableDistribution[a, b, c, d]]
Out[8]=
比较估计的概率密度函数并查看和太阳温度的关系.
显示完整的 Wolfram 语言输入
Out[9]=