<?xml version="1.0" encoding="UTF-8"?>
<TEI xml:space="preserve" xmlns="http://www.tei-c.org/ns/1.0" 
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" 
xsi:schemaLocation="http://www.tei-c.org/ns/1.0 https://raw.githubusercontent.com/kermitt2/grobid/master/grobid-home/schemas/xsd/Grobid.xsd"
 xmlns:xlink="http://www.w3.org/1999/xlink">
	<teiHeader xml:lang="en">
		<fileDesc>
			<titleStmt>
				<title level="a" type="main">Application of Programming Cocktails Identity Cards to Development Complexity Analysis</title>
			</titleStmt>
			<publicationStmt>
				<publisher/>
				<availability status="unknown"><licence/></availability>
			</publicationStmt>
			<sourceDesc>
				<biblStruct>
					<analytic>
						<author role="corresp">
							<persName><forename type="first">Alvaro</forename><forename type="middle">Costa</forename><surname>Neto</surname></persName>
							<email>alvaro@ifsp.edu.br</email>
							<affiliation key="aff0">
								<orgName type="department">Instituto Federal de Educação</orgName>
								<orgName type="institution">Ciência e Tecnologia de São Paulo</orgName>
								<address>
									<addrLine>Avenida C-1, 250</addrLine>
									<postCode>14781-502</postCode>
									<settlement>Barretos</settlement>
									<region>SP</region>
									<country key="BR">Brasil</country>
								</address>
							</affiliation>
							<affiliation key="aff1">
								<orgName type="institution">Instituto Politécnico de Bragança</orgName>
								<address>
									<addrLine>Campus de Santa Apolónia</addrLine>
									<postCode>5300-253</postCode>
									<settlement>Bragança</settlement>
									<country key="PT">Portugal</country>
								</address>
							</affiliation>
							<affiliation key="aff2">
								<orgName type="department">Campus de Gualtar</orgName>
								<orgName type="laboratory">ALGORITMI Research Centre/LASI</orgName>
								<orgName type="institution">DI -University of Minho</orgName>
								<address>
									<addrLine>Rua da Universidade</addrLine>
									<postCode>4710-057</postCode>
									<settlement>Braga</settlement>
									<country key="PT">Portugal</country>
								</address>
							</affiliation>
						</author>
						<author>
							<persName><forename type="first">Maria</forename><surname>João</surname></persName>
						</author>
						<author>
							<persName><forename type="first">Varanda</forename><surname>Pereira</surname></persName>
							<affiliation key="aff1">
								<orgName type="institution">Instituto Politécnico de Bragança</orgName>
								<address>
									<addrLine>Campus de Santa Apolónia</addrLine>
									<postCode>5300-253</postCode>
									<settlement>Bragança</settlement>
									<country key="PT">Portugal</country>
								</address>
							</affiliation>
						</author>
						<author>
							<persName><forename type="first">Pedro</forename><forename type="middle">Rangel</forename><surname>Henriques</surname></persName>
							<affiliation key="aff2">
								<orgName type="department">Campus de Gualtar</orgName>
								<orgName type="laboratory">ALGORITMI Research Centre/LASI</orgName>
								<orgName type="institution">DI -University of Minho</orgName>
								<address>
									<addrLine>Rua da Universidade</addrLine>
									<postCode>4710-057</postCode>
									<settlement>Braga</settlement>
									<country key="PT">Portugal</country>
								</address>
							</affiliation>
						</author>
						<title level="a" type="main">Application of Programming Cocktails Identity Cards to Development Complexity Analysis</title>
					</analytic>
					<monogr>
						<idno type="ISSN">1613-0073</idno>
					</monogr>
					<idno type="MD5">F096E0E7874BCD6DE692E41E430BDD07</idno>
				</biblStruct>
			</sourceDesc>
		</fileDesc>
		<encodingDesc>
			<appInfo>
				<application version="0.7.2" ident="GROBID" when="2025-04-23T19:00+0000">
					<desc>GROBID - A machine learning software for extracting information from scholarly documents</desc>
					<ref target="https://github.com/kermitt2/grobid"/>
				</application>
			</appInfo>
		</encodingDesc>
		<profileDesc>
			<textClass>
				<keywords>
					<term>programming cocktails</term>
					<term>programming languages</term>
					<term>development complexity</term>
					<term>cognitive analysis</term>
				</keywords>
			</textClass>
			<abstract>
