PrimaryElective.cs 9.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232
  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 preferenceOverflow; // 志愿超缺(多志愿取1志愿),正数超,负数缺
  90. // 5.31 注
  91. // 多志愿场景下,1志愿超出与下阶段的指标不能重合,新加字段来表示
  92. // 在报名代生成=(groupApprovedCount+actualCount[多志愿使用1志愿])-personCount 或者 actualCount-groupIndicator
  93. // 决策代从报名代继承
  94. public int nextGroupIndicator; // 下阶段组合指标
  95. // 5.22 注
  96. // 决策代,匹配算法后生成=Math.max(0, personCount-groupApprovedCount)
  97. public bool nextAllowSelect;
  98. public bool nextRecommend;
  99. // 5.26 +nextAllowSelect +nextRecommend
  100. public int rankInIndicator; // 组合指标排名
  101. // 5.22 注
  102. // 未录取学生推荐组合中的排名,其它已录或非推荐组合为0(也就是说最多只会有一个group有值)
  103. // 报名代从决策代继承
  104. public int bestInIndicator; // 未录取组合排名最优人数 // 这是一个解释数据,并没有直接参与计算
  105. public int rankInBest; // bestInIndicator中的排名
  106. // 5.22 注
  107. // bestInIndicator:未录学生的最佳成绩在未录满组合中的分布人数
  108. // rankInBest:未录学生最优的组合中的排名,其它已录取或非成绩最优组合为0(也就是说最多只会有一个group有值)
  109. // 报名代从决策代继承
  110. public int rankInDisenroll; // 全组合指标排名,即所有未录取人员中的排名 // 可能没用
  111. // 5.22 注
  112. // 学生在所有未录取学生中的排名,每个未录组合都会有一个排名(分别按6科成绩排)
  113. // 报名代从决策代继承
  114. public decimal scoreSumAll; // 9门成绩
  115. public decimal scoreSumGroup; // 6门成绩
  116. public bool isRecommend; // 推荐组合
  117. // 5.22 注
  118. // 对应未录学生在决策代匹配算法的推荐组合
  119. // 报名代从决策代继承
  120. public int rankInGroup;
  121. // 5.27 注释更正:报名组合在报名人数中的排名 录取组合在录取人数中的排名(录取状态需要迭代)未录取和未录取没有排名
  122. public int rankInGrade; // 选科全校排名 常量 来自成绩导入
  123. public bool allowSelect; // 是否可以报名 报名代专用
  124. public string disabledReason; // 不可报名时的原因 报名代专用
  125. public bool selected; // 已报名
  126. // 5.13 如果是多志愿,按selectedRank区分一志愿、二志愿、三志愿...
  127. public int selectedRank; // 多志愿时的排序
  128. // 5.20 +用来标识填报时拒填
  129. public bool rejected; // 拒绝填报
  130. public string rejectedReason; // 拒绝原因
  131. // 5.22 注
  132. // selected selectedRank rejected rejectedReason以上报名状态在报名代记录,继承至下一代决策代终止
  133. // 5.13 去除动态列,改为固定字段 +
  134. public int actualCount; // 阶段实际报名人数
  135. // 5.22 注
  136. // 本代报名汇总数据,继承至下一代决策代终止
  137. public bool approved; // 已被正常录取
  138. // 5.22 注
  139. // 学生录取状态,持续继承至所有后代,直至被forceAdjusted更改(非必触发)
  140. public bool forceAdjusted; // 已被调剂录取
  141. // 5.22 注
  142. // 学生强制调剂录取状态,持续继承至所有后代(目前只有forceAdjust代可能会更改此值)
  143. public int groupApprovedCount; // 本组合已被录取人数(迭代值)
  144. // 5.22 注
  145. // 学生正常录取汇总数据,每个决策代累加之前所有决策代的录取数据
  146. public int groupForceAdjustedCount; // 本组合已被强制调剂人数(迭代值)
  147. // 5.22 注
  148. // 学生强制调剂录取汇总数据,每个决策代累加之前所有决策代的录取数据(目前只有forceAdjust代会产生这种数据)
  149. }
  150. public class ElectiveSelectGroupStatistics {
  151. public string name; // stat column name
  152. public ElectiveGeneration.ElectiveGroupGenerationStatistic[] groupDescriptors;
  153. }
  154. ;
  155. public class ElectiveSelectModelWrapper {
  156. public ElectiveSelectModel[] models;
  157. public int generation;
  158. public long studentId;
  159. public int preferenceCount;
  160. // 5.31 +到当前阶段为止的未录取人数
  161. public int disenrollCount;
  162. }
  163. // 自选专业
  164. public class ElectiveOptionalMajor
  165. {
  166. public int collegeId;
  167. public string collegeName;
  168. // 可能还包含院校的一些其它属性
  169. public string majorCategoryCode;
  170. public string majorCategoryName;
  171. public Dictionary<string, string> majors;
  172. public string limitationA; // 选科限制1
  173. public string limitationB; // 选科限制2
  174. public List<int> matchedGroupIds; // 匹配的组合
  175. }
  176. #endregion
  177. // 本期会涉及很多隐藏需求,前端会去back-ui按页面+按功能设置很多按钮功能,后续配置为权限组来操作
  178. // 本期后台输出数据的时候不需要按权限屏蔽数据,全量输出即可,以减少后端开发的工作量
  179. // 因为本期要控制隐藏的内容比功能入口、API入口要更精细的粒度,可能是列表的某几列,可能是某些按钮,如果严格API数据规范可能会增加海量的工作。
  180. public interface IPrimaryElectiveService
  181. {
  182. // 旧接口getStudentSelected,返回内容+preferenceCount,志愿数
  183. ElectiveSetting getStudentSelected();
  184. // 学生获取选科状态数据,得到是每个组合最终状态和结果
  185. // 5.13 返回迭代至generation的多代选科表,如查询补录报名,即返回初录报名/初录结果/补录报名3代的模型集合
  186. ElectiveSelectModelWrapper[] getStudentElectiveModels(long studentId, int generation);
  187. // 学生获取自选专业及匹配情况
  188. List<ElectiveOptionalMajor> getOptionalMajors();
  189. // 初选报名。这里简化原型里的操作,直接提交,如需排序,调sortElectiveSelected接口,并刷新getPrimaryElectivesx
  190. void submitPrimaryElective(ElectiveSelectModel[] models, ElectiveEsign esign);
  191. void esign(ElectiveEsign esign);
  192. // 返回学生测评推荐专业以及匹配情况
  193. List<RecommendMajor> getRecommendMajor();
  194. // /*
  195. // AI分析
  196. // 需要的字段:
  197. // 详细见analysis.json
  198. // */
  199. // List<ElectiveSelectGroupStatistics> getAIAnalysis()
  200. }
  201. }