PrimaryElective.cs 8.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224
  1. using System;
  2. using System.Collections.Generic;
  3. namespace mxdemo.Mind
  4. {
  5. #region model
  6. public class ElectiveSetting
  7. {
  8. //"selectResult": {
  9. // "params": {},
  10. // "roundId": 8,
  11. // "schoolId": 1,
  12. // "year": 2021,
  13. // "name": "第三次",
  14. // "beginTime": "2022-02-16",
  15. // "endTime": "2022-02-17",
  16. // "groupIds": "1,2,3,10,11,12",
  17. public int currentGeneration; // 当前报名状态
  18. public int preferenceCount; // 选填志愿数量
  19. // "groupList": [
  20. // {
  21. // "params": {},
  22. // "groupId": 1,
  23. // "mask": 448,
  24. // "name": "物化生",
  25. // "rank": 1
  26. // },
  27. // {
  28. // "params": { },
  29. // "groupId": 2,
  30. // "mask": 416,
  31. // "name": "物化政",
  32. // "rank": 2
  33. // },
  34. // {
  35. // "params": { },
  36. // "groupId": 3,
  37. // "mask": 400,
  38. // "name": "物化地",
  39. // "rank": 3
  40. // },
  41. // {
  42. // "params": { },
  43. // "groupId": 10,
  44. // "mask": 56,
  45. // "name": "历政地",
  46. // "rank": 10
  47. // },
  48. // {
  49. // "params": { },
  50. // "groupId": 11,
  51. // "mask": 104,
  52. // "name": "历政生",
  53. // "rank": 11
  54. // },
  55. // {
  56. // "params": { },
  57. // "groupId": 12,
  58. // "mask": 88,
  59. // "name": "历生地",
  60. // "rank": 12
  61. // }
  62. // ],
  63. // "state": "1"
  64. //},
  65. //"allowSelect": false
  66. }
  67. // 评测推荐专业
  68. public class RecommendMajor
  69. {
  70. public string majorCategoryName; // 专业类别
  71. public int majorCategoryCode; // 专业编码
  72. public List<int> matchedGroupIds; // // 匹配哪几个组合?
  73. }
  74. // 学生这里无论什么时间得到的都是最终结果,不需要中间快照,以此区分校长的选科数据。
  75. // 校长的选科数据,初选时与学生相同;补录时也需要这份数据、但也需要初选与补录的差异部分;排名均衡同理
  76. public class ElectiveSelectModel
  77. {
  78. public int groupId; // 组合
  79. public string groupName; // 名称
  80. public int classCount; // 班级数
  81. public int personCount; // 人数设置
  82. // 5.22 注
  83. // 常量 来自发布选科
  84. // 5.7 hht +字段,用来展示报告
  85. public int groupIndicator; // 组合指标 // primary时为设置人数,之后为决策完毕后剩余的设置数
  86. // 5.22 注
  87. // 报名代=Math.max(0, personCount-groupApprovedCount) 决策代=从报名代继承值
  88. // 设置人数-组合录取人数(迭代数)
  89. public int nextGroupIndicator; // 下阶段组合指标
  90. // 5.22 注
  91. // 报名代=0 决策代用来表示超缺=(groupApprovedCount+actualCount[多志愿使用1志愿])-personCount
  92. public bool nextAllowSelect;
  93. public bool nextRecommend;
  94. // 5.26 +nextAllowSelect +nextRecommend
  95. public int rankInIndicator; // 组合指标排名
  96. // 5.22 注
  97. // 未录取学生推荐组合中的排名,其它已录或非推荐组合为0(也就是说最多只会有一个group有值)
  98. // 报名代从决策代继承
  99. public int bestInIndicator; // 未录取组合排名最优人数 // 这是一个解释数据,并没有直接参与计算
  100. public int rankInBest; // bestInIndicator中的排名
  101. // 5.22 注
  102. // bestInIndicator:未录学生的最佳成绩在未录满组合中的分布人数
  103. // rankInBest:未录学生最优的组合中的排名,其它已录取或非成绩最优组合为0(也就是说最多只会有一个group有值)
  104. // 报名代从决策代继承
  105. public int rankInDisenroll; // 全组合指标排名,即所有未录取人员中的排名 // 可能没用
  106. // 5.22 注
  107. // 学生在所有未录取学生中的排名,每个未录组合都会有一个排名(分别按6科成绩排)
  108. // 报名代从决策代继承
  109. public decimal scoreSumAll; // 9门成绩
  110. public decimal scoreSumGroup; // 6门成绩
  111. public bool isRecommend; // 推荐组合
  112. // 5.22 注
  113. // 对应未录学生在决策代匹配算法的推荐组合
  114. // 报名代从决策代继承
  115. public int rankInGroup;
  116. // 5.27 注释更正:报名组合在报名人数中的排名 录取组合在录取人数中的排名(录取状态需要迭代)未录取和未录取没有排名
  117. public int rankInGrade; // 选科全校排名 常量 来自成绩导入
  118. public bool allowSelect; // 是否可以报名 报名代专用
  119. public string disabledReason; // 不可报名时的原因 报名代专用
  120. public bool selected; // 已报名
  121. // 5.13 如果是多志愿,按selectedRank区分一志愿、二志愿、三志愿...
  122. public int selectedRank; // 多志愿时的排序
  123. // 5.20 +用来标识填报时拒填
  124. public bool rejected; // 拒绝填报
  125. public string rejectedReason; // 拒绝原因
  126. // 5.22 注
  127. // selected selectedRank rejected rejectedReason以上报名状态在报名代记录,继承至下一代决策代终止
  128. // 5.13 去除动态列,改为固定字段 +
  129. public int actualCount; // 阶段实际报名人数
  130. // 5.22 注
  131. // 本代报名汇总数据,继承至下一代决策代终止
  132. public bool approved; // 已被正常录取
  133. // 5.22 注
  134. // 学生录取状态,持续继承至所有后代,直至被forceAdjusted更改(非必触发)
  135. public bool forceAdjusted; // 已被调剂录取
  136. // 5.22 注
  137. // 学生强制调剂录取状态,持续继承至所有后代(目前只有forceAdjust代可能会更改此值)
  138. public int groupApprovedCount; // 本组合已被录取人数(迭代值)
  139. // 5.22 注
  140. // 学生正常录取汇总数据,每个决策代累加之前所有决策代的录取数据
  141. public int groupForceAdjustedCount; // 本组合已被强制调剂人数(迭代值)
  142. // 5.22 注
  143. // 学生强制调剂录取汇总数据,每个决策代累加之前所有决策代的录取数据(目前只有forceAdjust代会产生这种数据)
  144. }
  145. public class ElectiveSelectGroupStatistics {
  146. public string name; // stat column name
  147. public ElectiveGeneration.ElectiveGroupGenerationStatistic[] groupDescriptors;
  148. }
  149. ;
  150. public class ElectiveSelectModelWrapper {
  151. public ElectiveSelectModel[] models;
  152. public int generation;
  153. public long studentId;
  154. }
  155. // 自选专业
  156. public class ElectiveOptionalMajor
  157. {
  158. public int collegeId;
  159. public string collegeName;
  160. // 可能还包含院校的一些其它属性
  161. public string majorCategoryCode;
  162. public string majorCategoryName;
  163. public Dictionary<string, string> majors;
  164. public string limitationA; // 选科限制1
  165. public string limitationB; // 选科限制2
  166. public List<int> matchedGroupIds; // 匹配的组合
  167. }
  168. #endregion
  169. // 本期会涉及很多隐藏需求,前端会去back-ui按页面+按功能设置很多按钮功能,后续配置为权限组来操作
  170. // 本期后台输出数据的时候不需要按权限屏蔽数据,全量输出即可,以减少后端开发的工作量
  171. // 因为本期要控制隐藏的内容比功能入口、API入口要更精细的粒度,可能是列表的某几列,可能是某些按钮,如果严格API数据规范可能会增加海量的工作。
  172. public interface IPrimaryElectiveService
  173. {
  174. // 旧接口getStudentSelected,返回内容+preferenceCount,志愿数
  175. ElectiveSetting getStudentSelected();
  176. // 学生获取选科状态数据,得到是每个组合最终状态和结果
  177. // 5.13 返回迭代至generation的多代选科表,如查询补录报名,即返回初录报名/初录结果/补录报名3代的模型集合
  178. ElectiveSelectModelWrapper[] getStudentElectiveModels(long studentId, int generation);
  179. // 学生获取自选专业及匹配情况
  180. List<ElectiveOptionalMajor> getOptionalMajors();
  181. // 初选报名。这里简化原型里的操作,直接提交,如需排序,调sortElectiveSelected接口,并刷新getPrimaryElectivesx
  182. void submitPrimaryElective(ElectiveSelectModel[] models, ElectiveEsign esign);
  183. void esign(ElectiveEsign esign);
  184. // 返回学生测评推荐专业以及匹配情况
  185. List<RecommendMajor> getRecommendMajor();
  186. // /*
  187. // AI分析
  188. // 需要的字段:
  189. // 详细见analysis.json
  190. // */
  191. // List<ElectiveSelectGroupStatistics> getAIAnalysis()
  192. }
  193. }