<div xmlns="http://www.tei-c.org/ns/1.0"><p>Complexity in software projects tends to grow considerably as resources and stakeholders raise in numbers. Several factors may contribute to this, ranging from miscommunication between developers, to excessive dependency on external libraries and frameworks. Consequently, managing both developers and the assets they use becomes increasingly hard as features are implemented and changes in linguistic characteristics and coding styles become necessary. This position paper presents Programming Cocktails, their Ingredients, and Resources, three basic software development management concepts. These three main concepts culminate in Programming Cocktails Identity Cards, an ontology-based modelling technique to aid in assessing, planning, and understanding how each development technology contributes-both positively and negatively-to several aspects of software development, such as cognitive burden, risk and cost.</p></div>
			</abstract>
		</profileDesc>
	</teiHeader>
	<text xml:lang="en">
		<body>
<div xmlns="http://www.tei-c.org/ns/1.0"><head n="1.">Introduction</head><p>It is well established that as development projects grow in size and requirements multiply, complexity also increases <ref type="bibr" target="#b0">[1,</ref><ref type="bibr" target="#b1">2,</ref><ref type="bibr" target="#b2">3,</ref><ref type="bibr" target="#b3">4]</ref>. From the many factors that contribute to this growth, the interconnection between programming technologies (such as languages, libraries, tools and frameworks) poses challenges that may negatively affect cognitive effectiveness, raise risks and generate costs.</p><p>In this context, analysis should be made on the combined uses and interconnections of these technologies, reaching beyond comparison of individual metrics (as it is common <ref type="bibr" target="#b4">[5,</ref><ref type="bibr" target="#b5">6,</ref><ref type="bibr" target="#b6">7]</ref>). This point-of-view highlights several factors that may influence success in choosing and managing which programming technologies should be used in a certain project. Which language is a better fit for a substitution mid-development? What cognitive strains would it impose based on its differences to other languages, libraries and frameworks already in use? Do these differences raise security risks and vulnerabilities, or do they enforce behaviors that may nullify each other weaknesses?</p><p>The answers to these questions rely on the knowledge behind these combinations and how to better use and choose which technologies should be integrated into a development project. Naturally, it is of utmost importance to structure and analyse this knowledge in a productive way, considering, first of all, which factor is under evaluation (risk, cost, cognitive burden etc.), and secondly, how each technology relates to each other in this analysis. This paper presents Programming Cocktails as a formal, structured and novel concept that should aid developers, managers and their peers in reaching further conclusions about the intrinsic relationships between languages, libraries, frameworks and tools in their projects.</p><p>This position paper is divided into five sections. After the introduction and contextualization in Section 1, Section 2 introduces the basic concepts of Programming Cocktails, Ingredients, and Resources. Section 3 presents Cocktail Identity Cards as an ontological form of identification for Programming Cocktails. Section 4 proposes augmentations to and uses for the Cocktail Identity Cards that could  improve planning of several aspects in development life-cycles, both technical, such as risk and cost, and psychological, such as cognitive burden and affinity attrition. Finally, Section 5 concludes the article with final remarks of what has already been modelled via Cocktail Identity Cards, and what is planned to be researched and implemented in the near future.</p></div>
<div xmlns="http://www.tei-c.org/ns/1.0"><head n="2.">Programming Cocktails</head><p>At its basis, Programming Cocktails are the sets of programming technologies that are directly used to develop software systems <ref type="bibr" target="#b7">[8]</ref>. They may be composed of four types of Ingredients:</p><p>• Languages for programming, communication, configuration etc.</p><p>• Libraries, both in source and pre-compiled varieties; • Frameworks, as complementary code that requires the use or adoption of specific protocols, behavior or paradigms; • Tools that are directly used in the development tasks, such as source code editors, and IDEs.</p><p>Finally, technologies that indirectly participate in the development process, such as services and runtime support systems (e.g. Database Management Systems, DBMS) are considered Resources. While some of them might have components that are directly used in the development process (such as a connection library for a DBMS), the Resource itself is intended to support execution, not development.</p><p>These concepts were defined in an ontology that was initially created to structure knowledge about data that was gathered in a survey <ref type="bibr" target="#b7">[8]</ref>. It formed the basis on which the entire model of Programming Cocktails was created, including the Cocktail Identity Cards (explained in Section 3). Figure <ref type="figure" target="#fig_1">2</ref> shows the open conceptual model for the ontology (see Figure <ref type="figure" target="#fig_0">1</ref> for the graphical notation), with all its basic definitions, such as the previously mentioned concepts, the core concepts of System, Development, and Cocktail, as well as Tasks, which correspond to actual development tasks, such as Front-end Development, Database Communication and equivalent. There are two more important points to be made about the ontology:</p><p>• Despite the fact that the original intention of the ontology was to structure the data gathered in the survey <ref type="bibr" target="#b7">[8]</ref>, the results have become a foundation for modelling Cocktails via instantiation of the open conceptual model. This should aid stakeholders in the development team to visualize, document, analyse and decide which programming technologies should be used and why; • The conceptual model is considered open because the definition of the Task specializations (TaskA to TaskZ) is deferred to the individuals that will model Programming Cocktails using it. This decision aims to avoid pre-defining tasks that would eventually be either too generic for any kind of useful representation, or too granular and specific, which would inevitably lead to obsolescence.</p><p>The conceptual model is the starting point to the actual modelling of the Programming Cocktails, leaving practical application to its instantiation: the Cocktail Identity Cards. </p></div>
<div xmlns="http://www.tei-c.org/ns/1.0"><head n="3.">Cocktail Identity Cards</head><p>The conceptual model forms the basis for the modelling process, providing guidelines akin to schematics for the actual model. Its instantiation, consequently, renders a series of interconnected individuals<ref type="foot" target="#foot_0">1</ref> that provides an instant overview of the Cocktail's structure. If carefully drawn and pruned<ref type="foot" target="#foot_1">2</ref> , the resulting diagram is easily recognizable and most of the structural information about the Cocktail is immediately observable, such as ingredient quantity and diversity, different branches of development, which languages are more dependant of complementary ingredients, etc.</p><p>Figures <ref type="figure" target="#fig_2">3 and 4</ref> show two Cocktail Identity Cards, for two different software systems. The first is a Web application for an in-house Questions and Answers (Q&amp;A) system. As can be seen, not all relations are shown, as the System, Development and Cocktail concepts are hidden to improve legibility. The tasks were defined in a higher level of abstraction, including only general areas of development (markup, styling and scripting). This might not be the case with a different Cocktail, or even at another situation for the same Cocktail that requires a more detailed representation of each Ingredient's role in the project implementation. In the end, the definition of the granularity (or abstraction level) of the tasks is highly situational. The second Identity Card (shown in Figure <ref type="figure" target="#fig_2">4</ref>) models a Covid-19 pass management mobile application. It has two branches of development, one for each target platform: iOS and Android. This Identity Card also shows that both languages, Swift and Kotlin, are less dependant on complementary code, as no instances of Library and Framework are connected to them <ref type="foot" target="#foot_2">3</ref> . This may lead to a lower complexity, as linguistic and psychological features (such as affinity <ref type="bibr" target="#b8">[9,</ref><ref type="bibr" target="#b9">10]</ref> and cognitive load <ref type="bibr" target="#b10">[11]</ref>) are constant in each branch.</p><p>The Cocktail Identity Cards are useful as-is for quick identification of several characteristics of the Cocktails they represent. Nonetheless, if augmented with further information, it may serve as a foundation for other, more complex analysis.</p></div>
<div xmlns="http://www.tei-c.org/ns/1.0"><head n="4.">Possible Uses and Augmentation for Cocktail Identity Cards</head><p>Despite the immediate structural feedback obtained from the Identity Cards, more can be represented and documented if the relationships in the model are augmented to represent specific metrics. These metrics may relate to technical aspects, such as cost of maintenance, size needed for cloud hosting, or  definitive linguistic metrics, such as number of data types and functions. On the other hand, some more qualitative metrics could also be applied, such as cognitive burden <ref type="bibr" target="#b11">[12]</ref>, affinity, security risk, etc. With these augmentations, the Identity Cards would provide different points-of-view for the structure of the Cocktail. Stakeholders would be able to quickly assess current, former and even possibilities for future changes in the Cocktail's structure and how these changes would affect each of the augmented metrics. This use would form a historic account of how the programming technologies in the project have changed and evolved, aiding in tracking and predicting software evolution, as the software evolution can be represented by a set of identity cards in a timeline sequence.</p><p>A second possible use for the Identity Cards is decision support. By comparing different Identity Cards augmented with metrics such as cost, risk and cognitive burden, decision on which technologies should be included (or substituted) in the project could be taken with an overview of its impact on the project and on the team behind it. Figure <ref type="figure" target="#fig_3">5</ref> presents part of App1's Cocktail Identity Card (see Figure <ref type="figure">3</ref>) with hypothetical augmentations that represent security risks for each Ingredient. The values superimposed on the relations (HIGH and LOW ) could be measured based on specific linguistic features, such as the direct memory access via pointers, manual memory allocation, lack of bounds management in data structures, etc. but could also take into consideration historic findings about each technology and the inherent nature of its use. As an example of the latter, a markup language is naturally less vulnerable to exploits as it tends to express only structure instead of behavior and would contribute less to possible vulnerabilities. A simple score-card could be created to establish the level of risk for each Ingredient, and most important of all, for the relations between each other (such as between NodeJS and JavaScript in Figure <ref type="figure" target="#fig_3">5</ref>).</p><p>As for comparison against other modelling options, a few points can be made:</p><p>• By their own nature, ontologies are more flexible in their construction than other modelling techniques that have pre-defined semantics, such as Class Diagrams. This fact could lend Cocktail Identity Cards to better fit specific scenarios, as characteristics from different points of view can be assembled in one model. One possible caveat with this argument is that this flexibility could also decrease standardization. It could eventually hinder communication and information exchange between peers that come from different projects, given that each group would adapt the ontology to their particular needs; • Different levels of abstraction can be expressed in a single model, as new concepts do not have to adhere to any sort of pre-established abstraction level or standard; • By using only ontological modelling, fragmentation of tools and techniques can be avoided or at least reduced. This lowers development complexity between different peers in a project, such as developers, designers, managers, etc.</p></div>
<div xmlns="http://www.tei-c.org/ns/1.0"><head n="5.">Conclusion</head><p>Programming Cocktails provide a novel way to model and observe how different technologies compose and interact in a development setting. This paper presented the foundational ideas and concepts behind them, as well as their immediate result: Cocktail Identity Cards. Through future research into augmenting these Identity Cards, stakeholders in a software development project could evaluate, record, document and analyse different metrics, ranging from the most technical and quantitative, such as points of vulnerability and racing conditions, to more philosophical and qualitative ones, such as quality, affinity, and attrition. Software evolution and maintenance could also be tackled by constructing historic accounts for the changes that occur in Cocktails during its lifetime, establishing a sequence of Identity Cards that represent the evolution of their development technologies. The Cocktail Identity Cards will be used to assess cognitive burden in Programming Cocktails, culminating in a decisionsupport methodology that should aid developers and educators in choosing programming languages, frameworks, libraries and tools that lessens the cognitive load requirements for developers and students.</p></div><figure xmlns="http://www.tei-c.org/ns/1.0" xml:id="fig_0"><head>Figure 1 :</head><label>1</label><figDesc>Figure 1: Programming Cocktails ontology's graphical notation.</figDesc></figure>
<figure xmlns="http://www.tei-c.org/ns/1.0" xml:id="fig_1"><head>Figure 2 :</head><label>2</label><figDesc>Figure 2: Open conceptual model for the Programming Cocktails ontology.</figDesc></figure>
<figure xmlns="http://www.tei-c.org/ns/1.0" xml:id="fig_2"><head>Figure 4 :</head><label>4</label><figDesc>Figure 4: Cocktail Identity Card for a multiplatform Covid-19 pass application.</figDesc></figure>
<figure xmlns="http://www.tei-c.org/ns/1.0" xml:id="fig_3"><head>Figure 5 :</head><label>5</label><figDesc>Figure 5: Hypothetical security risk augmentation for App1's Cocktail. This analysis would be recursively applied up to the System instance.</figDesc></figure>
			<note xmlns="http://www.tei-c.org/ns/1.0" place="foot" n="1" xml:id="foot_0">The instance of an ontological concept may also be called an individual.</note>
			<note xmlns="http://www.tei-c.org/ns/1.0" place="foot" n="2" xml:id="foot_1">Some instantiation relations are hidden in order to avoid cluttering the diagram.</note>
			<note xmlns="http://www.tei-c.org/ns/1.0" place="foot" n="3" xml:id="foot_2">That is not to say that these languages are inherently less dependent on other components, only that in this case, the model indicates a lower level of dependency.</note>
		</body>
		<back>

			<div type="acknowledgement">
