test_conversion.py 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340
  1. import climate_categories as cc
  2. import primap2 as pm2
  3. import pytest
  4. def test_yaml_to_python():
  5. cat = cc.from_yaml("FAO.yaml")
  6. cat.to_python("FAO.py")
  7. def test_make_dict_comprehension_for_faster_typing():
  8. crops = [
  9. "Millet",
  10. "Barley",
  11. "Maize (corn)",
  12. "Sugar cane",
  13. "Beans, dry",
  14. "Oats",
  15. "Rye",
  16. "Sorghum",
  17. "Soya beans",
  18. ]
  19. letters = ["d", "e", "f", "g", "h", "i", "j", "k", "l"]
  20. dict_crops = {}
  21. for crop, letter in zip(crops, letters):
  22. main_code = f"1.A.1.{letter}"
  23. crop_residues_code = f"1.A.1.{letter}.i"
  24. crop_residues_indirect_code = f"1.A.1.{letter}.i.2"
  25. crop_residues_direct_code = f"1.A.1.{letter}.i.1"
  26. dict_crops[main_code] = {
  27. "title": crop,
  28. "comment": crop,
  29. "alternative_codes": main_code.replace(".", ""),
  30. "children": [crop_residues_code],
  31. "info": {"gases": ["CH4", "N2O"]},
  32. }
  33. dict_crops[crop_residues_direct_code] = {
  34. "title": f"{crop} crop residues direct emissions",
  35. "comment": f"{crop} crop residues direct emissions",
  36. "alternative_codes": [crop_residues_direct_code.replace(".", "")],
  37. "info": {"gases": ["CH4", "N2O"]},
  38. }
  39. dict_crops[crop_residues_indirect_code] = {
  40. "title": f"{crop} crop residues indirect emissions",
  41. "comment": f"{crop} crop residues indirect emissions",
  42. "alternative_codes": [crop_residues_direct_code.replace(".", "")],
  43. "info": {"gases": ["CH4", "N2O"]},
  44. }
  45. dict_crops[crop_residues_code] = {
  46. "title": f"{crop} crop residues",
  47. "comment": f"{crop} crop residues",
  48. "alternative_codes": [crop_residues_code.replace(".", "")],
  49. "info": {"gases": ["CH4", "N2O"]},
  50. "children": [[crop_residues_direct_code, crop_residues_indirect_code]],
  51. }
  52. # "1.A.1.c.i.1": {
  53. # "title" : "Potatoes crop residues direct emissions",
  54. # "comment" : "Potatoes crop residues direct emissions",
  55. # "alternative_codes" : ["1A1ci1"],
  56. # "info" : {"gases" : ["CH4", "N2O"]},
  57. # },
  58. # "1.A.1.c.i.2": {
  59. # "title" : "Potatoes crop residues indirect emissions",
  60. # "comment" : "Potatoes crop residues indirect emissions",
  61. # "alternative_codes" : ["1A1ci2"],
  62. # "info" : {"gases" : ["CH4", "N2O"]},
  63. # },
  64. pass
  65. {
  66. "1.A.1.d": {
  67. "title": "Millet",
  68. "comment": "Millet",
  69. "alternative_codes": "1A1d",
  70. "children": ["1.A.1.d.i"],
  71. "info": {"gases": ["CH4", "N2O"]},
  72. },
  73. "1.A.1.d.i.1": {
  74. "title": "Millet crop residues direct emissions",
  75. "comment": "Millet crop residues direct emissions",
  76. "alternative_codes": ["1A1di1"],
  77. "info": {"gases": ["CH4", "N2O"]},
  78. },
  79. "1.A.1.d.i.2": {
  80. "title": "Millet crop residues indirect emissions",
  81. "comment": "Millet crop residues indirect emissions",
  82. "alternative_codes": ["1A1di1"],
  83. "info": {"gases": ["CH4", "N2O"]},
  84. },
  85. "1.A.1.d.i": {
  86. "title": "Millet crop residues",
  87. "comment": "Millet crop residues",
  88. "alternative_codes": ["1A1di"],
  89. "info": {"gases": ["CH4", "N2O"]},
  90. "children": [["1.A.1.d.i.1", "1.A.1.d.i.2"]],
  91. },
  92. "1.A.1.e": {
  93. "title": "Barley",
  94. "comment": "Barley",
  95. "alternative_codes": "1A1e",
  96. "children": ["1.A.1.e.i"],
  97. "info": {"gases": ["CH4", "N2O"]},
  98. },
  99. "1.A.1.e.i.1": {
  100. "title": "Barley crop residues direct emissions",
  101. "comment": "Barley crop residues direct emissions",
  102. "alternative_codes": ["1A1ei1"],
  103. "info": {"gases": ["CH4", "N2O"]},
  104. },
  105. "1.A.1.e.i.2": {
  106. "title": "Barley crop residues indirect emissions",
  107. "comment": "Barley crop residues indirect emissions",
  108. "alternative_codes": ["1A1ei1"],
  109. "info": {"gases": ["CH4", "N2O"]},
  110. },
  111. "1.A.1.e.i": {
  112. "title": "Barley crop residues",
  113. "comment": "Barley crop residues",
  114. "alternative_codes": ["1A1ei"],
  115. "info": {"gases": ["CH4", "N2O"]},
  116. "children": [["1.A.1.e.i.1", "1.A.1.e.i.2"]],
  117. },
  118. "1.A.1.f": {
  119. "title": "Maize (corn)",
  120. "comment": "Maize (corn)",
  121. "alternative_codes": "1A1f",
  122. "children": ["1.A.1.f.i"],
  123. "info": {"gases": ["CH4", "N2O"]},
  124. },
  125. "1.A.1.f.i.1": {
  126. "title": "Maize (corn) crop residues direct emissions",
  127. "comment": "Maize (corn) crop residues direct emissions",
  128. "alternative_codes": ["1A1fi1"],
  129. "info": {"gases": ["CH4", "N2O"]},
  130. },
  131. "1.A.1.f.i.2": {
  132. "title": "Maize (corn) crop residues indirect emissions",
  133. "comment": "Maize (corn) crop residues indirect emissions",
  134. "alternative_codes": ["1A1fi1"],
  135. "info": {"gases": ["CH4", "N2O"]},
  136. },
  137. "1.A.1.f.i": {
  138. "title": "Maize (corn) crop residues",
  139. "comment": "Maize (corn) crop residues",
  140. "alternative_codes": ["1A1fi"],
  141. "info": {"gases": ["CH4", "N2O"]},
  142. "children": [["1.A.1.f.i.1", "1.A.1.f.i.2"]],
  143. },
  144. "1.A.1.g": {
  145. "title": "Sugar cane",
  146. "comment": "Sugar cane",
  147. "alternative_codes": "1A1g",
  148. "children": ["1.A.1.g.i"],
  149. "info": {"gases": ["CH4", "N2O"]},
  150. },
  151. "1.A.1.g.i.1": {
  152. "title": "Sugar cane crop residues direct emissions",
  153. "comment": "Sugar cane crop residues direct emissions",
  154. "alternative_codes": ["1A1gi1"],
  155. "info": {"gases": ["CH4", "N2O"]},
  156. },
  157. "1.A.1.g.i.2": {
  158. "title": "Sugar cane crop residues indirect emissions",
  159. "comment": "Sugar cane crop residues indirect emissions",
  160. "alternative_codes": ["1A1gi1"],
  161. "info": {"gases": ["CH4", "N2O"]},
  162. },
  163. "1.A.1.g.i": {
  164. "title": "Sugar cane crop residues",
  165. "comment": "Sugar cane crop residues",
  166. "alternative_codes": ["1A1gi"],
  167. "info": {"gases": ["CH4", "N2O"]},
  168. "children": [["1.A.1.g.i.1", "1.A.1.g.i.2"]],
  169. },
  170. "1.A.1.h": {
  171. "title": "Beans, dry",
  172. "comment": "Beans, dry",
  173. "alternative_codes": "1A1h",
  174. "children": ["1.A.1.h.i"],
  175. "info": {"gases": ["CH4", "N2O"]},
  176. },
  177. "1.A.1.h.i.1": {
  178. "title": "Beans, dry crop residues direct emissions",
  179. "comment": "Beans, dry crop residues direct emissions",
  180. "alternative_codes": ["1A1hi1"],
  181. "info": {"gases": ["CH4", "N2O"]},
  182. },
  183. "1.A.1.h.i.2": {
  184. "title": "Beans, dry crop residues indirect emissions",
  185. "comment": "Beans, dry crop residues indirect emissions",
  186. "alternative_codes": ["1A1hi1"],
  187. "info": {"gases": ["CH4", "N2O"]},
  188. },
  189. "1.A.1.h.i": {
  190. "title": "Beans, dry crop residues",
  191. "comment": "Beans, dry crop residues",
  192. "alternative_codes": ["1A1hi"],
  193. "info": {"gases": ["CH4", "N2O"]},
  194. "children": [["1.A.1.h.i.1", "1.A.1.h.i.2"]],
  195. },
  196. "1.A.1.i": {
  197. "title": "Oats",
  198. "comment": "Oats",
  199. "alternative_codes": "1A1i",
  200. "children": ["1.A.1.i.i"],
  201. "info": {"gases": ["CH4", "N2O"]},
  202. },
  203. "1.A.1.i.i.1": {
  204. "title": "Oats crop residues direct emissions",
  205. "comment": "Oats crop residues direct emissions",
  206. "alternative_codes": ["1A1ii1"],
  207. "info": {"gases": ["CH4", "N2O"]},
  208. },
  209. "1.A.1.i.i.2": {
  210. "title": "Oats crop residues indirect emissions",
  211. "comment": "Oats crop residues indirect emissions",
  212. "alternative_codes": ["1A1ii1"],
  213. "info": {"gases": ["CH4", "N2O"]},
  214. },
  215. "1.A.1.i.i": {
  216. "title": "Oats crop residues",
  217. "comment": "Oats crop residues",
  218. "alternative_codes": ["1A1ii"],
  219. "info": {"gases": ["CH4", "N2O"]},
  220. "children": [["1.A.1.i.i.1", "1.A.1.i.i.2"]],
  221. },
  222. "1.A.1.j": {
  223. "title": "Rye",
  224. "comment": "Rye",
  225. "alternative_codes": "1A1j",
  226. "children": ["1.A.1.j.i"],
  227. "info": {"gases": ["CH4", "N2O"]},
  228. },
  229. "1.A.1.j.i.1": {
  230. "title": "Rye crop residues direct emissions",
  231. "comment": "Rye crop residues direct emissions",
  232. "alternative_codes": ["1A1ji1"],
  233. "info": {"gases": ["CH4", "N2O"]},
  234. },
  235. "1.A.1.j.i.2": {
  236. "title": "Rye crop residues indirect emissions",
  237. "comment": "Rye crop residues indirect emissions",
  238. "alternative_codes": ["1A1ji1"],
  239. "info": {"gases": ["CH4", "N2O"]},
  240. },
  241. "1.A.1.j.i": {
  242. "title": "Rye crop residues",
  243. "comment": "Rye crop residues",
  244. "alternative_codes": ["1A1ji"],
  245. "info": {"gases": ["CH4", "N2O"]},
  246. "children": [["1.A.1.j.i.1", "1.A.1.j.i.2"]],
  247. },
  248. "1.A.1.k": {
  249. "title": "Sorghum",
  250. "comment": "Sorghum",
  251. "alternative_codes": "1A1k",
  252. "children": ["1.A.1.k.i"],
  253. "info": {"gases": ["CH4", "N2O"]},
  254. },
  255. "1.A.1.k.i.1": {
  256. "title": "Sorghum crop residues direct emissions",
  257. "comment": "Sorghum crop residues direct emissions",
  258. "alternative_codes": ["1A1ki1"],
  259. "info": {"gases": ["CH4", "N2O"]},
  260. },
  261. "1.A.1.k.i.2": {
  262. "title": "Sorghum crop residues indirect emissions",
  263. "comment": "Sorghum crop residues indirect emissions",
  264. "alternative_codes": ["1A1ki1"],
  265. "info": {"gases": ["CH4", "N2O"]},
  266. },
  267. "1.A.1.k.i": {
  268. "title": "Sorghum crop residues",
  269. "comment": "Sorghum crop residues",
  270. "alternative_codes": ["1A1ki"],
  271. "info": {"gases": ["CH4", "N2O"]},
  272. "children": [["1.A.1.k.i.1", "1.A.1.k.i.2"]],
  273. },
  274. "1.A.1.l": {
  275. "title": "Soya beans",
  276. "comment": "Soya beans",
  277. "alternative_codes": "1A1l",
  278. "children": ["1.A.1.l.i"],
  279. "info": {"gases": ["CH4", "N2O"]},
  280. },
  281. "1.A.1.l.i.1": {
  282. "title": "Soya beans crop residues direct emissions",
  283. "comment": "Soya beans crop residues direct emissions",
  284. "alternative_codes": ["1A1li1"],
  285. "info": {"gases": ["CH4", "N2O"]},
  286. },
  287. "1.A.1.l.i.2": {
  288. "title": "Soya beans crop residues indirect emissions",
  289. "comment": "Soya beans crop residues indirect emissions",
  290. "alternative_codes": ["1A1li1"],
  291. "info": {"gases": ["CH4", "N2O"]},
  292. },
  293. "1.A.1.l.i": {
  294. "title": "Soya beans crop residues",
  295. "comment": "Soya beans crop residues",
  296. "alternative_codes": ["1A1li"],
  297. "info": {"gases": ["CH4", "N2O"]},
  298. "children": [["1.A.1.l.i.1", "1.A.1.l.i.2"]],
  299. },
  300. }
  301. @pytest.mark.xfail
  302. def test_conversion_from_FAO_to_IPCC2006_PRIMAP():
  303. # make categorisation A from yaml
  304. categorisation_a = cc.from_yaml("FAO.yaml")
  305. # make categorisation B from yaml
  306. categorisation_b = cc.IPCC2006_PRIMAP
  307. # categories not part of climate categories so we need to add them manually
  308. cats = {
  309. "A": categorisation_a,
  310. "B": categorisation_b,
  311. }
  312. # make conversion from csv
  313. conv = cc.Conversion.from_csv("conversion.FAO.IPPCC2006_PRIMAP.csv", cats=cats)
  314. ds = pm2.open_dataset(
  315. "extracted_data/v2024-11-14/FAOSTAT_Agrifood_system_emissions_v2024-11-14.nc"
  316. )
  317. result = ds.pr.convert(
  318. dim="category",
  319. conversion=conv,
  320. auxiliary_dimensions={"gas": "source (gas)"},
  321. )
  322. assert result