<div xmlns="http://www.tei-c.org/ns/1.0"><head>Acknowledgments</head><p>This work has been supported by FCT -Fundação para a Ciência e Tecnologia within the R&amp;D Units Project Scope: UIDB/00319/2020. The work of Maria João was supported by national funds through FCT/MCTES (PIDDAC): CeDRI, UIDB/05757/2020 (DOI: 10.54499/UIDB/05757/2020) and UIDP/05757/2020 (DOI: 10.54499/UIDP/05757/2020); SusTEC, LA/P/0007/2020 (DOI: 10.54499/LA/P/0007/2020).</p></div>
			</div>

			<div type="references">

				<listBibl>

<biblStruct xml:id="b0">
	<analytic>
		<title level="a" type="main">A theory of software complexity</title>
		<author>
			<persName><forename type="first">A</forename><surname>Ghazarian</surname></persName>
		</author>
		<idno type="DOI">10.1109/GTSE.2015.11</idno>
	</analytic>
	<monogr>
		<title level="m">IEEE/ACM 4th SEMAT Workshop on a General Theory of Software Engineering</title>
				<imprint>
			<date type="published" when="2015">2015. 2015</date>
			<biblScope unit="page" from="29" to="32" />
		</imprint>
	</monogr>
</biblStruct>

<biblStruct xml:id="b1">
	<analytic>
		<title level="a" type="main">How much does software complexity matter for maintenance productivity? the link between team instability and diversity</title>
		<author>
			<persName><forename type="first">M</forename><surname>Benaroch</surname></persName>
		</author>
		<author>
			<persName><forename type="first">K</forename><surname>Lyytinen</surname></persName>
		</author>
		<idno type="DOI">10.1109/TSE.2022.3222119</idno>
	</analytic>
	<monogr>
		<title level="j">IEEE Transactions on Software Engineering</title>
		<imprint>
			<biblScope unit="volume">49</biblScope>
			<biblScope unit="page" from="2459" to="2475" />
			<date type="published" when="2023">2023</date>
		</imprint>
	</monogr>
</biblStruct>

<biblStruct xml:id="b2">
	<analytic>
		<title level="a" type="main">The research on software metrics and software complexity metrics</title>
		<author>
			<persName><forename type="first">T</forename><surname>Honglei</surname></persName>
		</author>
		<author>
			<persName><forename type="first">S</forename><surname>Wei</surname></persName>
		</author>
		<author>
			<persName><forename type="first">Z</forename><surname>Yanan</surname></persName>
		</author>
		<idno type="DOI">10.1109/IFCSTA.2009.39</idno>
	</analytic>
	<monogr>
		<title level="j">International Forum on Computer Science-Technology and Applications</title>
		<imprint>
			<biblScope unit="volume">1</biblScope>
			<biblScope unit="page" from="131" to="136" />
			<date type="published" when="2009">2009. 2009</date>
		</imprint>
	</monogr>
</biblStruct>

<biblStruct xml:id="b3">
	<analytic>
		<title level="a" type="main">Software complexity measurement based on complex network</title>
		<author>
			<persName><forename type="first">L</forename><surname>Hanyan</surname></persName>
		</author>
		<author>
			<persName><forename type="first">W</forename><surname>Shihai</surname></persName>
		</author>
		<author>
			<persName><forename type="first">L</forename><surname>Bin</surname></persName>
		</author>
		<author>
			<persName><forename type="first">X</forename><surname>Peng</surname></persName>
		</author>
		<idno type="DOI">10.1109/ICSESS.2017.8342910</idno>
	</analytic>
	<monogr>
		<title level="m">8th IEEE International Conference on Software Engineering and Service Science (ICSESS)</title>
				<imprint>
			<date type="published" when="2017">2017. 2017</date>
			<biblScope unit="page" from="262" to="265" />
		</imprint>
	</monogr>
</biblStruct>

<biblStruct xml:id="b4">
	<analytic>
		<title level="a" type="main">Analytical and comparison study of main web programming languages: Asp and php</title>
		<author>
			<persName><forename type="first">A</forename><forename type="middle">H</forename><surname>Odeh</surname></persName>
		</author>
		<idno type="DOI">10.18421/TEM84-58</idno>
		<ptr target="http://www.temjournal.com/content/84/TEMJournalNovember2019_1517_1522.pdf.doi:10.18421/TEM84-58" />
	</analytic>
	<monogr>
		<title level="j">TEM Journal</title>
		<imprint>
			<biblScope unit="volume">8</biblScope>
			<biblScope unit="page" from="1517" to="1522" />
			<date type="published" when="2019">2019</date>
		</imprint>
	</monogr>
</biblStruct>

<biblStruct xml:id="b5">
	<analytic>
		<title level="a" type="main">A comparison of common programming languages used in bioinformatics</title>
		<author>
			<persName><forename type="first">M</forename><surname>Fourment</surname></persName>
		</author>
		<author>
			<persName><forename type="first">M</forename><forename type="middle">R</forename><surname>Gillings</surname></persName>
		</author>
		<idno type="DOI">10.1186/1471-2105-9-82</idno>
		<idno>doi:</idno>
		<ptr target="10.1186/1471-2105-9-82" />
	</analytic>
	<monogr>
		<title level="j">BMC Bioinformatics</title>
		<imprint>
			<biblScope unit="volume">82</biblScope>
			<date type="published" when="2008">2008</date>
		</imprint>
	</monogr>
</biblStruct>

<biblStruct xml:id="b6">
	<analytic>
		<title level="a" type="main">Programming languages for data mining: a review</title>
		<author>
			<persName><forename type="first">N</forename><surname>Walia</surname></persName>
		</author>
		<author>
			<persName><forename type="first">A</forename><surname>Kalia</surname></persName>
		</author>
		<idno type="DOI">10.14445/22312803/IJCTT-V68I1P109</idno>
		<ptr target="https://ijcttjournal.org/archives/ijctt-v68i1p109.doi:10.14445/22312803/IJCTT-V68I1P109" />
	</analytic>
	<monogr>
		<title level="j">International Journal of Computer Trends and Technology</title>
		<imprint>
			<biblScope unit="volume">68</biblScope>
			<biblScope unit="page" from="38" to="41" />
			<date type="published" when="2020">2020</date>
		</imprint>
	</monogr>
</biblStruct>

<biblStruct xml:id="b7">
	<analytic>
		<title level="a" type="main">An ontology to understand programming cocktails</title>
		<author>
			<persName><forename type="first">A</forename><forename type="middle">C</forename><surname>Neto</surname></persName>
		</author>
		<author>
			<persName><forename type="first">M</forename><forename type="middle">J V</forename><surname>Pereira</surname></persName>
		</author>
		<author>
			<persName><forename type="first">P</forename><forename type="middle">R</forename><surname>Henriques</surname></persName>
		</author>
	</analytic>
	<monogr>
		<title level="m">Proceedings of the 19th Conference on Computer Science and Intelligence Systems</title>
				<editor>
			<persName><forename type="first">M</forename><surname>Ganzha</surname></persName>
		</editor>
		<editor>
			<persName><forename type="first">L</forename><surname>Maciaszek</surname></persName>
		</editor>
		<editor>
			<persName><forename type="first">M</forename><surname>Paprzycki</surname></persName>
		</editor>
		<editor>
			<persName><forename type="first">D</forename><surname>Ślęzak</surname></persName>
		</editor>
		<meeting>the 19th Conference on Computer Science and Intelligence Systems</meeting>
		<imprint>
			<publisher>IEEE</publisher>
			<date type="published" when="2024">2024</date>
		</imprint>
	</monogr>
	<note>To be published</note>
</biblStruct>

<biblStruct xml:id="b8">
	<analytic>
		<title level="a" type="main">Programmers&apos; affinity to languages</title>
		<author>
			<persName><forename type="first">A</forename><forename type="middle">Costa</forename><surname>Neto</surname></persName>
		</author>
		<author>
			<persName><forename type="first">C</forename><surname>Araújo</surname></persName>
		</author>
		<author>
			<persName><forename type="first">M</forename><forename type="middle">J V</forename><surname>Pereira</surname></persName>
		</author>
		<author>
			<persName><forename type="first">P</forename><forename type="middle">R</forename><surname>Henriques</surname></persName>
		</author>
		<idno type="DOI">10.4230/OASIcs.ICPEC.2021.3</idno>
		<ptr target="https://drops.dagstuhl.de/opus/volltexte/2021/14219.doi:10.4230/OASIcs.ICPEC.2021.3" />
	</analytic>
	<monogr>
		<title level="m">Open Access Series in Informatics (OASIcs)</title>
		<title level="s">Schloss Dagstuhl -Leibniz-Zentrum für Informatik</title>
		<imprint>
			<date type="published" when="2021">2021</date>
			<biblScope unit="volume">91</biblScope>
			<biblScope unit="page" from="1" to="7" />
		</imprint>
	</monogr>
</biblStruct>

<biblStruct xml:id="b9">
	<analytic>
		<title level="a" type="main">Value-focused investigation into programming languages affinity</title>
		<author>
			<persName><forename type="first">A</forename><forename type="middle">Costa</forename><surname>Neto</surname></persName>
		</author>
		<author>
			<persName><forename type="first">C</forename><surname>Araújo</surname></persName>
		</author>
		<author>
			<persName><forename type="first">M</forename><forename type="middle">J V</forename><surname>Pereira</surname></persName>
		</author>
		<author>
			<persName><forename type="first">P</forename><forename type="middle">R</forename><surname>Henriques</surname></persName>
		</author>
		<idno type="DOI">10.4230/OASIcs.ICPEC.2022.1</idno>
		<ptr target="https://drops.dagstuhl.de/opus/volltexte/2022/16605.doi:10.4230/OASIcs.ICPEC.2022.1" />
	</analytic>
	<monogr>
		<title level="m">Open Access Series in Informatics (OASIcs)</title>
		<title level="s">Schloss Dagstuhl -Leibniz-Zentrum für Informatik</title>
		<imprint>
			<date type="published" when="2022">2022</date>
			<biblScope unit="volume">102</biblScope>
			<biblScope unit="page" from="1" to="12" />
		</imprint>
	</monogr>
</biblStruct>

<biblStruct xml:id="b10">
	<analytic>
		<title level="a" type="main">A large-scale empirical study on the cognitive complexity of software</title>
		<author>
			<persName><forename type="first">V</forename><surname>Chiew</surname></persName>
		</author>
		<author>
			<persName><forename type="first">Y</forename><surname>Wang</surname></persName>
		</author>
		<idno type="DOI">10.1109/CCECE.2010.5575116</idno>
	</analytic>
	<monogr>
		<title level="j">CCECE</title>
		<imprint>
			<biblScope unit="volume">2010</biblScope>
			<biblScope unit="page" from="1" to="4" />
			<date type="published" when="2010">2010</date>
		</imprint>
	</monogr>
</biblStruct>

<biblStruct xml:id="b11">
	<analytic>
		<title level="a" type="main">Cognitive load during problem solving: Effects on learning</title>
		<author>
			<persName><forename type="first">J</forename><surname>Sweller</surname></persName>
		</author>
		<idno type="DOI">10.1207/s15516709cog1202_4</idno>
		<ptr target="https://doi.org/10.1207/s15516709cog1202_4" />
	</analytic>
	<monogr>
		<title level="j">Cognitive Science</title>
		<imprint>
			<biblScope unit="volume">12</biblScope>
			<biblScope unit="page" from="257" to="285" />
			<date type="published" when="1988">1988</date>
		</imprint>
	</monogr>
</biblStruct>

				</listBibl>
			</div>
		</back>
	</text>
</TEI>
